/usr/include/gdcm-2.6/gdcmBasicOffsetTable.h is in libgdcm2-dev 2.6.6-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | /*=========================================================================
Program: GDCM (Grassroots DICOM). A DICOM library
Copyright (c) 2006-2011 Mathieu Malaterre
All rights reserved.
See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html 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 notice for more information.
=========================================================================*/
#ifndef GDCMBASICOFFSETTABLE_H
#define GDCMBASICOFFSETTABLE_H
#include "gdcmFragment.h"
namespace gdcm_ns
{
/**
* \brief Class to represent a BasicOffsetTable
*/
class GDCM_EXPORT BasicOffsetTable : public Fragment
{
//protected:
// void SetTag(const Tag &t);
public:
BasicOffsetTable() : Fragment() {}
friend std::ostream &operator<<(std::ostream &os, const BasicOffsetTable &val);
/*
VL GetLength() const {
assert( !ValueLengthField.IsUndefined() );
assert( !ValueField || ValueField->GetLength() == ValueLengthField );
return TagField.GetLength() + ValueLengthField.GetLength()
+ ValueLengthField;
}
*/
template <typename TSwap>
std::istream &Read(std::istream &is) {
// Superclass
const Tag itemStart(0xfffe, 0xe000);
const Tag seqDelItem(0xfffe,0xe0dd);
if( !TagField.Read<TSwap>(is) )
{
assert(0 && "Should not happen");
return is;
}
//assert( TagField == itemStart );
if( TagField != itemStart )
{
// Bug_Siemens_PrivateIconNoItem.dcm
gdcmDebugMacro( "Could be Bug_Siemens_PrivateIconNoItem.dcm" );
throw "SIEMENS Icon thingy";
}
if( !ValueLengthField.Read<TSwap>(is) )
{
assert(0 && "Should not happen");
return is;
}
// Self
SmartPointer<ByteValue> bv = new ByteValue;
bv->SetLength(ValueLengthField);
if( !bv->Read<TSwap>(is) )
{
assert(0 && "Should not happen");
return is;
}
ValueField = bv;
return is;
}
/*
template <typename TSwap>
std::ostream &Write(std::ostream &os) const {
const Tag itemStart(0xfffe, 0xe000);
const Tag seqDelItem(0xfffe,0xe0dd);
if( !TagField.Write<TSwap>(os) )
{
assert(0 && "Should not happen");
return os;
}
assert( TagField == itemStart );
if( !ValueLengthField.Write<TSwap>(os) )
{
assert(0 && "Should not happen");
return os;
}
if( ValueLengthField )
{
// Self
const ByteValue *bv = GetByteValue();
assert( bv );
assert( bv->GetLength() == ValueLengthField );
if( !bv->Write<TSwap>(os) )
{
assert(0 && "Should not happen");
return os;
}
}
return os;
}
*/
};
//-----------------------------------------------------------------------------
inline std::ostream &operator<<(std::ostream &os, const BasicOffsetTable &val)
{
os << " BasicOffsetTable Length=" << val.ValueLengthField << std::endl;
if( val.ValueField )
{
const ByteValue *bv = val.GetByteValue();
assert( bv );
os << *bv;
}
return os;
}
} // end namespace gdcm_ns
#endif //GDCMBASICOFFSETTABLE_H
|