X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmSQItem.h;h=e45c252990ef6fb60612cd1c2ebf981612ac8b56;hb=f55ad21e7872cc4a4b0a37da859650e538d14075;hp=e1ba7a5244b57103688b8b5ebf3b12ff1f3f81af;hpb=233c8b3ebb1aee6b1be6723d842eb2241b9ffb91;p=gdcm.git diff --git a/src/gdcmSQItem.h b/src/gdcmSQItem.h index e1ba7a52..e45c2529 100644 --- a/src/gdcmSQItem.h +++ b/src/gdcmSQItem.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmSQItem.h,v $ Language: C++ - Date: $Date: 2004/12/03 17:13:18 $ - Version: $Revision: 1.25 $ + Date: $Date: 2007/08/29 15:30:50 $ + Version: $Revision: 1.55 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -15,8 +15,8 @@ PURPOSE. See the above copyright notices for more information. =========================================================================*/ -#ifndef GDCMSQITEM_H -#define GDCMSQITEM_H +#ifndef _GDCMSQITEM_H_ +#define _GDCMSQITEM_H_ #include "gdcmDocEntrySet.h" #include "gdcmElementSet.h" @@ -24,77 +24,68 @@ #include #include -namespace gdcm +namespace GDCM_NAME_SPACE { class DocEntry; //----------------------------------------------------------------------------- typedef std::list ListDocEntry; + //----------------------------------------------------------------------------- +/** + * \brief a SeqEntry is composed by a set of SQItems. + * Each SQItem is composed by a set of DocEntry + * A DocEntry may be a SeqEntry + * ... and so forth + */ class GDCM_EXPORT SQItem : public DocEntrySet { -public: - SQItem(int depthLevel); - ~SQItem(); + gdcmTypeMacro(SQItem); - void Print(std::ostream &os = std::cout); - void WriteContent(std::ofstream *fp, FileType filetype); +public: + static SQItem *New(int depthLevel) {return new SQItem(depthLevel);} - /// \brief returns the DocEntry chained List for this SQ Item. - ListDocEntry const & GetDocEntries() const { return DocEntries; }; - - /// \brief adds the passed DocEntry to the DocEntry chained List for - /// this SQ Item. - void AddDocEntry(DocEntry *e) { DocEntries.push_back(e); }; + virtual void Print(std::ostream &os = std::cout, + std::string const &indent = "" ); + void WriteContent(std::ofstream *fp, FileType filetype, + bool insideMetaElements, bool insideSequence); + uint32_t ComputeFullLength(); bool AddEntry(DocEntry *Entry); // add to the List bool RemoveEntry(DocEntry *EntryToRemove); - bool RemoveEntryNoDestroy(DocEntry *EntryToRemove); + void ClearEntry(); - DocEntry *GetDocEntryByNumber(uint16_t group, uint16_t element); - // FIXME method to write - //DocEntry *GetDocEntryByName (std::string Name); - - bool SetEntryByNumber(std::string const & val, uint16_t group, - uint16_t element); - - std::string GetEntryByNumber(uint16_t group, uint16_t element); + DocEntry *GetFirstEntry(); + DocEntry *GetNextEntry(); - /// \brief returns the ordinal position of a given SQItem - int GetSQItemNumber() { return SQItemNumber; }; + DocEntry *GetDocEntry(uint16_t group, uint16_t elem); - /// \brief Sets the ordinal position of a given SQItem - void SetSQItemNumber(int itemNumber) { SQItemNumber = itemNumber; }; + bool IsEmpty() { return DocEntries.empty(); } - /// Accessor on \ref SQDepthLevel. - int GetDepthLevel() { return SQDepthLevel; } - - /// Accessor on \ref SQDepthLevel. - void SetDepthLevel(int depth) { SQDepthLevel = depth; } + /// \brief returns the ordinal position of a given SQItem + int GetSQItemNumber() { return SQItemNumber; } + /// \brief Sets the ordinal position of a given SQItem + void SetSQItemNumber(int itemNumber) { SQItemNumber = itemNumber; } - /// Accessor on \ref BaseTagKey. - void SetBaseTagKey( BaseTagKey const & key ) { BaseTagKeyNested = key; } + /// \brief Accessor on \ref SQDepthLevel. + int GetDepthLevel() { return SQDepthLevel; } - /// Accessor on \ref BaseTagKey. - BaseTagKey const & GetBaseTagKey() const { return BaseTagKeyNested; } + /// \brief Accessor on \ref SQDepthLevel. + void SetDepthLevel(int depth) { SQDepthLevel = depth; } - void Initialize(); - DocEntry *GetNextEntry(); + virtual void Copy(DocEntrySet *set); protected: -// Variables that need to be access in subclasses + SQItem(int depthLevel); + ~SQItem(); - /// \brief Chained list of (Elementary) Doc Entries +// Variables that need to be accessed in subclasses + /// \brief Chained list of Doc Entries ListDocEntry DocEntries; - /// Chained list iterator, used to visit the TagHT variable + /// Iterator, used to visit the entries ListDocEntry::iterator ItDocEntries; - - ///\brief pointer to the HTable of the Document, - /// (because we don't know it within any DicomDirObject nor any SQItem) - TagDocEntryHT *PtagHT; - + private: - /// \brief Sequences can be nested. This \ref SQDepthLevel represents /// the level of the nesting of instances of this class. /// \ref SQDepthLevel and its \ref SeqEntry::SQDepthLevel @@ -102,14 +93,8 @@ private: /// (see \ref Print). int SQDepthLevel; - /// \brief A TagKey of a DocEntry nested in a sequence is prepended - /// with this BaseTagKey. - BaseTagKey BaseTagKeyNested; - - /// \brief SQ Item ordinal number int SQItemNumber; - }; } // end namespace gdcm //-----------------------------------------------------------------------------