X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDict.h;h=d72fec8df51e529bdad7e1a41f085bfe45bfa18f;hb=fc4f7706c78baf3f60474c06d871b82db221f37b;hp=68aacb933e26a4cc9007b9393cd057022c2c299f;hpb=67aacdcd9af99ca00b8333adaac5057d95912bff;p=gdcm.git diff --git a/src/gdcmDict.h b/src/gdcmDict.h index 68aacb93..d72fec8d 100644 --- a/src/gdcmDict.h +++ b/src/gdcmDict.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDict.h,v $ Language: C++ - Date: $Date: 2005/09/02 07:00:04 $ - Version: $Revision: 1.40 $ + Date: $Date: 2007/08/22 16:14:03 $ + Version: $Revision: 1.51 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -16,22 +16,24 @@ =========================================================================*/ -#ifndef GDCMDICT_H -#define GDCMDICT_H +#ifndef _GDCMDICT_H_ +#define _GDCMDICT_H_ -#include "gdcmBase.h" +#include "gdcmRefCounter.h" #include "gdcmDictEntry.h" #include +#include // for ifstream #include #include -namespace gdcm +namespace GDCM_NAME_SPACE { //----------------------------------------------------------------------------- typedef std::string DictKey; -typedef std::map TagKeyHT; +typedef std::map TagKeyHT; + //----------------------------------------------------------------------------- /** * \brief Dict acts a memory representation of a dicom dictionary i.e. @@ -42,12 +44,15 @@ typedef std::map TagKeyHT; * combined with all software versions... * \see DictSet */ -class GDCM_EXPORT Dict : public Base +class GDCM_EXPORT Dict : public RefCounter { + gdcmTypeMacro(Dict); + public: - Dict(); - Dict(std::string const &filename); - ~Dict(); +/// \brief Contructs an empty Dict with a RefCounter + static Dict *New() {return new Dict();} +/// \brief Contructs a Dict with a RefCounter + static Dict *New(std::string const &filename) {return new Dict(filename);} bool AddDict(std::string const &filename); bool RemoveDict(std::string const &filename); @@ -55,8 +60,8 @@ public: void Print(std::ostream &os = std::cout, std::string const &indent = ""); // Entries - bool AddEntry(DictEntry const &newEntry); - bool ReplaceEntry(DictEntry const &newEntry); + bool AddEntry(DictEntry *newEntry); + // bool ReplaceEntry(DictEntry *newEntry); // useless ? bool RemoveEntry (TagKey const &key); bool RemoveEntry (uint16_t group, uint16_t elem); void ClearEntry(); @@ -68,6 +73,11 @@ public: DictEntry *GetFirstEntry(); DictEntry *GetNextEntry(); +protected: + Dict(); + Dict(std::string const &filename); + ~Dict(); + private: void DoTheLoadingJob(std::ifstream &ifs); @@ -76,6 +86,7 @@ private: /// Access through TagKey TagKeyHT KeyHt; + /// Iterator for the entries TagKeyHT::iterator ItKeyHt; }; } // end namespace gdcm