X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirElement.cxx;h=b393d5dd00b93fe579af715a671b646f36e63b2b;hb=ed0cb816b9fbe45a5dfead3f7d95194e0cbbd3a4;hp=a645bc814c4cc285387c80bd574db384a1c03acd;hpb=28d134e7a6dcc11f3703bb8ec85334636f57f56e;p=gdcm.git diff --git a/src/gdcmDicomDirElement.cxx b/src/gdcmDicomDirElement.cxx index a645bc81..b393d5dd 100644 --- a/src/gdcmDicomDirElement.cxx +++ b/src/gdcmDicomDirElement.cxx @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDicomDirElement.cxx,v $ Language: C++ - Date: $Date: 2004/10/09 03:21:55 $ - Version: $Revision: 1.18 $ + Date: $Date: 2005/01/18 07:53:42 $ + Version: $Revision: 1.27 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -24,6 +24,9 @@ #include #include +namespace gdcm +{ +void FillDefaultDIRDict(DicomDirElement *dde); //----------------------------------------------------------------------------- // Constructor / Destructor @@ -31,66 +34,51 @@ * \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) + { + gdcmVerboseMacro( "Can't open dictionary" << filename.c_str()); + FillDefaultDIRDict( this ); + } + else { - from >> std::ws; - from.getline(buff, 1024, ' '); - type = buff; + char buff[1024]; + std::string type; + Element elem; - if( (type=="metaElem") || (type=="patientElem") || - (type=="studyElem") || (type=="serieElem") || - (type=="imageElem") ) + while (!from.eof()) { - from >> std::hex >> elem.Group >> elem.Elem; - - from >> std::ws; - from.getline(buff, 1024, '"'); from >> std::ws; - from.getline(buff, 1024, '"'); - elem.Value = buff; + from.getline(buff, 1024, ' '); + type = buff; - if( type == "metaElem" ) - { - DicomDirMetaList.push_back(elem); - } - else if( type == "patientElem" ) + if( type == "metaElem" || type == "patientElem" || + type == "studyElem" || type == "serieElem" || + type == "imageElem" ) { - DicomDirPatientList.push_back(elem); - } - else if( type == "studyElem" ) - { - DicomDirStudyList.push_back(elem); - } - else if( type == "serieElem" ) - { - DicomDirSerieList.push_back(elem); - } - else if( type == "imageElem" ) - { - DicomDirImageList.push_back(elem); + from >> std::hex >> elem.Group >> elem.Elem; + + from >> std::ws; + from.getline(buff, 1024, '"'); + from >> std::ws; + from.getline(buff, 1024, '"'); + elem.Value = buff; + + AddNewEntry(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(); @@ -102,50 +90,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; + std::list::iterator it; //char greltag[10]; //group element tag std::string greltag; s << "Meta Elements :"<Group,it->Elem); + greltag = Util::Format("%04x|%04x ",it->Group,it->Elem); s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Patient Elements :"<Group,it->Elem); + greltag = Util::Format("%04x|%04x ",it->Group,it->Elem); s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Study Elements :"<Group, it->Elem); + greltag = Util::Format("%04x|%04x ", it->Group, it->Elem); s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Serie Elements :"<Group, it->Elem); + greltag = Util::Format("%04x|%04x ", it->Group, it->Elem); s << " (" << greltag << ") = " << it->Value << std::endl; } s << "Image Elements :"<Group, it->Elem); + greltag = Util::Format("%04x|%04x ", it->Group, it->Elem); s << " (" << greltag << ") = " << it->Value << std::endl; } @@ -155,6 +142,40 @@ void gdcmDicomDirElement::Print(std::ostream &os) //----------------------------------------------------------------------------- // Public +/** + * \brief AddNewEntry + * @param type type + * @param elem elem + */ +bool DicomDirElement::AddNewEntry(std::string const &type, + Element const &elem) +{ + if( type == "metaElem" ) + { + DicomDirMetaList.push_back(elem); + } + else if( type == "patientElem" ) + { + DicomDirPatientList.push_back(elem); + } + else if( type == "studyElem" ) + { + DicomDirStudyList.push_back(elem); + } + else if( type == "serieElem" ) + { + DicomDirSerieList.push_back(elem); + } + else if( type == "imageElem" ) + { + DicomDirImageList.push_back(elem); + } + else + { + return false; + } + return true; +} //----------------------------------------------------------------------------- // Protected @@ -162,3 +183,5 @@ void gdcmDicomDirElement::Print(std::ostream &os) // Private //----------------------------------------------------------------------------- + +} // end namespace gdcm