X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDictSet.h;h=4256ad8e3fc29defb1f33f0b6338ef1c05a3a42e;hb=bed33c23d52354bfe0c3714493754c60c05cb320;hp=0e2aed0b3a39a207fc4c6dface09f26b3f28b9fd;hpb=565a47ec4e037897aaf770aeccc5d67d7ad7b478;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index 0e2aed0b..4256ad8e 100644 --- a/src/gdcmDictSet.h +++ b/src/gdcmDictSet.h @@ -3,44 +3,45 @@ #ifndef GDCMDICTSET_H #define GDCMDICTSET_H +#include "gdcmDict.h" #include #include -#include "gdcmCommon.h" -#include "gdcmDict.h" - -//////////////////////////////////////////////////////////////////////////// -// Container for managing a set of loaded dictionaries. Sharing dictionaries -// should avoid : -// * reloading an allready loaded dictionary, -// * having many in memory representations of the same dictionary. -typedef string DictKey; -typedef map DictSetHT; +typedef std::string DictKey; +typedef std::map DictSetHT; +/* + * \defgroup gdcmDictSet + * \brief Container for managing a set of loaded dictionaries. + * \note Hopefully, sharing dictionaries should avoid + * \par reloading an already loaded dictionary (saving time) + * \par having many in memory representations of the same dictionary + * (saving memory). + */ class GDCM_EXPORT gdcmDictSet { private: - DictSetHT dicts; + /// Hash table of all dictionaries contained in this gdcmDictSet + DictSetHT Dicts; + /// Directory path to dictionaries + std::string DictPath; int AppendDict(gdcmDict* NewDict); - void LoadDictFromFile(string filename, DictKey); -private: - static string DictPath; // Directory path to dictionaries - static string BuildDictPath(void); - static gdcmDict* DefaultPubDict; + void LoadDictFromFile(std::string FileName, DictKey Name); + std::string BuildDictPath(void); public: - static list * GetPubDictTagNames(void); - static map >* GetPubDictTagNamesByCategory(void); - static gdcmDict* LoadDefaultPubDict(void); + std::list * GetPubDictTagNames(void); + std::map >* + GetPubDictTagNamesByCategory(void); - gdcmDictSet(void); - // TODO Swig int LoadDictFromFile(string filename); + // TODO Swig int LoadDictFromFile(std::string filename); // QUESTION: the following function might not be thread safe !? Maybe // we need some mutex here, to avoid concurent creation of // the same dictionary !?!?! - // TODO Swig int LoadDictFromName(string filename); - // TODO Swig int LoadAllDictFromDirectory(string DirectoryName); - // TODO Swig string* GetAllDictNames(); - // - void Print(ostream&); + // TODO Swig int LoadDictFromName(std::string filename); + // TODO Swig int LoadAllDictFromDirectory(std::string DirectoryName); + // TODO Swig std::string* GetAllDictNames(); + gdcmDictSet(void); + ~gdcmDictSet(void); + void Print(std::ostream& os); gdcmDict* GetDict(DictKey DictName); gdcmDict* GetDefaultPubDict(void); };