X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDictSet.h;h=9e2e2d777580a759e99c168c6a4d5d67d0e32a82;hb=bd7bec4c367d671a9da358584e98a8ec29bb641e;hp=89b1ff883c9da962ffe99442d1f297ea0d7abffc;hpb=a2040ffd26fc9a3c835b6c45b92a808f1d001b36;p=gdcm.git diff --git a/src/gdcmDictSet.h b/src/gdcmDictSet.h index 89b1ff88..9e2e2d77 100644 --- a/src/gdcmDictSet.h +++ b/src/gdcmDictSet.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDictSet.h,v $ Language: C++ - Date: $Date: 2005/01/05 15:38:28 $ - Version: $Revision: 1.31 $ + Date: $Date: 2007/08/22 16:14:04 $ + Version: $Revision: 1.55 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -16,70 +16,73 @@ =========================================================================*/ -#ifndef GDCMDICTSET_H -#define GDCMDICTSET_H +#ifndef _GDCMDICTSET_H +#define _GDCMDICTSET_H -#include "gdcmBase.h" +#include "gdcmRefCounter.h" #include "gdcmDict.h" +#include "gdcmGlobal.h" #include #include -namespace gdcm +namespace GDCM_NAME_SPACE { +//----------------------------------------------------------------------------- typedef std::map DictSetHT; //----------------------------------------------------------------------------- -/* - * \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 + * - reloading an already loaded dictionary (saving time) + * - having many in memory representations of the same dictionary * (saving memory). */ -class GDCM_EXPORT DictSet : public Base +class GDCM_EXPORT DictSet : public RefCounter { -public: - DictSet(); - ~DictSet(); + gdcmTypeMacro(DictSet); - void Print(std::ostream& os); +public: +/// \brief Contructs a DictSet with a RefCounter + static DictSet *New() {return new DictSet();} - EntryNamesList * GetPubDictEntryNames(); - EntryNamesByCatMap * GetPubDictEntryNamesByCategory(); + void Print(std::ostream &os = std::cout, std::string const &indent = "" ); - Dict* LoadDictFromFile( std::string const & fileName, - DictKey const & name ); + // Probabely useless ! + //EntryNamesList *GetPubDictEntryNames(); + //EntryNamesByCatMap *GetPubDictEntryNamesByCategory(); - Dict* GetDict( DictKey const & DictName ); + Dict *LoadDictFromFile( std::string const &fileName, + DictKey const &name ); - /// \brief Retrieve the default reference DICOM V3 public dictionary. - Dict* GetDefaultPubDict() { return GetDict(PUB_DICT_NAME); }; + Dict *GetDict( DictKey const &DictName ); - // \brief Retrieve the virtual reference DICOM dictionary. - // \warning : not end user intended - // Dict* GetVirtualDict() { return &VirtualEntry; }; + /// \brief Returns the default reference DICOM V3 public dictionary. + //Dict* GetDefaultPubDict() { return GetDict(PUB_DICT_NAME); } + Dict* GetDefaultPubDict() { return Global::DefaultPubDict; } + + // \ brief Returns the virtual references DICOM dictionary. + // \ warning : not end user intended + // Dict *GetVirtualDict() { return &VirtualEntries; } - DictEntry* NewVirtualDictEntry(uint16_t group, uint16_t element, - TagName vr = GDCM_UNKNOWN, - TagName fourth = GDCM_UNKNOWN, - TagName name = GDCM_UNKNOWN); + Dict *GetFirstDict(); + Dict *GetNextDict(); static std::string BuildDictPath(); protected: - bool AppendDict(Dict *NewDict, DictKey const & name); + DictSet(); + ~DictSet(); private: /// Hash table of all dictionaries contained in this DictSet DictSetHT Dicts; + /// Iterator to visit the Dictionaries of a given DictSet + DictSetHT::iterator ItDictHt; /// Directory path to dictionaries std::string DictPath; - - /// H table for the on the fly created DictEntries - TagKeyHT VirtualEntry; }; } // end namespace gdcm