X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirElement.cxx;h=9d0bd87822e784090c3694e50b0b8b810f5f98ae;hb=d0dd94b3bab6007ec04534a451f456ceebd6dca7;hp=22530e7d80dce3cc6480309a04efdba0ffdfa225;hpb=4b4569ba7d0829cf3782ff6b5bbe5ae1009466e6;p=gdcm.git diff --git a/src/gdcmDicomDirElement.cxx b/src/gdcmDicomDirElement.cxx index 22530e7d..9d0bd878 100644 --- a/src/gdcmDicomDirElement.cxx +++ b/src/gdcmDicomDirElement.cxx @@ -3,12 +3,12 @@ Program: gdcm Module: $RCSfile: gdcmDicomDirElement.cxx,v $ Language: C++ - Date: $Date: 2004/08/01 02:39:09 $ - Version: $Revision: 1.14 $ + Date: $Date: 2005/01/28 17:01:29 $ + Version: $Revision: 1.32 $ 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.htm for details. + 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 @@ -16,16 +16,17 @@ =========================================================================*/ -#include -#include // For sprintf -#include - #include "gdcmDicomDirElement.h" #include "gdcmUtil.h" #include "gdcmDebug.h" #include "gdcmDictSet.h" +#include +#include +namespace gdcm +{ +void FillDefaultDIRDict(DicomDirElement *dde); //----------------------------------------------------------------------------- // Constructor / Destructor @@ -33,65 +34,68 @@ * \brief constructor : populates the chained lists * from the file 'Dicts/DicomDir.dic' */ -gdcmDicomDirElement::gdcmDicomDirElement() +DicomDirElement::DicomDirElement() { - std::string filename = gdcmDictSet::BuildDictPath() + std::string(DICT_ELEM); + std::string filename = DictSet::BuildDictPath() + DICT_ELEM; std::ifstream from(filename.c_str()); - dbg.Error(!from, "gdcmDicomDirElement::gdcmDicomDirElement: can't open dictionary",filename.c_str()); - - char buff[1024]; - std::string type; - gdcmElement elem; - - while (!from.eof()) + if(!from) { - eatwhite(from); - from.getline(buff, 1024, ' '); - type = buff; + gdcmVerboseMacro( "Can't open DicomDirElement dictionary" + << filename.c_str()); + FillDefaultDIRDict( this ); + } + else + { + char buff[1024]; + std::string strType; + Element elem; + DicomDirType type; - if( (type=="metaElem") || (type=="patientElem") || - (type=="studyElem") || (type=="serieElem") || - (type=="imageElem") ) + while (!from.eof()) { - from >> std::hex >> elem.group >> elem.elem; - - eatwhite(from); - from.getline(buff, 1024, '"'); - eatwhite(from); - from.getline(buff, 1024, '"'); - elem.value = buff; - - if( type == "metaElem" ) + from >> std::ws; + from.getline(buff, 1024, ' '); + strType = buff; + + if( strType == "metaElem" ) + type = DD_META; + else if( strType == "patientElem" ) + type = DD_PATIENT; + else if( strType == "studyElem" ) + type = DD_STUDY; + else if( strType == "serieElem" ) + type = DD_SERIE; + else if( strType == "imageElem" ) + type = DD_IMAGE; + else { - DicomDirMetaList.push_back(elem); + gdcmVerboseMacro("Unknown type found in the file : " + <> std::hex >> elem.Group >> elem.Elem; + + from >> std::ws; + from.getline(buff, 1024, '"'); + from >> std::ws; + from.getline(buff, 1024, '"'); + elem.Value = buff; + + AddEntry(type, elem); } + from.getline(buff, 1024, '\n'); } - from.getline(buff, 1024, '\n'); + from.close(); } - from.close(); } /** - * \ingroup gdcmDicomDirElement * \brief canonical destructor */ -gdcmDicomDirElement::~gdcmDicomDirElement() +DicomDirElement::~DicomDirElement() { DicomDirMetaList.clear(); DicomDirPatientList.clear(); @@ -103,50 +107,49 @@ gdcmDicomDirElement::~gdcmDicomDirElement() //----------------------------------------------------------------------------- // Print /** - * \ingroup gdcmDicomDirElement * \brief Print all - * \todo add a 'Print Level' check * @param os The output stream to be written to. */ -void gdcmDicomDirElement::Print(std::ostream &os) +void DicomDirElement::Print(std::ostream &os) { std::ostringstream s; - std::list::iterator it; - char greltag[10]; //group element tag + std::list::iterator it; + //char greltag[10]; //group element tag + std::string greltag; s << "Meta Elements :"<group,it->elem); - s << " ("<value<Group,it->Elem); + s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Patient Elements :"<group,it->elem); - s << " ("<value<Group,it->Elem); + s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Study Elements :"<group,it->elem); - s << " ("<value<Group, it->Elem); + s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Serie Elements :"<group,it->elem); - s << " ("<value<Group, it->Elem); + s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Image Elements :"<group,it->elem); - s << " ("<value<Group, it->Elem); + s << " (" << greltag << ") = " << it->Value << std::endl; } os << s.str(); @@ -154,7 +157,35 @@ void gdcmDicomDirElement::Print(std::ostream &os) //----------------------------------------------------------------------------- // Public - +/** + * \brief Add an entry + * @param type type + * @param elem elem + */ +bool DicomDirElement::AddEntry(DicomDirType type, Element const &elem) +{ + switch( type ) + { + case DD_META : + DicomDirMetaList.push_back(elem); + break; + case DD_PATIENT : + DicomDirPatientList.push_back(elem); + break; + case DD_STUDY : + DicomDirStudyList.push_back(elem); + break; + case DD_SERIE : + DicomDirSerieList.push_back(elem); + break; + case DD_IMAGE : + DicomDirImageList.push_back(elem); + break; + default : + return false; + } + return true; +} //----------------------------------------------------------------------------- // Protected @@ -162,3 +193,5 @@ void gdcmDicomDirElement::Print(std::ostream &os) // Private //----------------------------------------------------------------------------- + +} // end namespace gdcm