Program: gdcm
Module: $RCSfile: gdcmElementSet.h,v $
Language: C++
- Date: $Date: 2005/02/21 17:47:19 $
- Version: $Revision: 1.44 $
+ Date: $Date: 2007/08/22 16:14:04 $
+ Version: $Revision: 1.57 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
=========================================================================*/
-#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;
//-----------------------------------------------------------------------------
*/
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 AddEntry(DocEntry *Entry);
bool RemoveEntry(DocEntry *EntryToRemove);
- bool RemoveEntryNoDestroy(DocEntry *EntryToRemove);
void ClearEntry();
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(); };
+ 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
//-----------------------------------------------------------------------------