// gdcmDictSet.h
-
+//-----------------------------------------------------------------------------
#ifndef GDCMDICTSET_H
#define GDCMDICTSET_H
typedef std::string DictKey;
typedef std::map<DictKey, gdcmDict*> DictSetHT;
+//-----------------------------------------------------------------------------
/*
* \defgroup gdcmDictSet
* \brief Container for managing a set of loaded dictionaries.
* (saving memory).
*/
class GDCM_EXPORT gdcmDictSet {
-private:
- /// Hash table of all dictionaries contained in this gdcmDictSet
- DictSetHT Dicts;
- /// Directory path to dictionaries
- std::string DictPath;
- int AppendDict(gdcmDict* NewDict);
- void LoadDictFromFile(std::string FileName, DictKey Name);
- std::string BuildDictPath(void);
public:
- std::list<std::string> * GetPubDictTagNames(void);
- std::map<std::string, std::list<std::string> >*
- GetPubDictTagNamesByCategory(void);
-
// TODO Swig int LoadDictFromFile(std::string filename);
// QUESTION: the following function might not be thread safe !? Maybe
// we need some mutex here, to avoid concurent creation of
// TODO Swig int LoadDictFromName(std::string filename);
// TODO Swig int LoadAllDictFromDirectory(std::string DirectoryName);
// TODO Swig std::string* GetAllDictNames();
- gdcmDictSet(void);
- ~gdcmDictSet(void);
- void Print(std::ostream& os);
- gdcmDict* GetDict(DictKey DictName);
- gdcmDict* GetDefaultPubDict(void);
+ gdcmDictSet(void);
+ ~gdcmDictSet(void);
+
+ void Print(std::ostream& os);
+
+ std::list<std::string> *GetPubDictEntryNames(void);
+ std::map<std::string, std::list<std::string> > *
+ GetPubDictEntryNamesByCategory(void);
+
+ gdcmDict *LoadDictFromFile(std::string FileName, DictKey Name);
+
+ gdcmDict *GetDict(DictKey DictName);
+ gdcmDict *GetDefaultPubDict(void);
+
+ gdcmDictEntry *NewVirtualDictEntry(guint16 group, guint16 element,
+ std::string vr = "Unknown",
+ std::string fourth = "Unknown",
+ std::string name = "Unknown");
+
+ static std::string BuildDictPath(void);
+
+protected:
+ bool AppendDict(gdcmDict *NewDict,DictKey Name);
+
+private:
+ /// Hash table of all dictionaries contained in this gdcmDictSet
+ DictSetHT Dicts;
+ /// Directory path to dictionaries
+ std::string DictPath;
+
+ std::map<std::string,gdcmDictEntry *> virtualEntry;
};
+//-----------------------------------------------------------------------------
#endif