Program: gdcm
Module: $RCSfile: gdcmDict.h,v $
Language: C++
- Date: $Date: 2005/01/08 15:03:59 $
- Version: $Revision: 1.29 $
+ 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
=========================================================================*/
-#ifndef GDCMDICT_H
-#define GDCMDICT_H
+#ifndef _GDCMDICT_H_
+#define _GDCMDICT_H_
-#include "gdcmBase.h"
+#include "gdcmRefCounter.h"
#include "gdcmDictEntry.h"
#include <iostream>
+#include <fstream> // for ifstream
#include <list>
#include <map>
-namespace gdcm
+namespace GDCM_NAME_SPACE
{
//-----------------------------------------------------------------------------
typedef std::string DictKey;
-typedef std::map<TagKey, DictEntry> TagKeyHT;
-typedef std::list<std::string> EntryNamesList;
-typedef std::map<std::string,
- std::list<std::string> > EntryNamesByCatMap;
+typedef std::map<TagKey, DictEntry *> TagKeyHT;
+
//-----------------------------------------------------------------------------
-/*
- * \defgroup 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.
* combined with all software versions...
* \see DictSet
*/
-class GDCM_EXPORT Dict : public Base
+class GDCM_EXPORT Dict : public RefCounter
{
+ gdcmTypeMacro(Dict);
+
public:
- 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);
// Print
- void Print(std::ostream &os = std::cout);
+ void Print(std::ostream &os = std::cout, std::string const &indent = "");
// Entries
- bool AddNewEntry (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 element);
+ bool RemoveEntry (uint16_t group, uint16_t elem);
+ void ClearEntry();
// Tag
- DictEntry *GetDictEntry(uint16_t group, uint16_t element);
+ DictEntry *GetEntry(uint16_t group, uint16_t elem);
+ DictEntry *GetEntry(TagKey const &key);
- // EntryNamesList *GetDictEntryNames();
- // EntryNamesByCatMap *GetDictEntryNamesByCategory();
+ DictEntry *GetFirstEntry();
+ DictEntry *GetNextEntry();
- /// \brief Returns a ref to the Dicom Dictionary H table (map)
- /// @return the Dicom Dictionary H table
- const TagKeyHT & GetEntriesByKey() const { return KeyHt; }
+protected:
+ Dict();
+ Dict(std::string const &filename);
+ ~Dict();
- /// \brief Returns a ref to the Dicom Dictionary H table (map)
- /// @return the Dicom Dictionary H table
-
private:
+ void DoTheLoadingJob(std::ifstream &ifs);
+
/// ASCII file holding the Dictionnary
std::string Filename;
/// Access through TagKey
- TagKeyHT KeyHt;
-
+ TagKeyHT KeyHt;
+ /// Iterator for the entries
+ TagKeyHT::iterator ItKeyHt;
};
} // end namespace gdcm