]> Creatis software - gdcm.git/blobdiff - Example/PrintHeader.cxx
According to Benoit's suggestion, and without any objection from anybody
[gdcm.git] / Example / PrintHeader.cxx
index 4b12529f23f36cccd6b72f23bcf53ffb85b99730..74305de60f4419165ed248f68bc09498e0043fd6 100644 (file)
@@ -1,5 +1,22 @@
+/*=========================================================================
+                                                                                
+  Program:   gdcm
+  Module:    $RCSfile: PrintHeader.cxx,v $
+  Language:  C++
+  Date:      $Date: 2005/01/08 15:03:57 $
+  Version:   $Revision: 1.13 $
+                                                                                
+  Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
+  l'Image). All rights reserved. See Doc/License.txt or
+  http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
+                                                                                
+     This software is distributed WITHOUT ANY WARRANTY; without even
+     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+     PURPOSE.  See the above copyright notices for more information.
+                                                                                
+=========================================================================*/
+#include "gdcmHeader.h"
 #include <iostream>
-#include "gdcm.h"
 
 int main(int argc, char* argv[])
 { 
@@ -19,34 +36,30 @@ int main(int argc, char* argv[])
       fileName += GDCM_DATA_ROOT;
       fileName += "/test.acr";
    }
-   
-   gdcmFile *e2 = new gdcmFile( fileName.c_str() );
-   gdcmHeader *e1 = e2->GetHeader();  
-        
-   if (argc > 2) {
+
+   gdcm::Header *e1 = new gdcm::Header( fileName.c_str() );  
+
+   if (argc > 2) 
+   {
       int level = atoi(argv[2]);   
       e1->SetPrintLevel(level);
    }
 
-  e1->Print();   
-      
-  std::cout << "\n\n" << std::endl;      
-  std::string transferSyntaxName = e1->GetTransfertSyntaxName();
-  std::cout << " TransferSyntaxName= [" << transferSyntaxName << "]" << std::endl;
-   
-   if (  transferSyntaxName != "Implicit VR - Little Endian"
-      && transferSyntaxName != "Explicit VR - Little Endian"     
-      && transferSyntaxName != "Deflated Explicit VR - Little Endian"      
-      && transferSyntaxName != "Explicit VR - Big Endian"
-      && transferSyntaxName != "Uncompressed ACR-NEMA"     )
-  {
-  std::cout << std::endl << "==========================================="
-                  << std::endl; 
-        e2->ParsePixelData();
-  std::cout << std::endl << "==========================================="
-                  << std::endl; 
-  }
-   
+   e1->Print();   
+
+   std::cout << "\n\n" << std::endl; 
+
+   if ( e1->GetEntry(0x0002,0x0010) == gdcm::GDCM_NOTLOADED ) 
+   {
+      std::cout << "Transfert Syntax not loaded. " << std::endl
+                << "Better you increase MAX_SIZE_LOAD_ELEMENT_VALUE"
+                << std::endl;
+      return 0;
+   }
+
+   std::string transferSyntaxName = e1->GetTransfertSyntaxName();
+   std::cout << " TransferSyntaxName= [" << transferSyntaxName << "]" << std::endl;
+
    if(e1->IsReadable())
       std::cout <<std::endl<<fileName<<" is Readable"<<std::endl;
    else
@@ -55,5 +68,4 @@ int main(int argc, char* argv[])
    delete e1;
 
    return 0;
-   
 }