X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDictSet.h;h=c4cca7c9944541ff74a64f19140eb332423961cd;hb=0accc3e4b95c96903d4fb6a792d657bf1e509375;hp=a65677523650943954f30001d1236469d02033d4;hpb=15d7b1b38f5ddb59d395e0e4e3f9b0250eb90eec;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index a6567752..c4cca7c9 100644 --- a/src/gdcmDictSet.h +++ b/src/gdcmDictSet.h @@ -1,4 +1,20 @@ -// gdcmDictSet.h +/*========================================================================= + + Program: gdcm + Module: $RCSfile: gdcmDictSet.h,v $ + Language: C++ + Date: $Date: 2004/06/20 18:08:47 $ + Version: $Revision: 1.20 $ + + 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.htm 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. + +=========================================================================*/ #ifndef GDCMDICTSET_H #define GDCMDICTSET_H @@ -10,6 +26,7 @@ typedef std::string DictKey; typedef std::map DictSetHT; +//----------------------------------------------------------------------------- /* * \defgroup gdcmDictSet * \brief Container for managing a set of loaded dictionaries. @@ -19,21 +36,7 @@ typedef std::map DictSetHT; * (saving memory). */ class GDCM_EXPORT gdcmDictSet { -private: - /// Hash table of all dictionaries contained in this gdcmDictSet - DictSetHT Dicts; - /// Directory path to dictionaries - std::string DictPath; - - int AppendDict(gdcmDict* NewDict); - void LoadDictFromFile(std::string FileName, DictKey Name); - std::string BuildDictPath(void); - public: - std::list * GetPubDictTagNames(void); - std::map >* - GetPubDictTagNamesByCategory(void); - // 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 @@ -41,12 +44,38 @@ public: // 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); + gdcmDictSet(void); + ~gdcmDictSet(void); + + void Print(std::ostream& os); + + std::list *GetPubDictEntryNames(void); + std::map > * + GetPubDictEntryNamesByCategory(void); - gdcmDict* GetDict(DictKey DictName); - gdcmDict* GetDefaultPubDict(void); + gdcmDict *LoadDictFromFile(std::string FileName, DictKey Name); + + gdcmDict *GetDict(DictKey DictName); + gdcmDict *GetDefaultPubDict(void); + + gdcmDictEntry *NewVirtualDictEntry(guint16 group, guint16 element, + std::string vr = "Unknown", + std::string fourth = "Unknown", + std::string name = "Unknown"); + + static std::string BuildDictPath(void); + +protected: + bool AppendDict(gdcmDict *NewDict,DictKey Name); + +private: + /// Hash table of all dictionaries contained in this gdcmDictSet + DictSetHT Dicts; + /// Directory path to dictionaries + std::string DictPath; + /// H table for the on the fly created gdcmDictEntries + std::map virtualEntry; }; +//----------------------------------------------------------------------------- #endif