]> Creatis software - gdcm.git/blobdiff - src/gdcmElementSet.h
Print
[gdcm.git] / src / gdcmElementSet.h
index fe681ee4311e99d571e120698488c1b381eccbaa..332ca84bddfc8058f16ead2cfc1df37195a6870e 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: gdcmElementSet.h,v $
   Language:  C++
-  Date:      $Date: 2005/09/02 07:10:03 $
-  Version:   $Revision: 1.45 $
+  Date:      $Date: 2007/08/29 15:30:49 $
+  Version:   $Revision: 1.58 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
@@ -16,8 +16,8 @@
                                                                                 
 =========================================================================*/
 
-#ifndef GDCMELEMENTSET_H
-#define GDCMELEMENTSET_H
+#ifndef _GDCMELEMENTSET_H_
+#define _GDCMELEMENTSET_H_
 
 #include "gdcmDocEntrySet.h"
 
 #include <iostream>
 #include <fstream>
 
-namespace gdcm 
+namespace GDCM_NAME_SPACE 
 {
-class ValEntry;
-class BinEntry;
-class SeqEntry;
-
 typedef std::map<TagKey, DocEntry *> TagDocEntryHT;
 
 //-----------------------------------------------------------------------------
@@ -43,18 +39,17 @@ typedef std::map<TagKey, DocEntry *> TagDocEntryHT;
  */
 class GDCM_EXPORT ElementSet : public DocEntrySet
 {
-public:
-   ElementSet(int);
-   ~ElementSet();
+   gdcmTypeMacro(ElementSet);
 
+public:
    virtual void Print(std::ostream &os = std::cout, 
                       std::string const &indent = "" ); 
 
-   void WriteContent(std::ofstream *fp, FileType filetype); 
+   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();
    
    DocEntry *GetFirstEntry();
@@ -62,17 +57,24 @@ public:
    DocEntry *GetDocEntry(uint16_t group, uint16_t elem);
    /// Tells us if the ElementSet contains no entry
    bool IsEmpty() { return TagHT.empty(); }
+   
+   int IsVRCoherent(uint16_t group);
 
-protected:
+   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;
    /// iterator, used to visit the TagHT variable
    TagDocEntryHT::iterator ItTagHT;
-   /// iterator, used to visit the TagHT variable, seeking only for ValEntries
-   TagDocEntryHT::iterator ItValEntryTagHT;
 };
 } // end namespace gdcm
 //-----------------------------------------------------------------------------