1 /*=========================================================================
4 Module: $RCSfile: gdcmDicomDirPatient.h,v $
6 Date: $Date: 2005/11/29 12:48:46 $
7 Version: $Revision: 1.30 $
9 Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
10 l'Image). All rights reserved. See Doc/License.txt or
11 http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
13 This software is distributed WITHOUT ANY WARRANTY; without even
14 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 PURPOSE. See the above copyright notices for more information.
17 =========================================================================*/
22 #include "gdcmDicomDirObject.h"
28 //-----------------------------------------------------------------------------
29 typedef std::list<DicomDirStudy*> ListDicomDirStudy;
31 //-----------------------------------------------------------------------------
33 * \brief describes a PATIENT within a DICOMDIR (DicomDir)
36 class GDCM_EXPORT DicomDirPatient : public DicomDirObject
38 gdcmTypeMacro(DicomDirPatient);
41 /// \brief Constructs a DicomDirPatient with a RefCounter
42 static DicomDirPatient *New(bool empty=false) {return new DicomDirPatient(empty);}
44 void Print(std::ostream &os = std::cout, std::string const &indent = "" );
45 void WriteContent(std::ofstream *fp, FileType t);
48 /// \brief Adds a new gdcmDicomDirStudy to the Patient
49 void AddStudy(DicomDirStudy *obj) { Studies.push_back(obj); }
50 DicomDirStudy *NewStudy();
53 DicomDirStudy *GetFirstStudy();
54 DicomDirStudy *GetNextStudy();
55 DicomDirStudy *GetLastStudy();
57 virtual void Copy(DocEntrySet *set);
60 DicomDirPatient(bool empty=false);
64 /// chained list of DicomDirStudy (to be exploited hierarchicaly)
65 ListDicomDirStudy Studies;
66 /// iterator on the DicomDirStudies of the current DicomDirPatient
67 ListDicomDirStudy::iterator ItStudy;
69 } // end namespace gdcm
71 //-----------------------------------------------------------------------------