]> Creatis software - gdcm.git/blobdiff - src/gdcmDicomDirStudy.h
BUG: Fix declaration of vars within a switch/case
[gdcm.git] / src / gdcmDicomDirStudy.h
index bac655086b9618544f25a8335dc8e2a0eecfb59e..ba277d51cb5586e34a98d4fe3cb662c70466465c 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: gdcmDicomDirStudy.h,v $
   Language:  C++
-  Date:      $Date: 2005/07/08 19:07:12 $
-  Version:   $Revision: 1.27 $
+  Date:      $Date: 2005/10/25 14:52:33 $
+  Version:   $Revision: 1.30 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
@@ -42,32 +42,33 @@ typedef std::list<DicomDirStudyComponent *> ListDicomDirStudyComponent;
  */
 class GDCM_EXPORT DicomDirStudy : public DicomDirObject
 {
+   gdcmTypeMacro(DicomDirStudy);
+
 public:
-   DicomDirStudy(bool empty=false); 
-   ~DicomDirStudy();
+   static DicomDirStudy *New(bool empty=false) {return new DicomDirStudy(empty);}
 
    void Print(std::ostream &os = std::cout, std::string const &indent = "" );
    void WriteContent(std::ofstream *fp, FileType t);
 
-   // Serie methods
+   // 'Serie' methods
    DicomDirSerie *NewSerie();
-   /// Adds a gdcm::DicomDirSerie to a Study
-   void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); };
+   /// Adds a gdcm::DicomDirSerie to a gdcm::DicomDirStudy
+   void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); }
    void ClearSerie();
-
    DicomDirSerie *GetFirstSerie();
    DicomDirSerie *GetNextSerie();
    DicomDirSerie *GetLastSerie();
 
-
-   // for future use (Full DICOMDIR)
-
+   // 'Visit' methods
    DicomDirVisit *NewVisit();
-   void AddVisit(DicomDirVisit *obj) { Visits.push_back(obj); };
+   /// Adds a gdcm::DicomDirVisit to a gdcm::DicomDirStudy
+   void AddVisit(DicomDirVisit *obj) { Visits.push_back(obj); }
    void ClearVisit();
    DicomDirVisit *GetFirstVisit();
    DicomDirVisit *GetNextVisit();
    DicomDirVisit *GetLastVisit();
+   
+   // for future use (Full DICOMDIR)
 /*
    DicomDirResult *GetFirstResult();
    DicomDirResult *GetNextResult();
@@ -77,20 +78,24 @@ public:
    DicomDirStudyComponent *GetNextStudyComponent();
    DicomDirStudyComponent *GetLastStudyComponent();
 */    
-private:
 
+protected:
+   DicomDirStudy(bool empty=false); 
+   ~DicomDirStudy();
+
+private:
    /// chained list of DicomDirSeries (to be exploited hierarchicaly)
    ListDicomDirSerie Series;
    /// iterator on the DicomDirSeries of the current DicomDirStudy
    ListDicomDirSerie::iterator ItSerie;
 
-
-   // for future use (Full DICOMDIR)
-
    /// chained list of DicomDirVisits(single level)
    ListDicomDirVisit Visits;
    /// iterator on the DicomDirVisits of the current DicomDirStudy
    ListDicomDirVisit::iterator ItVisit;
+   
+
+   // for future use (Full DICOMDIR)
 /*
    /// chained list of DicomDirResults(single level)
    ListDicomDirResult Results;