X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDictSet.h;h=c4cca7c9944541ff74a64f19140eb332423961cd;hb=00b6e0ddcbdbd41252e03732783f65efe5f52526;hp=4256ad8e3fc29defb1f33f0b6338ef1c05a3a42e;hpb=29bdd1e88a28b6267618f633f304e1154537ce7b;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index 4256ad8e..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,19 +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 @@ -39,11 +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); - gdcmDict* GetDict(DictKey DictName); - gdcmDict* GetDefaultPubDict(void); + gdcmDictSet(void); + ~gdcmDictSet(void); + + void Print(std::ostream& os); + + std::list *GetPubDictEntryNames(void); + std::map > * + GetPubDictEntryNamesByCategory(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