X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmSQItem.h;h=ef24fa2843dddaa1fbda237288f32dd078b7e986;hb=0416947420d9168401c99e7fbf0dca0a081c9175;hp=ea771ed2cedcb61b4ade2d463227c8ca79fe82b5;hpb=7f5f66f57c85e30920d807612d32a65800cb1df0;p=gdcm.git diff --git a/src/gdcmSQItem.h b/src/gdcmSQItem.h index ea771ed2..ef24fa28 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/06 11:37:38 $ - Version: $Revision: 1.26 $ + Date: $Date: 2005/02/07 08:48:18 $ + Version: $Revision: 1.41 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -30,69 +30,62 @@ 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(); - void Print(std::ostream &os = std::cout); + virtual void Print(std::ostream &os = std::cout, std::string const &indent = "" ); void WriteContent(std::ofstream *fp, FileType filetype); - /// \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. 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(); + + DocEntry *GetDocEntry(uint16_t group, uint16_t elem); + + bool IsEmpty() { return DocEntries.empty(); }; /// \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 SQDepthLevel. - int GetDepthLevel() { return SQDepthLevel; } - - /// Accessor on \ref SQDepthLevel. - void SetDepthLevel(int depth) { SQDepthLevel = depth; } + /// \brief Accessor on \ref SQDepthLevel. + int GetDepthLevel() { return SQDepthLevel; } - /// Accessor on \ref BaseTagKey. - void SetBaseTagKey( BaseTagKey const & key ) { BaseTagKeyNested = key; } + /// \brief Accessor on \ref SQDepthLevel. + void SetDepthLevel(int depth) { SQDepthLevel = depth; } - /// Accessor on \ref BaseTagKey. - BaseTagKey const & GetBaseTagKey() const { return BaseTagKeyNested; } + /// \brief Accessor on \ref BaseTagKey. + void SetBaseTagKey( BaseTagKey const &key ) { BaseTagKeyNested = key; } - void Initialize(); - DocEntry *GetNextEntry(); + /// \brief Accessor on \ref BaseTagKey. + BaseTagKey const &GetBaseTagKey() const { return BaseTagKeyNested; } protected: -// Variables that need to be access in subclasses - - /// \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; - + /// Iterator, used to visit the Val Entries (for Python users) + ListDocEntry::iterator ItValEntries; + 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