X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=src%2FgdcmDicomDir.h;h=e54995e3445a1d927dfbfd382e7d40bd13853e2e;hb=9232388f3d3f9defdc6a8ac291a79b9a97b79dcf;hp=ed91ea9658282cab962a1eb682c6784b635a797e;hpb=8d4184fc7129f85d9ec384a3c7b9c5928a1f5b5e;p=gdcm.git diff --git a/src/gdcmDicomDir.h b/src/gdcmDicomDir.h index ed91ea96..e54995e3 100644 --- a/src/gdcmDicomDir.h +++ b/src/gdcmDicomDir.h @@ -1,4 +1,4 @@ -// gdcmDICOMDIR.h +// gdcmDicomDir.h //----------------------------------------------------------------------------- #ifndef GDCMDICOMDIR_H #define GDCMDICOMDIR_H @@ -6,9 +6,15 @@ #include "gdcmHeader.h" #include "gdcmCommon.h" #include "gdcmPatient.h" +#include "gdcmMeta.h" +#include "gdcmDicomDirElement.h" + +#include +#include //----------------------------------------------------------------------------- -typedef std::list ListPatient; +typedef std::list ListPatient; +typedef std::vector ListHeader; //----------------------------------------------------------------------------- /* @@ -16,36 +22,57 @@ typedef std::list ListPatient; * \brief gdcmDicomDir defines an object representing a DICOMDIR in memory. * */ -class GDCM_EXPORT gdcmDicomDir: public gdcmParser +class GDCM_EXPORT gdcmDicomDir: public gdcmParser { public: - gdcmDicomDir(bool exception_on_error = false); - gdcmDicomDir(std::string &FileName,bool exception_on_error = false ); +// gdcmDicomDir(ListTag *l, bool exception_on_error = false); + gdcmDicomDir(const char *FileName, + bool parseDir = false, + bool exception_on_error = false); ~gdcmDicomDir(void); void SetPrintLevel(int level) { printLevel = level; }; virtual void Print(std::ostream &os = std::cout); + inline gdcmMeta *GetMeta() {return metaElems;}; inline ListPatient &GetPatients() {return patients;}; +// Write + bool Write(std::string fileName); + void ParseDirectory(void); + +// Types typedef enum { GDCM_NONE, + GDCM_META, GDCM_PATIENT, GDCM_STUDY, GDCM_SERIE, GDCM_IMAGE, } gdcmDicomDirType; +protected: + void NewDicomDir(std::string path); + std::string GetPath(void); + private: void CreateDicomDir(void); - void AddObjectToEnd(gdcmDicomDirType type,ListTag::iterator begin,ListTag::iterator end); + void AddObjectToEnd(gdcmDicomDirType type, + ListTag::iterator begin,ListTag::iterator end); + void AddMetaToEnd (ListTag::iterator begin,ListTag::iterator end); void AddPatientToEnd(ListTag::iterator begin,ListTag::iterator end); - void AddStudyToEnd(ListTag::iterator begin,ListTag::iterator end); - void AddSerieToEnd(ListTag::iterator begin,ListTag::iterator end); - void AddImageToEnd(ListTag::iterator begin,ListTag::iterator end); + void AddStudyToEnd (ListTag::iterator begin,ListTag::iterator end); + void AddSerieToEnd (ListTag::iterator begin,ListTag::iterator end); + void AddImageToEnd (ListTag::iterator begin,ListTag::iterator end); + + void SetElements(std::string &path,ListHeader &list); + void SetElement (std::string &path,gdcmDicomDirType type,gdcmHeader *header); + + static bool HeaderLessThan(gdcmHeader *header1,gdcmHeader *header2); + gdcmMeta *metaElems; ListPatient patients; };