X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmTS.cxx;h=b648b26bbb9e018bb2612108fe7fae8726147a1d;hb=a23d3b0e36743664f22f42269224f305ccf50fdb;hp=29ab1be0a9c6d52731fd5d3e7ad488c765ccc785;hpb=ecc068684313c5f9f1050de920afc7e413041220;p=gdcm.git diff --git a/src/gdcmTS.cxx b/src/gdcmTS.cxx index 29ab1be0..b648b26b 100644 --- a/src/gdcmTS.cxx +++ b/src/gdcmTS.cxx @@ -1,5 +1,5 @@ // gdcmTS.cxx - +//----------------------------------------------------------------------------- #include #include "gdcmTS.h" @@ -10,7 +10,18 @@ #endif #define DICT_TS "dicomTS.dic" -gdcmTS::gdcmTS(void) { +#include +#ifdef GDCM_NO_ANSI_STRING_STREAM +# include +# define ostringstream ostrstream +# else +# include +#endif + +//----------------------------------------------------------------------------- +// Constructor / Destructor +gdcmTS::gdcmTS(void) +{ std::string filename=gdcmDictSet::BuildDictPath() + std::string(DICT_TS); std::ifstream from(filename.c_str()); dbg.Error(!from, "gdcmTS::gdcmTS: can't open dictionary",filename.c_str()); @@ -23,11 +34,12 @@ gdcmTS::gdcmTS(void) { eatwhite(from); from.getline(buff, 1024, ' '); key = buff; + eatwhite(from); from.getline(buff, 1024, '\n'); name = buff; - if(key!="") + if(key!="") { ts[key]=name; } @@ -35,16 +47,47 @@ gdcmTS::gdcmTS(void) { from.close(); } -gdcmTS::~gdcmTS() { +gdcmTS::~gdcmTS() +{ ts.clear(); } -int gdcmTS::Count(TSKey key) { +//----------------------------------------------------------------------------- +// Print +/** + * \ingroup gdcmVR + * \brief Print all + * @param os The output stream to be written to. + */ +void gdcmTS::Print(std::ostream &os) +{ + std::ostringstream s; + + for (TSHT::iterator it = ts.begin(); it != ts.end(); ++it) + { + s << "TS : "<first<<" = "<second<