00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef GDCMELEMENTSET_H
00020 #define GDCMELEMENTSET_H
00021
00022 #include "gdcmDocEntrySet.h"
00023
00024 #include <map>
00025 #include <iostream>
00026 #include <fstream>
00027
00028 namespace gdcm
00029 {
00030 class ValEntry;
00031 class BinEntry;
00032 class SeqEntry;
00033
00034 typedef std::map<TagKey, DocEntry *> TagDocEntryHT;
00035
00036
00044 class GDCM_EXPORT ElementSet : public DocEntrySet
00045 {
00046 public:
00047 ElementSet(int);
00048 ~ElementSet();
00049
00050 virtual void Print(std::ostream &os = std::cout, std::string const &indent = "" );
00051
00052 void WriteContent(std::ofstream *fp, FileType filetype);
00053
00054 bool AddEntry(DocEntry *Entry);
00055 bool RemoveEntry(DocEntry *EntryToRemove);
00056 bool RemoveEntryNoDestroy(DocEntry *EntryToRemove);
00057 void ClearEntry();
00058
00059 DocEntry *GetFirstEntry();
00060 DocEntry *GetNextEntry();
00061 DocEntry *GetDocEntry(uint16_t group, uint16_t elem);
00063 bool IsEmpty() { return TagHT.empty(); };
00064
00065 protected:
00066
00067 private:
00068
00070 TagDocEntryHT TagHT;
00072 TagDocEntryHT::iterator ItTagHT;
00074 TagDocEntryHT::iterator ItValEntryTagHT;
00075 };
00076 }
00077
00078 #endif
00079