]> Creatis software - gdcm.git/blobdiff - Example/PrintFile.cxx
* Remove all old python demo using an older gdcm version
[gdcm.git] / Example / PrintFile.cxx
index 7fb53f008fb111d0c1794af753f7e66b0301c2b3..0bf9ff33a7253a1d58f7ccc3fc7042b5f13e1a98 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: PrintFile.cxx,v $
   Language:  C++
-  Date:      $Date: 2005/05/02 17:28:15 $
-  Version:   $Revision: 1.34 $
+  Date:      $Date: 2005/06/07 11:12:10 $
+  Version:   $Revision: 1.38 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
                                                                                 
 =========================================================================*/
 #include "gdcmFile.h"
-#include "gdcmDebug.h"
 #include "gdcmFileHelper.h"
+#include "gdcmDebug.h"
+
+#include "gdcmArgMgr.h"
 
 #include <iostream>
 
 int main(int argc, char *argv[])
 {
-   gdcm::File *e1;
-   gdcm::FileHelper   *f1;
-   std::string fileName;
+
+   START_USAGE(usage)
+   " \n PrintFile : \n",
+   " Display the header of a ACR-NEMA/PAPYRUS/DICOM File",
+   " usage: PrintFile filein=fileName [level=n] [noshadow] [noseq] [debug] ",
+   "        level = 0,1,2 : depending on the amount of details user wants to see",
+   "        noshadow : user doesn't want to load Private groups (odd number)",
+   "        noseq    : user doesn't want to load Sequences ",
+   "        debug    : user wants to run the program in 'debug mode' ",
+   FINISH_USAGE
+
+   // Initialize Arguments Manager   
+   gdcm::ArgMgr *am= new gdcm::ArgMgr(argc, argv);
   
-   if (argc == 1) 
+   if (argc == 1)
    {
-      std::cout << " usage : PrintFile fileName printLevel debug "
-          << "short (=NOSEQ + NOSHADOW)" 
-                << std::endl;
-    return 0;
+      am->ArgMgrUsage(usage); // Display 'usage'
+      delete am;
+      return 0;
    }
 
-   e1 = new gdcm::File();
+   char *fileName = am->ArgMgrWantString("filein",usage);
 
-   if (argc > 1) 
-   {
-      fileName=argv[1];
-   } 
+   int loadMode;
+   if ( am->ArgMgrDefined("noshadow") && am->ArgMgrDefined("noseq") )
+       loadMode = NO_SEQ | NO_SHADOW;  
+   else if ( am->ArgMgrDefined("noshadow") )
+      loadMode = NO_SHADOW;
+   else if ( am->ArgMgrDefined("noseq") )
+      loadMode = NO_SEQ;
+   else
+      loadMode = 0;
 
-   if (argc > 3)
+   int level = am->ArgMgrGetInt("level", 2);
+
+   if (am->ArgMgrDefined("debug"))
       gdcm::Debug::DebugOn();
 
-   if (argc > 4)
-      e1->SetLoadMode(NO_SEQ | NO_SHADOW);   
-   e1->Load( fileName.c_str() );
+   /* if unused Param we give up */
+   if ( am->ArgMgrPrintUnusedLabels() )
+   { 
+      am->ArgMgrUsage(usage);
+      delete am;
+      return 0;
+   } 
+   // gdcm::File::IsReadable() is no usable here, because we deal with
+   // any kind of gdcm-Parsable *document* 
+   // not only gdcm::File (as opposed to gdcm::DicomDir)
+
+   gdcm::File *e1 = new gdcm::File();
+   e1->SetLoadMode(loadMode);
 
-   if ( !e1->IsReadable() )
+   bool res = e1->Load( fileName );
+   if ( !res )
    {
       delete e1;
+      delete am;
       return 0;
    }
 
-   f1 = new gdcm::FileHelper(e1);
-
-   if (argc > 2)  // keep it here (f1 needs to be constructed !)
-   {
-      int level = atoi(argv[2]);   
-      f1->SetPrintLevel(level);
-   }
+   gdcm::FileHelper *f1 = new gdcm::FileHelper(e1);
+   f1->SetPrintLevel( level );
 
    f1->Print();   
 
    std::cout << "\n\n" << std::endl; 
 
    std::cout <<std::endl;
-   std::cout <<" dataSize " << f1->GetImageDataSize() << std::endl;
+   std::cout <<" dataSize    " << f1->GetImageDataSize()    << std::endl;
    std::cout <<" dataSizeRaw " << f1->GetImageDataRawSize() << std::endl;
 
    int nX,nY,nZ,sPP,planarConfig;
@@ -82,7 +108,7 @@ int main(int argc, char *argv[])
    sPP          = e1->GetSamplesPerPixel();
    planarConfig = e1->GetPlanarConfiguration();
    
-   std::cout << " pixelType= ["           << pixelType 
+   std::cout << " pixelType= ["            << pixelType 
              << "] SamplesPerPixel= ["     << sPP
              << "] PlanarConfiguration= [" << planarConfig 
              << "] "<< std::endl 
@@ -115,7 +141,7 @@ int main(int argc, char *argv[])
    std::cout<<std::flush;
    delete e1;
    delete f1;
-
+   delete am;
    return 0;
    
 }