-// gdcmTS.cxx
-//-----------------------------------------------------------------------------
-#include <fstream>
-#include <string>
-#include <iostream>
-#ifdef GDCM_NO_ANSI_STRING_STREAM
-# include <strstream>
-# define ostringstream ostrstream
-# else
-# include <sstream>
-#endif
+/*=========================================================================
+
+ Program: gdcm
+ Module: $RCSfile: gdcmTS.cxx,v $
+ Language: C++
+ Date: $Date: 2004/10/08 04:43:38 $
+ Version: $Revision: 1.25 $
+
+ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
+ l'Image). All rights reserved. See Doc/License.txt or
+ http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
+
+ This software is distributed WITHOUT ANY WARRANTY; without even
+ the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ PURPOSE. See the above copyright notices for more information.
+
+=========================================================================*/
#include "gdcmTS.h"
#include "gdcmDebug.h"
#include "gdcmUtil.h"
#include "gdcmDictSet.h"
-#ifndef PUB_DICT_PATH
-# define PUB_DICT_PATH "../Dicts/"
-#endif
-#define DICT_TS "dicomTS.dic"
-
+#include <fstream>
+#include <string>
+#include <iostream>
//-----------------------------------------------------------------------------
// Constructor / Destructor
-gdcmTS::gdcmTS(void)
+gdcmTS::gdcmTS()
{
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());
- char buff[1024];
std::string key;
std::string name;
- while (!from.eof()) {
- eatwhite(from);
- from.getline(buff, 1024, ' ');
- key = buff;
+ while (!from.eof())
+ {
+ from >> key;
- eatwhite(from);
- from.getline(buff, 1024, '\n');
- name = buff;
+ from >> std::ws; // used to be eatwhite(from);
+ std::getline(from, name); /// MEMORY LEAK
- if(key!="")
+ if(key!="")
{
ts[key]=name;
}
from.close();
}
+//-----------------------------------------------------------------------------
gdcmTS::~gdcmTS()
{
ts.clear();
std::string gdcmTS::GetValue(TSKey key)
{
- if (ts.count(key) == 0)
- return (GDCM_UNFOUND);
+ if (ts.count(key) == 0)
+ {
+ return GDCM_UNFOUND;
+ }
return ts[key];
}