Program: gdcm
Module: $RCSfile: gdcmDicomDirStudy.h,v $
Language: C++
- Date: $Date: 2004/10/22 03:05:41 $
- Version: $Revision: 1.11 $
+ Date: $Date: 2005/02/02 14:52:26 $
+ Version: $Revision: 1.23 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
#define GDCMDICOMDIRSTUDY_H
#include "gdcmDicomDirObject.h"
-#include "gdcmDicomDirSerie.h"
+
namespace gdcm
{
-
+class DicomDirSerie;
//-----------------------------------------------------------------------------
typedef std::list<DicomDirSerie *> ListDicomDirSerie;
//-----------------------------------------------------------------------------
+/**
+ * \brief describes a STUDY within a within a PATIENT
+ * (DicomDirPatient) of a given DICOMDIR (DicomDir)
+ */
class GDCM_EXPORT DicomDirStudy : public DicomDirObject
{
public:
- DicomDirStudy(SQItem *s, TagDocEntryHT *ptagHT);
- DicomDirStudy(TagDocEntryHT *ptagHT);
-
+ DicomDirStudy(bool empty=false);
~DicomDirStudy();
- virtual void Print(std::ostream &os = std::cout);
- virtual void Write(std::ofstream *fp, FileType t);
-/**
- * \ingroup DicomDirStudy
- * \brief returns the SERIE chained List for this STUDY.
- */
- ListDicomDirSerie &GetDicomDirSeries() { return series; };
-/**
- * \ingroup DicomDirStudy
- * \brief adds the passed SERIE to the SERIE chained List for this STUDY.
- */
- void AddDicomDirSerie(DicomDirSerie *obj) { series.push_back(obj); };
+ void Print(std::ostream &os = std::cout, std::string const & indent = "" );
+ void WriteContent(std::ofstream *fp, FileType t);
-/**
- * \ingroup DicomDirStudy
- * \brief TODO
- */
+ // Serie methods
DicomDirSerie* NewSerie();
+ void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); };
+ void ClearSerie();
+
+ DicomDirSerie *GetFirstSerie();
+ DicomDirSerie *GetNextSerie();
+ DicomDirSerie *GetLastSerie();
private:
-/**
-* \brief chained list of DicomDirSeries (to be exploited recursively)
-*/
- ListDicomDirSerie series;
+
+ /// chained list of DicomDirSeries (to be exploited recursively)
+ ListDicomDirSerie Series;
+ /// iterator on the DicomDirSeries of the current DicomDirStudy
+ ListDicomDirSerie::iterator ItSerie;
+
};
} // end namespace gdcm