X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDict.h;h=b901f57a9b78daef8f7e495fab0055c05570a3c2;hb=41cc62fb86c116bd195581980c27480c213c958b;hp=dfab30c3557c9423fcd9aabf2c45b3aa48628411;hpb=05abd393cf82392c894dd1d852e2273b0648671d;p=gdcm.git diff --git a/src/gdcmDict.h b/src/gdcmDict.h index dfab30c3..b901f57a 100644 --- a/src/gdcmDict.h +++ b/src/gdcmDict.h @@ -1,15 +1,20 @@ // gdcmDict.h - +//----------------------------------------------------------------------------- #ifndef GDCMDICT_H #define GDCMDICT_H -#include #include "gdcmCommon.h" #include "gdcmDictEntry.h" +#include +#include +#include + +//----------------------------------------------------------------------------- typedef std::map TagKeyHT; typedef std::map TagNameHT; +//----------------------------------------------------------------------------- /* * \defgroup gdcmDict * \brief gdcmDict acts a memory representation of a dicom dictionary i.e. @@ -21,25 +26,44 @@ typedef std::map TagNameHT; * \see gdcmDictSet */ class GDCM_EXPORT gdcmDict { - std::string name; +public: + gdcmDict(std::string & FileName); + ~gdcmDict(); + +// 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 (gdcmDictEntry *NewEntry); + bool ReplaceEntry(gdcmDictEntry *NewEntry); + bool RemoveEntry (TagKey key); + bool RemoveEntry (guint16 group, guint16 element); + +// Tag + gdcmDictEntry *GetDictEntryByName(TagName name); + gdcmDictEntry *GetDictEntryByNumber(guint16 group, guint16 element); + + std::list *GetDictEntryNames(void); + std::map > * + GetDictEntryNamesByCategory(void); + + /** + * \ingroup gdcmDict + * \brief returns a ref to the Dicom Dictionary H table (map) + * return the Dicom Dictionary H table + */ + inline TagKeyHT & gdcmDict::GetEntries(void) { return KeyHt; } + +private: std::string filename; + /// Access through TagKey (see alternate access with NameHt) TagKeyHT KeyHt; /// Access through TagName (see alternate access with KeyHt) TagNameHT NameHt; -public: - gdcmDict(std::string & FileName); - ~gdcmDict(); - int AddNewEntry (gdcmDictEntry* NewEntry); - int ReplaceEntry(gdcmDictEntry* NewEntry); - int RemoveEntry (TagKey key); - int RemoveEntry (guint16 group, guint16 element); - gdcmDictEntry * GetTagByNumber(guint16 group, guint16 element); - gdcmDictEntry * GetTagByName(TagName name); - void Print(ostream&); - void PrintByKey(ostream&); - void PrintByName(ostream&); - TagKeyHT & GetEntries(void) { return KeyHt; } }; +//----------------------------------------------------------------------------- #endif