Program: gdcm
Module: $RCSfile: AnonymizeNoLoad.cxx,v $
Language: C++
- Date: $Date: 2005/07/20 14:48:15 $
- Version: $Revision: 1.7 $
+ Date: $Date: 2005/08/28 17:26:31 $
+ Version: $Revision: 1.10 $
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",
+ "\n AnonymizeNoLoad :\n ",
"Anonymize a gdcm-readable Dicom image even if pixels aren't gdcm readable ",
" Warning : Warning : the image is overwritten ",
" to preserve image integrity, use a copy. ",
"usage: AnonymizeNoLoad {filein=inputFileName|dirin=inputDirectoryName} ",
- " [rubout=listOfPrivateElementsToRubOut] ",
+ " [rubout=listOfElementsToRubOut] ",
" [ { [noshadowseq] | [noshadow][noseq] } ] [debug] ",
" inputFileName : Name of the (single) file user wants to anonymize ",
" inputDirectoryName : user wants to anonymize *all* the files ",
" within the (single Patient!) directory ",
- " listOfPrivateElementsToRubOut : group,elem (in hexa) of private ",
- " Elements to rub out ",
+ " listOfElementsToRubOut : group-elem,g2-e2,... (in hexa, no space) ",
+ " of extra Elements to rub out ",
" 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 ",
gdcm::ArgMgr *am = new gdcm::ArgMgr(argc, argv);
- if (am->ArgMgrDefined("usage"))
+ if (am->ArgMgrDefined("usage") || argc == 1)
{
am->ArgMgrUsage(usage); // Display 'usage'
delete am;
if ( (fileName == 0 && dirName == 0)
||
- (fileName != 0 && dirName != 0) )
+ (fileName != 0 && dirName != 0) )
{
std::cout <<std::endl
- << "Either 'filein' or 'dirin' must be present;" << std::endl
- << "Not both" << std::endl;
+ << "Either 'filein=' or 'dirin=' must be present;"
+ << std::endl << "Not both" << std::endl;
+ am->ArgMgrUsage(usage); // Display 'usage'
delete am;
return 0;
}
int rubOutNb;
uint16_t *elemsToRubOut = am->ArgMgrGetXInt16Enum("rubout", &rubOutNb);
+
+ /* if unused Param we give up */
+ if ( am->ArgMgrPrintUnusedLabels() )
+ {
+ am->ArgMgrUsage(usage);
+ delete am;
+ return 0;
+ }
- std::cout << " ---------------------------- rubOutNb " << rubOutNb
- << std::endl;
delete am; // ------ we don't need Arguments Manager any longer ------
-
+ gdcm::File *f;
if ( fileName != 0 ) // ====== Deal with a single file ======
{
//
// Parse the input file.
//
- gdcm::File *f;
f = new gdcm::File( );
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 )
+ if ( !f->Load() )
{
std::cout <<std::endl
<< "Sorry, " << fileName <<" not a gdcm-readable "
f->AnonymizeNoLoad();
- // No need to write the File : modif were done on disc !
- // File was overwritten ...
-
+ // No need to write the file : modif were done on disc !
+ // ( The Dicom file is overwritten )
std::cout <<"End AnonymizeNoLoad" << std::endl;
//
it != fileList.end();
++it )
{
-
- gdcm::File *f;
f = new gdcm::File( );
f->SetLoadMode(loadMode);
f->SetFileName( it->c_str() );
- bool res = f->Load();
- if ( !res )
+ if ( !f->Load() )
{
delete f;
continue;
// Telephone
f->AddAnonymizeElement(0x0010, 0x2154, "3615" );
+ // deal with user defined Elements set
+
for (int ri=0; ri<rubOutNb; ri++)
{
f->AddAnonymizeElement((uint32_t)elemsToRubOut[2*ri],
std::cout <<"Let's AnonymizeNoLoad " << it->c_str() << std::endl;
// The gdcm::File remains untouched in memory
+ // The Dicom file is overwritten on disc
f->AnonymizeNoLoad();