X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDict.h;h=ab0b99efc20f93a8a43261a8bc972c7855cb0b2a;hb=5887c4beef24959af83e43efad0bb86acac9339e;hp=6fcfd93a79cad98d69a9c4ba94cadbd91b3a5854;hpb=1d69b92978803204089d270599133917d944c651;p=gdcm.git diff --git a/src/gdcmDict.h b/src/gdcmDict.h index 6fcfd93a..ab0b99ef 100644 --- a/src/gdcmDict.h +++ b/src/gdcmDict.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDict.h,v $ Language: C++ - Date: $Date: 2004/10/12 04:35:45 $ - Version: $Revision: 1.19 $ + Date: $Date: 2005/01/11 15:15:38 $ + Version: $Revision: 1.30 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -19,70 +19,68 @@ #ifndef GDCMDICT_H #define GDCMDICT_H -#include "gdcmCommon.h" +#include "gdcmBase.h" #include "gdcmDictEntry.h" #include #include #include + namespace gdcm { //----------------------------------------------------------------------------- -typedef std::map TagKeyHT; -typedef std::map TagNameHT; - +typedef std::string DictKey; +typedef std::map TagKeyHT; +typedef std::list EntryNamesList; +typedef std::map > EntryNamesByCatMap; //----------------------------------------------------------------------------- -/* - * \defgroup Dict +/** + * \ingroup Dict * \brief Dict acts a memory representation of a dicom dictionary i.e. - * it is a container for a collection of dictionary entries. The - * dictionary is loaded from in an ascii file. + * it is a container for a collection of dictionary entries. + * The dictionary is loaded from in an ascii file. * There should be a single public dictionary (THE dictionary of * the actual DICOM v3) but as many shadow dictionaries as imagers * combined with all software versions... * \see DictSet */ -class GDCM_EXPORT Dict +class GDCM_EXPORT Dict : public Base { public: - Dict(std::string const & FileName); + Dict(std::string const & filename); ~Dict(); // Print void Print(std::ostream &os = std::cout); - void PrintByKey(std::ostream &os = std::cout); - void PrintByName(std::ostream &os = std::cout); // Entries - bool AddNewEntry (DictEntry *NewEntry); - bool ReplaceEntry(DictEntry *NewEntry); - bool RemoveEntry (TagKey key); + bool AddNewEntry (DictEntry const &newEntry); + bool ReplaceEntry(DictEntry const &newEntry); + bool RemoveEntry (TagKey const &key); bool RemoveEntry (uint16_t group, uint16_t element); // Tag - DictEntry *GetDictEntryByName(TagName name); - DictEntry *GetDictEntryByNumber(uint16_t group, uint16_t element); + DictEntry *GetDictEntry(uint16_t group, uint16_t element); - std::list *GetDictEntryNames(); - std::map > * - GetDictEntryNamesByCategory(); + // EntryNamesList *GetDictEntryNames(); + // EntryNamesByCatMap *GetDictEntryNamesByCategory(); /// \brief Returns a ref to the Dicom Dictionary H table (map) /// @return the Dicom Dictionary H table - TagKeyHT & GetEntriesByKey() { return KeyHt; } + const TagKeyHT & GetEntriesByKey() const { return KeyHt; } /// \brief Returns a ref to the Dicom Dictionary H table (map) /// @return the Dicom Dictionary H table - TagNameHT & GetEntriesByName() { return NameHt; } private: /// ASCII file holding the Dictionnary std::string Filename; - /// Access through TagKey (see alternate access with NameHt) + + /// Access through TagKey TagKeyHT KeyHt; - /// Access through TagName (see alternate access with KeyHt) - TagNameHT NameHt; + }; } // end namespace gdcm