X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmSQItem.h;h=1b3cdad7e0814954acbde7b59d0d4c2192344a26;hb=692f863c018c259a380e664d3608a46ec0c8bb3e;hp=e08ae79cda38dfa1ce787e31e744183682f03d96;hpb=2012716d624d631dcdb825fdd4470908e115a717;p=gdcm.git diff --git a/src/gdcmSQItem.h b/src/gdcmSQItem.h index e08ae79c..1b3cdad7 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/06/20 18:08:48 $ - Version: $Revision: 1.9 $ + Date: $Date: 2004/09/16 19:21:57 $ + Version: $Revision: 1.15 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -23,6 +23,9 @@ #include "gdcmDocEntrySet.h" #include "gdcmDocument.h" + +class gdcmBinEntry; + //----------------------------------------------------------------------------- typedef std::list ListDocEntry; //----------------------------------------------------------------------------- @@ -30,37 +33,48 @@ class GDCM_EXPORT gdcmSQItem : public gdcmDocEntrySet { public: gdcmSQItem(int); - ~gdcmSQItem(void); + ~gdcmSQItem(); virtual void Print(std::ostream &os = std::cout); + virtual void Write(FILE *fp, FileType filetype); /// \brief returns the DocEntry chained List for this SQ Item. - inline ListDocEntry &GetDocEntries() {return docEntries;}; + ListDocEntry &GetDocEntries() { return docEntries; }; /// \brief adds the passed DocEntry to the DocEntry chained List for /// this SQ Item. - inline void AddDocEntry(gdcmDocEntry *e) {docEntries.push_back(e);}; + void AddDocEntry(gdcmDocEntry *e) { docEntries.push_back(e); }; virtual bool AddEntry(gdcmDocEntry *Entry); // add to the List - gdcmDocEntry *GetDocEntryByNumber(guint16 group, guint16 element); - gdcmDocEntry *GetDocEntryByName (std::string Name); + gdcmDocEntry *GetDocEntryByNumber(uint16_t group, uint16_t element); + // FIXME method to write + //gdcmDocEntry *GetDocEntryByName (std::string Name); - bool SetEntryByNumber(std::string val,guint16 group, guint16 element); + bool SetEntryByNumber(std::string val, uint16_t group, uint16_t element); - std::string GetEntryByNumber(guint16 group, guint16 element); - std::string GetEntryByName(TagName name); + virtual std::string GetEntryByNumber(uint16_t group, uint16_t element); - inline int GetSQItemNumber() { return SQItemNumber;}; + /// \brief returns the ordinal position of a given SQItem + int GetSQItemNumber() { return SQItemNumber; }; - inline void SetSQItemNumber(int itemNumber) { SQItemNumber=itemNumber;}; -protected: + /// \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; } + + /// Accessor on \ref BaseTagKey. + void SetBaseTagKey( gdcmBaseTagKey key ) { BaseTagKey = key; } -// DocEntry related utilities - - virtual gdcmDocEntry *NewDocEntryByNumber(guint16 group, - guint16 element); // TODO - virtual gdcmDocEntry *NewDocEntryByName (std::string Name); //TODO + /// Accessor on \ref BaseTagKey. + gdcmBaseTagKey GetBaseTagKey( ) { return BaseTagKey; } + + +protected: // Variables @@ -72,10 +86,21 @@ protected: ///\brief pointer to the HTable of the gdcmDocument, /// (because we don't know it within any gdcmObject nor any gdcmSQItem) - TagDocEntryHT *ptagHT; + 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 gdcmSeqEntry::SQDepthLevel + /// counterpart are only defined on printing purposes + /// (see \ref Print). + int SQDepthLevel; + + /// \brief A TagKey of a gdcmDocEntry nested in a sequence is prepended + /// with this BaseTagKey. + gdcmBaseTagKey BaseTagKey; };