Program: gdcm
Module: $RCSfile: gdcmBinEntry.cxx,v $
Language: C++
- Date: $Date: 2004/06/18 12:26:54 $
- Version: $Revision: 1.9 $
+ Date: $Date: 2004/08/16 16:30:32 $
+ Version: $Revision: 1.22 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
/**
* \brief Constructor from a given gdcmBinEntry
*/
-gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e) {
-
+gdcmBinEntry::gdcmBinEntry(gdcmDictEntry* e) : gdcmValEntry(e)
+{
+ 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 !
+gdcmBinEntry::gdcmBinEntry(gdcmDocEntry* e) : gdcmValEntry(e->GetDictEntry())
+{
+ UsableLength = e->GetLength();
+ ReadLength = e->GetReadLength();
+ ImplicitVR = e->IsImplicitVR();
+ Offset = e->GetOffset();
+ PrintLevel = e->GetPrintLevel();
+ SQDepthLevel = e->GetDepthLevel();
+
+ VoidArea = NULL; // let's be carefull !
}
/**
* \brief Canonical destructor.
*/
-gdcmBinEntry::~gdcmBinEntry(){
- free (voidArea);
+gdcmBinEntry::~gdcmBinEntry()
+{
+ if (VoidArea)
+ {
+ free (VoidArea);
+ VoidArea = NULL; // let's be carefull !
+ }
}
//-----------------------------------------------------------------------------
// 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)
+ {
+ 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)
+ {
+ // there is a 'non string' LUT, overlay, etc
+ fwrite ( voidArea,(size_t)lgr ,(size_t)1 ,fp); // Elem value
+ }
}
//-----------------------------------------------------------------------------
// Public