X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=Example%2FAnonymizeDicomDir.cxx;h=33cca00a7b0a64f3e36a8a00f187c03fb6116f2d;hb=175f7eaa4d1f56100622951645c6d677b351a5ba;hp=747714b538ff476dd775f5c4c4d9f03e06177204;hpb=6b51b22366f878e1050c75a6ebb755bd2ff365c7;p=gdcm.git diff --git a/Example/AnonymizeDicomDir.cxx b/Example/AnonymizeDicomDir.cxx index 747714b5..33cca00a 100644 --- a/Example/AnonymizeDicomDir.cxx +++ b/Example/AnonymizeDicomDir.cxx @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: AnonymizeDicomDir.cxx,v $ Language: C++ - Date: $Date: 2005/10/25 14:52:26 $ - Version: $Revision: 1.9 $ + Date: $Date: 2007/11/08 10:40:39 $ + Version: $Revision: 1.12 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -35,15 +35,15 @@ * \brief AnonymizeDicomDir */ -void AnoNoLoad(gdcm::SQItem *s, std::fstream *fp, +void AnoNoLoad(GDCM_NAME_SPACE::SQItem *s, std::fstream *fp, uint16_t group, uint16_t elem, std::string val); -void AnoNoLoad(gdcm::SQItem *s, std::fstream *fp, +void AnoNoLoad(GDCM_NAME_SPACE::SQItem *s, std::fstream *fp, uint16_t group, uint16_t elem, std::string val) { - gdcm::DocEntry *d; + GDCM_NAME_SPACE::DocEntry *d; uint32_t offset; uint32_t lgth; uint32_t valLgth = 0; @@ -55,7 +55,7 @@ void AnoNoLoad(gdcm::SQItem *s, std::fstream *fp, if ( d == NULL) return; - if ( ! dynamic_cast(d) ) + if ( ! dynamic_cast(d) ) return; offset = d->GetOffset(); @@ -75,16 +75,16 @@ int main(int argc, char *argv[]) { START_USAGE(usage) - " \n AnonymizeDicomDir :\n", - " Anonymize a gdcm-readable DICOMDIR ", - " even when some 'Objects' are not yet taken into account", - " Warning : the DICOMDIR is overwritten", - " usage: AnonymizeDicomDir filein=dicomDirName [debug] ", - " debug : user wants to run the program in 'debug mode' ", + " \n AnonymizeDicomDir :\n ", + " Anonymize a gdcm-readable DICOMDIR ", + " even when some 'Objects' are not yet taken into account ", + " Warning : the DICOMDIR is overwritten ", + " usage: AnonymizeDicomDir filein=dicomDirName [debug] ", + " debug : developper wants to run the program in 'debug mode' ", FINISH_USAGE // ----- Initialize Arguments Manager ------ - gdcm::ArgMgr *am = new gdcm::ArgMgr(argc, argv); + GDCM_NAME_SPACE::ArgMgr *am = new GDCM_NAME_SPACE::ArgMgr(argc, argv); if (argc == 1 || am->ArgMgrDefined("usage")) { @@ -106,8 +106,8 @@ int main(int argc, char *argv[]) // Read the input DICOMDIR - gdcm::File *f; - f = gdcm::File::New( ); + GDCM_NAME_SPACE::File *f; + f = GDCM_NAME_SPACE::File::New( ); f->SetLoadMode(0); f->SetFileName( fileName ); bool res = f->Load(); @@ -119,7 +119,7 @@ int main(int argc, char *argv[]) std::cout << " ... is readable " << std::endl; // Look for Directory record sequence - gdcm::DocEntry *e = f->GetDocEntry(0x0004, 0x1220); + GDCM_NAME_SPACE::DocEntry *e = f->GetDocEntry(0x0004, 0x1220); if ( !e ) { std::cout << "No Directory Record Sequence (0004,1220) found" <(e); + GDCM_NAME_SPACE::SeqEntry *s = dynamic_cast(e); if ( !s ) { std::cout << "Element (0004,1220) is not a Sequence ?!?" <GetFirstSQItem(); // For all the SQItems + GDCM_NAME_SPACE::SQItem *tmpSI=s->GetFirstSQItem(); // For all the SQItems while(tmpSI) { d = tmpSI->GetDocEntry(0x0004, 0x1430); // Directory Record Type - if ( gdcm::DataEntry *dataEntry = dynamic_cast(d) ) + if ( GDCM_NAME_SPACE::DataEntry *dataEntry = + dynamic_cast(d) ) { v = dataEntry->GetString(); } @@ -164,7 +166,7 @@ int main(int argc, char *argv[]) continue; } - oss << patientNumber; + oss << "P^" << patientNumber; // Overwrite the sensitive Entries @@ -173,7 +175,7 @@ int main(int argc, char *argv[]) // Patient's ID AnoNoLoad(tmpSI, fp, 0x0010, 0x0020, oss.str()); // Patient's Birth Date - AnoNoLoad(tmpSI, fp, 0x0010, 0x0030, oss.str()); + AnoNoLoad(tmpSI, fp, 0x0010, 0x0030, "11111111"); // Telephone AnoNoLoad(tmpSI, fp, 0x0010, 0x2154, oss.str());