-// gdcmBinEntry.cxx
-//-----------------------------------------------------------------------------
-//
+/*=========================================================================
+
+ Program: gdcm
+ Module: $RCSfile: gdcmBinEntry.cxx,v $
+ Language: C++
+ 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
+ http://www.creatis.insa-lyon.fr/Public/Gdcm/License.htm for details.
+
+ This software is distributed WITHOUT ANY WARRANTY; without even
+ the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ PURPOSE. See the above copyright notices for more information.
+
+=========================================================================*/
+
#include "gdcmBinEntry.h"
+#include "gdcmDebug.h"
//-----------------------------------------------------------------------------
/**
* \brief Constructor from a given gdcmBinEntry
*/
-gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e) {
+gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e)
+{
+ this->voidArea = NULL;
+}
+/**
+ * \brief Constructor from a given gdcmBinEntry
+ * @param e Pointer to existing Doc entry
+ */
+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->voidArea = NULL; // let's be carefull !
}
/**
* \brief Canonical destructor.
*/
gdcmBinEntry::~gdcmBinEntry(){
- free (voidArea);
+ if (voidArea)
+ free (voidArea);
}
//-----------------------------------------------------------------------------
// Print
/*
- * \ingroup gdcmDocEntry
* \brief canonical Printer
*/
-void gdcmBinEntry::Print(std::ostream &os = std::cout) {
- PrintCommonPart(os);
- std::cout << "gdcmBinEntry : Print, et alors ?" <<std::endl;
+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