X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmBinEntry.cxx;h=ae4c5be868395906260f7a5a65a114f2a1d498bc;hb=16887ff26b068405a235a6a8a37f4e62516de393;hp=b24d5c387e2a1b4c390fa8f11f789ed12993fe24;hpb=61e1a3e0ce5480990a0d0b844cf0e86d1775306d;p=gdcm.git diff --git a/src/gdcmBinEntry.cxx b/src/gdcmBinEntry.cxx index b24d5c38..ae4c5be8 100644 --- a/src/gdcmBinEntry.cxx +++ b/src/gdcmBinEntry.cxx @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmBinEntry.cxx,v $ Language: C++ - Date: $Date: 2004/06/19 23:51:03 $ - Version: $Revision: 1.10 $ + Date: $Date: 2004/06/24 18:03:14 $ + Version: $Revision: 1.18 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -26,7 +26,8 @@ /** * \brief Constructor from a given gdcmBinEntry */ -gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e) { +gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e) +{ this->voidArea = NULL; } @@ -34,14 +35,15 @@ gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e) { * \brief Constructor from a given gdcmBinEntry * @param e Pointer to existing Doc entry */ -gdcmBinEntry::gdcmBinEntry(gdcmDocEntry* e) : gdcmValEntry(e->GetDictEntry()){ +gdcmBinEntry::gdcmBinEntry(gdcmDocEntry* e) : gdcmValEntry(e->GetDictEntry()) +{ this->UsableLength = e->GetLength(); - this->ReadLength = e->GetReadLength(); - this->ImplicitVR = e->IsImplicitVR(); - this->Offset = e->GetOffset(); - this->printLevel = e->GetPrintLevel(); - this->SQDepthLevel = e->GetDepthLevel(); - + this->ReadLength = e->GetReadLength(); + this->ImplicitVR = e->IsImplicitVR(); + this->Offset = e->GetOffset(); + this->printLevel = e->GetPrintLevel(); + this->SQDepthLevel = e->GetDepthLevel(); + this->voidArea = NULL; // let's be carefull ! } @@ -57,15 +59,44 @@ gdcmBinEntry::~gdcmBinEntry(){ //----------------------------------------------------------------------------- // Print /* - * \ingroup gdcmDocEntry * \brief canonical Printer */ -void gdcmBinEntry::Print(std::ostream &os) { - PrintCommonPart(os); - /// \todo Write a true specialisation of Print i.e. display something - /// for BinEntry extension. - dbg.Verbose(1, "gdcmBinEntry::Print: so WHAT ?"); +void gdcmBinEntry::Print(std::ostream &os) +{ + gdcmDocEntry::Print(os); + std::ostringstream s; + void *voidArea = GetVoidArea(); + if (voidArea != NULL) + { + s << " [gdcm::Binary data loaded with length is " + << GetLength() << "]"; + } + else + { + if ( GetLength() == 0 ) + s << " []"; + else + { + s << " [gdcm::Binary data NOT loaded]"; + } + + } + os << s.str(); +} + +/* + * \brief canonical Writer + */ +void gdcmBinEntry::Write(FILE *fp, FileType filetype) { + gdcmDocEntry::Write(fp, filetype); + void *voidArea = GetVoidArea(); + int lgr=GetLength(); + if (voidArea != NULL) + { // there is a 'non string' LUT, overlay, etc + fwrite ( voidArea,(size_t)lgr ,(size_t)1 ,fp); // Elem value + return; + } } //----------------------------------------------------------------------------- // Public