X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmElementSet.h;h=397f342c5290e650b61ac76b8f94f9f6e20d2d3d;hb=df832cf7f90b4ca5aca2f628c1756fb276779fac;hp=926bec2c619623727af84cdaffd471fbcd8c8994;hpb=3c25b6a04715c20b3680bca5447b4f10add258fd;p=gdcm.git diff --git a/src/gdcmElementSet.h b/src/gdcmElementSet.h index 926bec2c..397f342c 100644 --- a/src/gdcmElementSet.h +++ b/src/gdcmElementSet.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmElementSet.h,v $ Language: C++ - Date: $Date: 2004/11/19 18:49:39 $ - Version: $Revision: 1.22 $ + Date: $Date: 2007/09/17 12:16:02 $ + Version: $Revision: 1.59 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -16,52 +16,65 @@ =========================================================================*/ -#ifndef GDCMELEMENTSET_H -#define GDCMELEMENTSET_H +#ifndef _GDCMELEMENTSET_H_ +#define _GDCMELEMENTSET_H_ -#include "gdcmCommon.h" #include "gdcmDocEntrySet.h" + #include #include +#include -class ValEntry; -class BinEntry; -class SeqEntry; - -namespace gdcm +namespace GDCM_NAME_SPACE { typedef std::map TagDocEntryHT; //----------------------------------------------------------------------------- - +/** + * \brief + * ElementSet is based on the STL map<> container + * (see ElementSet::TagHT), as opposed to SQItem + * which is based on an STL list container (see ListDocEntry). + * It contains the 'zero-level- DocEntry (out of any Dicom Sequence) + */ class GDCM_EXPORT ElementSet : public DocEntrySet { + gdcmTypeMacro(ElementSet); + public: - ElementSet(int); - ~ElementSet(); + virtual void Print(std::ostream &os = std::cout, + std::string const &indent = "" ); + + void WriteContent(std::ofstream *fp, FileType filetype, + bool insideMetaElements, bool insideSequence); bool AddEntry(DocEntry *Entry); bool RemoveEntry(DocEntry *EntryToRemove); - bool RemoveEntryNoDestroy(DocEntry *EntryToRemove); + void ClearEntry(); - void Print(std::ostream &os = std::cout); - void Write(std::ofstream *fp, FileType filetype); + DocEntry *GetFirstEntry(); + DocEntry *GetNextEntry(); + DocEntry *GetDocEntry(uint16_t group, uint16_t elem); + /// Tells us if the ElementSet contains no entry + bool IsEmpty() { return TagHT.empty(); } - /// Accessor to \ref TagHT - // Do not expose this to user (public API) ! - // A test is using it thus put it in public (matt) - TagDocEntryHT const & GetTagHT() const { return TagHT; }; + int IsVRCoherent(uint16_t group); + + virtual void Copy(DocEntrySet *set); protected: - + ElementSet(); + ~ElementSet(); + /// \brief Some group are illegal withing some Dicom Documents + /// Only the Document knows it. + bool MayIWrite(uint16_t ) + { return true; } private: // Variables /// Hash Table (map), to provide fast access - TagDocEntryHT TagHT; - - friend class Document; - friend class DicomDir; //For accessing private TagHT - friend class DocEntryArchive; //For accessing private TagHT + TagDocEntryHT TagHT; + /// iterator, used to visit the TagHT variable + TagDocEntryHT::iterator ItTagHT; }; } // end namespace gdcm //-----------------------------------------------------------------------------