X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDict.h;h=316f7ccdea9867e8fe03e9f616a5a53cf847d5c3;hb=7796d0740430edfba773ad0d20bc159c6cafcbd3;hp=9931f7bcab26a123c54d07c08c1f7bd776cf3178;hpb=2012716d624d631dcdb825fdd4470908e115a717;p=gdcm.git diff --git a/src/gdcmDict.h b/src/gdcmDict.h index 9931f7bc..316f7ccd 100644 --- a/src/gdcmDict.h +++ b/src/gdcmDict.h @@ -3,12 +3,12 @@ Program: gdcm Module: $RCSfile: gdcmDict.h,v $ Language: C++ - Date: $Date: 2004/06/20 18:08:47 $ - Version: $Revision: 1.15 $ + Date: $Date: 2005/09/03 18:24:10 $ + Version: $Revision: 1.41 $ 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. + http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR @@ -19,74 +19,67 @@ #ifndef GDCMDICT_H #define GDCMDICT_H -#include "gdcmCommon.h" +#include "gdcmBase.h" #include "gdcmDictEntry.h" #include +#include // for ifstream #include #include -//----------------------------------------------------------------------------- -typedef std::map TagKeyHT; -typedef std::map TagNameHT; +namespace gdcm +{ //----------------------------------------------------------------------------- -/* - * \defgroup gdcmDict - * \brief gdcmDict 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. +typedef std::string DictKey; +typedef std::map TagKeyHT; +//----------------------------------------------------------------------------- +/** + * \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. * 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 gdcmDictSet + * \see DictSet */ -class GDCM_EXPORT gdcmDict { +class GDCM_EXPORT Dict : public Base +{ public: - gdcmDict(std::string & FileName); - ~gdcmDict(); + Dict(); + Dict(std::string const &filename); + ~Dict(); + bool AddDict(std::string const &filename); + bool RemoveDict(std::string const &filename); // Print - void Print(std::ostream &os = std::cout); - void PrintByKey(std::ostream &os = std::cout); - void PrintByName(std::ostream &os = std::cout); + void Print(std::ostream &os = std::cout, std::string const &indent = ""); // Entries - bool AddNewEntry (gdcmDictEntry *NewEntry); - bool ReplaceEntry(gdcmDictEntry *NewEntry); - bool RemoveEntry (TagKey key); - bool RemoveEntry (guint16 group, guint16 element); + bool AddEntry(DictEntry const &newEntry); + bool ReplaceEntry(DictEntry const &newEntry); + bool RemoveEntry (TagKey const &key); + bool RemoveEntry (uint16_t group, uint16_t elem); + void ClearEntry(); // Tag - gdcmDictEntry *GetDictEntryByName(TagName name); - gdcmDictEntry *GetDictEntryByNumber(guint16 group, guint16 element); - - std::list *GetDictEntryNames(void); - std::map > * - GetDictEntryNamesByCategory(void); + DictEntry *GetEntry(uint16_t group, uint16_t elem); + DictEntry *GetEntry(TagKey const &key); - /** - * \ingroup gdcmDict - * \brief returns a ref to the Dicom Dictionary H table (map) - * return the Dicom Dictionary H table - */ - inline TagKeyHT & GetEntriesByKey(void) { return KeyHt; } + DictEntry *GetFirstEntry(); + DictEntry *GetNextEntry(); - /** - * \ingroup gdcmDict - * \brief returns a ref to the Dicom Dictionary H table (map) - * return the Dicom Dictionary H table - */ - inline TagNameHT & GetEntriesByName(void) { return NameHt; } - private: + void DoTheLoadingJob(std::ifstream &ifs); + /// ASCII file holding the Dictionnary - std::string filename; - /// Access through TagKey (see alternate access with NameHt) - TagKeyHT KeyHt; - /// Access through TagName (see alternate access with KeyHt) - TagNameHT NameHt; + std::string Filename; + + /// Access through TagKey + TagKeyHT KeyHt; + TagKeyHT::iterator ItKeyHt; }; +} // end namespace gdcm //----------------------------------------------------------------------------- #endif