]> Creatis software - gdcm.git/blob - Testing/TestMakeDicomDir.cxx
Give up defaulting NO_SHADOW (because of some bugged 0x0000 element lengths)
[gdcm.git] / Testing / TestMakeDicomDir.cxx
1 /*=========================================================================
2                                                                                 
3   Program:   gdcm
4   Module:    $RCSfile: TestMakeDicomDir.cxx,v $
5   Language:  C++
6   Date:      $Date: 2005/06/02 09:37:50 $
7   Version:   $Revision: 1.3 $
8                                                                                 
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.
12                                                                                 
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.
16                                                                                 
17 =========================================================================*/
18 #include "gdcmDocEntry.h"
19 #include "gdcmDicomDir.h"
20 #include "gdcmDicomDirPatient.h"
21 #include "gdcmDirList.h"
22 #include "gdcmDebug.h"
23
24 // ---
25 void StartMethod(void *startMethod) 
26 {
27   (void)startMethod;
28    std::cout<<"Start parsing"<<std::endl;
29 }
30
31 void EndMethod(void *endMethod) 
32 {
33   (void)endMethod;
34    std::cout<<"End parsing"<<std::endl;
35 }
36 // ---
37
38 /**
39   * \brief   - Explores recursively the given directory 
40   *            (or GDCM_DATA_ROOT by default)
41   *          - Orders the gdcm-readable found Files
42   *             according their Patient/Study/Serie/Image characteristics
43   *          - Makes the gdcm::DicomDir. 
44   *          - Writes a file named "NewDICOMDIR".
45   *          - Reads "NewDICOMDIR" file.
46   */  
47
48 int TestMakeDicomDir(int argc, char *argv[])
49 {
50    //gdcm::Debug::DebugOn();
51    std::string dirName;   
52
53    if (argc > 1)
54    {
55       dirName = argv[1];
56    }
57    else
58    {
59       dirName = GDCM_DATA_ROOT;
60    }
61  
62    gdcm::DicomDir *dcmdir;
63  
64     // Old style (still available)
65     //
66     // true : we ask for Directory parsing
67     // dcmdir = new gdcm::DicomDir(dirName, true);
68
69    // new style (user is allowed no to load Sequences an/or Shadow Groups)
70    dcmdir = new gdcm::DicomDir( );
71    dcmdir->SetParseDir(true);
72    // dcmdir->SetLoadMode(NO_SEQ | NO_SHADOW);
73    // some images have a wrong length for element 0x0000 of private groups
74    dcmdir->SetLoadMode(NO_SEQ);
75    dcmdir->Load(dirName);
76
77    dcmdir->SetStartMethod(StartMethod, (void *) NULL);
78    dcmdir->SetEndMethod(EndMethod);
79    
80    if ( !dcmdir->GetFirstPatient() ) 
81    {
82       std::cout << "makeDicomDir: no patient found. Exiting."
83                 << std::endl;
84
85       delete dcmdir;
86       return 1;
87    }
88     
89    // Create the corresponding DicomDir
90    dcmdir->WriteDicomDir("NewDICOMDIR");
91    delete dcmdir;
92
93    // Read from disc the just written DicomDir
94    gdcm::DicomDir *newDicomDir = new gdcm::DicomDir("NewDICOMDIR");
95    if( !newDicomDir->IsReadable() )
96    {
97       std::cout<<"          Written DicomDir 'NewDICOMDIR'"
98                <<" is not readable"<<std::endl
99                <<"          ...Failed"<<std::endl;
100
101       delete newDicomDir;
102       return 1;
103    }
104
105    if( !newDicomDir->GetFirstPatient() )
106    {
107       std::cout<<"          Written DicomDir 'NewDICOMDIR'"
108                <<" has no patient"<<std::endl
109                <<"          ...Failed"<<std::endl;
110
111       delete newDicomDir;
112       return(1);
113    }
114
115    std::cout<<std::flush;
116    delete newDicomDir;
117    return 0;
118 }