X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=src%2FgdcmDictSet.h;h=751be5f83e208322cd4b9b57541dc182901ac51c;hb=66553b88cd6daaac48ac62a910199cb2fff276f6;hp=0e2aed0b3a39a207fc4c6dface09f26b3f28b9fd;hpb=565a47ec4e037897aaf770aeccc5d67d7ad7b478;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index 0e2aed0b..751be5f8 100644 --- a/src/gdcmDictSet.h +++ b/src/gdcmDictSet.h @@ -5,33 +5,32 @@ #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; +/* + * \defgroup gdcmDictSet + * \brief Container for managing a set of loaded dictionaries. + * \note Hopefully, sharing dictionaries should avoid + * \par reloading an allready 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 + 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; + string BuildDictPath(void); public: - static list * GetPubDictTagNames(void); - static map >* GetPubDictTagNamesByCategory(void); - static gdcmDict* LoadDefaultPubDict(void); + list * GetPubDictTagNames(void); + map >* GetPubDictTagNamesByCategory(void); - gdcmDictSet(void); // TODO Swig int LoadDictFromFile(string filename); // QUESTION: the following function might not be thread safe !? Maybe // we need some mutex here, to avoid concurent creation of @@ -39,7 +38,8 @@ public: // TODO Swig int LoadDictFromName(string filename); // TODO Swig int LoadAllDictFromDirectory(string DirectoryName); // TODO Swig string* GetAllDictNames(); - // + gdcmDictSet(void); + ~gdcmDictSet(void); void Print(ostream&); gdcmDict* GetDict(DictKey DictName); gdcmDict* GetDefaultPubDict(void);