X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDictSet.h;h=3cc5eca7ed2c192b22f792b25304fa47b89210d3;hb=3bfc348942b85891d4f2a36782e0726df4e4b4c3;hp=895459d094903057916db82a368bb447deeaa0b3;hpb=867b8ef63054497249cc3a0138107383d60351dc;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index 895459d0..3cc5eca7 100644 --- a/src/gdcmDictSet.h +++ b/src/gdcmDictSet.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDictSet.h,v $ Language: C++ - Date: $Date: 2004/10/18 02:17:07 $ - Version: $Revision: 1.28 $ + Date: $Date: 2005/09/02 07:10:03 $ + Version: $Revision: 1.45 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -19,66 +19,73 @@ #ifndef GDCMDICTSET_H #define GDCMDICTSET_H +#include "gdcmBase.h" #include "gdcmDict.h" + #include #include namespace gdcm { -typedef std::string DictKey; typedef std::map DictSetHT; +typedef std::string ExtendedTagKey; +typedef std::map ExtendedTagKeyHT; //----------------------------------------------------------------------------- -/* - * \defgroup DictSet - * \brief Container for managing a set of loaded dictionaries. +/** + * \brief Container for managing a set of loaded dictionaries (Dict). * \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 DictSet +class GDCM_EXPORT DictSet : public Base { public: DictSet(); ~DictSet(); - void Print(std::ostream& os); + void Print(std::ostream &os = std::cout, std::string const &indent = "" ); + + // Probabely useless ! + //EntryNamesList *GetPubDictEntryNames(); + //EntryNamesByCatMap *GetPubDictEntryNamesByCategory(); - EntryNamesList * GetPubDictEntryNames(); - EntryNamesByCatMap * GetPubDictEntryNamesByCategory(); + Dict *LoadDictFromFile( std::string const &fileName, + DictKey const &name ); - Dict* LoadDictFromFile( std::string const & fileName, - DictKey const & name ); + Dict *GetDict( DictKey const &DictName ); - Dict* GetDict( DictKey const & DictName ); + /// \brief Returns the default reference DICOM V3 public dictionary. + Dict* GetDefaultPubDict() { return GetDict(PUB_DICT_NAME); } - /// \brief Retrieve the default reference DICOM V3 public dictionary. - Dict* GetDefaultPubDict() { return GetDict(PUB_DICT_NAME); }; + // \ brief Returns the virtual references DICOM dictionary. + // \ warning : not end user intended + // Dict *GetVirtualDict() { return &VirtualEntries; } - // \brief Retrieve the virtual reference DICOM dictionary. - // \warning : not end user intended - // Dict* GetVirtualDict() { return &VirtualEntry; }; + DictEntry *NewVirtualDictEntry(uint16_t group, uint16_t elem, + TagName vr = GDCM_UNKNOWN, + TagName vm = GDCM_UNKNOWN, + TagName name = GDCM_UNKNOWN); - DictEntry* NewVirtualDictEntry(uint16_t group, uint16_t element, - TagName vr = "Unknown", - TagName fourth = "Unknown", - TagName name = "Unknown"); + Dict *GetFirstEntry(); + Dict *GetNextEntry(); static std::string BuildDictPath(); protected: - bool AppendDict(Dict *NewDict, DictKey const & name); + bool AppendDict(Dict *NewDict, DictKey const &name); private: /// Hash table of all dictionaries contained in this DictSet DictSetHT Dicts; + DictSetHT::iterator ItDictHt; /// Directory path to dictionaries std::string DictPath; /// H table for the on the fly created DictEntries - TagKeyHT VirtualEntry; + ExtendedTagKeyHT VirtualEntries; }; } // end namespace gdcm