-// gdcmDicomDirStudy.h
-//-----------------------------------------------------------------------------
+/*=========================================================================
+
+ Program: gdcm
+ Module: $RCSfile: gdcmDicomDirStudy.h,v $
+ Language: C++
+ Date: $Date: 2005/01/25 11:11:58 $
+ Version: $Revision: 1.22 $
+
+ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
+ l'Image). All rights reserved. See Doc/License.txt or
+ http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
+
+ This software is distributed WITHOUT ANY WARRANTY; without even
+ the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ PURPOSE. See the above copyright notices for more information.
+
+=========================================================================*/
+
#ifndef GDCMDICOMDIRSTUDY_H
#define GDCMDICOMDIRSTUDY_H
-#include "gdcmObject.h"
-#include "gdcmDicomDirSerie.h"
+#include "gdcmDicomDirObject.h"
+namespace gdcm
+{
+class DicomDirSerie;
//-----------------------------------------------------------------------------
-typedef std::list<gdcmDicomDirSerie *> ListDicomDirSerie;
+typedef std::list<DicomDirSerie *> ListDicomDirSerie;
//-----------------------------------------------------------------------------
-class GDCM_EXPORT gdcmDicomDirStudy : public gdcmObject {
+/**
+ * \brief describes a STUDY within a within a PATIENT
+ * (DicomDirPatient) of a given DICOMDIR (DicomDir)
+ */
+class GDCM_EXPORT DicomDirStudy : public DicomDirObject
+{
public:
- gdcmDicomDirStudy(gdcmSQItem *s, TagDocEntryHT *ptagHT);
- gdcmDicomDirStudy(TagDocEntryHT *ptagHT);
+ DicomDirStudy(bool empty=false);
+ ~DicomDirStudy();
- ~gdcmDicomDirStudy(void);
+ void Print(std::ostream &os = std::cout, std::string const & indent = "" );
+ void WriteContent(std::ofstream *fp, FileType t);
- virtual void Print(std::ostream &os = std::cout);
-/**
- * \ingroup gdcmDicomDirStudy
- * \brief returns the SERIE chained List for this STUDY.
- */
- inline ListDicomDirSerie &GetDicomDirSeries()
- {return series;};
-/**
- * \ingroup gdcmDicomDirStudy
- * \brief adds the passed SERIE to the SERIE chained List for this STUDY.
- */
- inline void AddDicomDirSerie(gdcmDicomDirSerie *obj)
- {series.push_back(obj);};
+ // should avoid exposing internal mechanism
+ DicomDirSerie *GetFirstSerie();
+ DicomDirSerie *GetNextSerie();
+ DicomDirSerie *GetLastSerie();
-/**
- * \ingroup gdcmDicomDirStudy
- * \brief TODO
- */
- gdcmDicomDirSerie* NewSerie(void);
+ /// adds the passed SERIE to the SERIE chained List for this STUDY.
+ void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); };
+ DicomDirSerie* NewSerie();
+
+ void ClearSerie();
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
//-----------------------------------------------------------------------------
#endif