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
|
/*=========================================================================
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 GDCMSEQUENCEOFITEMS_TXX
#define GDCMSEQUENCEOFITEMS_TXX
namespace gdcm
{
template <typename TDE>
VL SequenceOfItems::ComputeLength() const
{
typename ItemVector::const_iterator it = Items.begin();
VL length = 0;
for(;it != Items.end(); ++it)
{
length += it->template GetLength<TDE>();
}
if( SequenceLengthField.IsUndefined() )
{
length += 8; // item end delimitor (tag + vl)
}
// For defined length SQ, make sure computation is correct (compare
// to original length)
//assert( SequenceLengthField.IsUndefined()
// || length == SequenceLengthField );
return length;
}
} // end namespace gdcm
#endif // GDCMSEQUENCEOFITEMS_TXX
|