Program: gdcm
Module: $RCSfile: AnonymizeNoLoad.cxx,v $
Language: C++
- Date: $Date: 2005/08/22 11:14:27 $
- Version: $Revision: 1.9 $
+ Date: $Date: 2007/06/06 13:03:57 $
+ Version: $Revision: 1.21 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
int main(int argc, char *argv[])
{
START_USAGE(usage)
- "\n AnonymizeNoLoad :\n",
- "Anonymize a gdcm-readable Dicom image even if pixels aren't gdcm readable ",
- " Warning : Warning : the image is overwritten ",
+ "\n AnonymizeNoLoad :\n ",
+ "Anonymize a gdcm-parsable Dicom image even if pixels aren't gdcm readable ",
+ " Warning : the image is OVERWRITTEN ",
" to preserve image integrity, use a copy. ",
"usage: AnonymizeNoLoad {filein=inputFileName|dirin=inputDirectoryName} ",
- " [rubout=listOfElementsToRubOut] ",
+ " [rubout=listOfElementsToRubOut] ",
" [ { [noshadowseq] | [noshadow][noseq] } ] [debug] ",
" inputFileName : Name of the (single) file user wants to anonymize ",
" inputDirectoryName : user wants to anonymize *all* the files ",
" noshadowseq: user doesn't want to load Private Sequences ",
" 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' ",
+ " 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 (am->ArgMgrDefined("usage") || argc == 1)
{
}
if (am->ArgMgrDefined("debug"))
- gdcm::Debug::DebugOn();
+ GDCM_NAME_SPACE::Debug::DebugOn();
- char *fileName = am->ArgMgrGetString("filein",(char *)0);
- char *dirName = am->ArgMgrGetString("dirin",(char *)0);
+ const char *fileName = am->ArgMgrGetString("filein");
+ const char *dirName = am->ArgMgrGetString("dirin");
if ( (fileName == 0 && dirName == 0)
||
return 0;
}
- int loadMode = 0x00000000;
+ int loadMode = GDCM_NAME_SPACE::LD_ALL;
if ( am->ArgMgrDefined("noshadowseq") )
- loadMode |= NO_SHADOWSEQ;
+ loadMode |= GDCM_NAME_SPACE::LD_NOSHADOWSEQ;
else
{
- if ( am->ArgMgrDefined("noshadow") )
- loadMode |= NO_SHADOW;
+ if ( am->ArgMgrDefined("noshadow") )
+ loadMode |= GDCM_NAME_SPACE::LD_NOSHADOW;
if ( am->ArgMgrDefined("noseq") )
- loadMode |= NO_SEQ;
+ loadMode |= GDCM_NAME_SPACE::LD_NOSEQ;
}
int rubOutNb;
delete am; // ------ we don't need Arguments Manager any longer ------
+ GDCM_NAME_SPACE::File *f;
if ( fileName != 0 ) // ====== Deal with a single file ======
{
//
// Parse the input file.
//
- gdcm::File *f;
- f = new gdcm::File( );
+ f = GDCM_NAME_SPACE::File::New( );
f->SetLoadMode(loadMode);
f->SetFileName( fileName );
- bool res = f->Load();
- // gdcm::File::IsReadable() is no usable here, because we deal with
- // any kind of gdcm::Readable *document*
- // not only gdcm::File (as opposed to gdcm::DicomDir)
- if ( !res )
+ // GDCM_NAME_SPACE::File::IsReadable() is no usable here, because we deal with
+ // any kind of GDCM_NAME_SPACE::Readable *document*
+ // not only GDCM_NAME_SPACE::File (as opposed to GDCM_NAME_SPACE::DicomDir)
+ if ( !f->Load() )
{
std::cout <<std::endl
<< "Sorry, " << fileName <<" not a gdcm-readable "
<< "DICOM / ACR Document"
<< std::endl;
- delete f;
+ f->Delete();
return 1;
}
std::cout << fileName << " is readable " << std::endl;
// File will be overwritten
//
-
//
// Choose the fields to anonymize.
//
// Institution name
- f->AddAnonymizeElement( 0x0008, 0x0080, "Xanadoo" );
+ f->AddAnonymizeElement( 0x0008, 0x0080, "gdcm-Xanadoo Hospital" );
// Patient's name
- f->AddAnonymizeElement( 0x0010, 0x0010, "g^Fantomas" );
+ f->AddAnonymizeElement( 0x0010, 0x0010, "gdcm^Fantomas" );
// Patient's ID
f->AddAnonymizeElement( 0x0010, 0x0020,"1515" );
// Patient's Birthdate
- f->AddAnonymizeElement( 0x0010, 0x0030,"11.11.1111" );
+ f->AddAnonymizeElement( 0x0010, 0x0030,"11111111" );
// Patient's Adress
- f->AddAnonymizeElement( 0x0010, 0x1040,"Sing-sing" );
+ f->AddAnonymizeElement( 0x0010, 0x1040,"gdcm at Sing-sing.org" );
// Patient's Mother's Birth Name
- f->AddAnonymizeElement( 0x0010, 0x1060,"g^Vampirella" );
+ f->AddAnonymizeElement( 0x0010, 0x1060,"gdcm^Vampirella" );
// Study Instance UID
f->AddAnonymizeElement( 0x0020, 0x000d, "9.99.999.9999" );
// Telephone
std::cout <<"Let's AnonymizeNoLoad " << std::endl;
- // The gdcm::File remains untouched in memory
+ // The GDCM_NAME_SPACE::File remains untouched in memory
f->AnonymizeNoLoad();
//
f->ClearAnonymizeList();
- delete f;
+ f->Delete();
return 0;
}
else // ====== Deal with a (single Patient) Directory ======
{
std::cout << "dirName [" << dirName << "]" << std::endl;
- gdcm::DirList dirList(dirName,1); // gets recursively the file list
- gdcm::DirListType fileList = dirList.GetFilenames();
- for( gdcm::DirListType::iterator it = fileList.begin();
+ GDCM_NAME_SPACE::DirList dirList(dirName,1); // gets recursively the file list
+ GDCM_NAME_SPACE::DirListType fileList = dirList.GetFilenames();
+ for( GDCM_NAME_SPACE::DirListType::iterator it = fileList.begin();
it != fileList.end();
++it )
{
-
- gdcm::File *f;
- f = new gdcm::File( );
+ f = GDCM_NAME_SPACE::File::New( );
f->SetLoadMode(loadMode);
f->SetFileName( it->c_str() );
- bool res = f->Load();
- if ( !res )
+ if ( !f->Load() )
{
- delete f;
+ f->Delete();
continue;
}
//
//
// Institution name
- f->AddAnonymizeElement( 0x0008, 0x0080, "Xanadoo" );
+ f->AddAnonymizeElement( 0x0008, 0x0080, "gdcm-Xanadoo Hospital" );
// Patient's name
- f->AddAnonymizeElement( 0x0010, 0x0010, "g^Fantomas" );
+ f->AddAnonymizeElement( 0x0010, 0x0010, "gdcm^Fantomas" );
// Patient's ID
f->AddAnonymizeElement( 0x0010, 0x0020,"1515" );
// Patient's Birthdate
- f->AddAnonymizeElement( 0x0010, 0x0030,"11.11.1111" );
+ f->AddAnonymizeElement( 0x0010, 0x0030,"11111111" );
// Patient's Adress
- f->AddAnonymizeElement( 0x0010, 0x1040,"Sing-sing" );
+ f->AddAnonymizeElement( 0x0010, 0x1040,"gdcm at Sing-sing.org" );
// Patient's Mother's Birth Name
- f->AddAnonymizeElement( 0x0010, 0x1060,"g^Vampirella" );
+ f->AddAnonymizeElement( 0x0010, 0x1060,"gdcm^Vampirella" );
// Study Instance UID
// we may not brutaly overwrite it
//f->AddAnonymizeElement( 0x0020, 0x000d, "9.99.999.9999" );
}
std::cout <<"Let's AnonymizeNoLoad " << it->c_str() << std::endl;
- // The gdcm::File remains untouched in memory
+ // The GDCM_NAME_SPACE::File remains untouched in memory
// The Dicom file is overwritten on disc
f->AnonymizeNoLoad();
f->ClearAnonymizeList();
- delete f;
- }
-
- }
+ f->Delete();
+ }
+ }
return 0;
}