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 127 128 129 130 131 132 133
|
/*
*
* Copyright (C) 1994-2021, OFFIS e.V.
* All rights reserved. See COPYRIGHT file for details.
*
* This software and supporting documentation were developed by
*
* OFFIS e.V.
* R&D Division Health
* Escherweg 2
* D-26121 Oldenburg, Germany
*
*
* Module: dcmdata
*
* Author: Gerd Ehlers, Andreas Barth
*
* Purpose: Implementation of class DcmUnsignedLongOffset
*
*/
#include "dcmtk/config/osconfig.h"
#include "dcmtk/dcmdata/dcvrulup.h"
// ********************************
DcmUnsignedLongOffset::DcmUnsignedLongOffset(const DcmTag &tag)
: DcmUnsignedLong(tag, 0),
nextRecord(NULL)
{
}
DcmUnsignedLongOffset::DcmUnsignedLongOffset(const DcmTag &tag,
const Uint32 len)
: DcmUnsignedLong(tag, len),
nextRecord(NULL)
{
}
DcmUnsignedLongOffset::DcmUnsignedLongOffset(const DcmUnsignedLongOffset &old)
: DcmUnsignedLong(old),
nextRecord(old.nextRecord)
{
}
DcmUnsignedLongOffset& DcmUnsignedLongOffset::operator=(const DcmUnsignedLongOffset& obj)
{
if (this != &obj)
{
// copy parent's member variables
DcmUnsignedLong::operator=(obj);
// copy member variables
nextRecord = obj.nextRecord;
}
return *this;
}
DcmUnsignedLongOffset::~DcmUnsignedLongOffset()
{
}
OFCondition DcmUnsignedLongOffset::copyFrom(const DcmObject& rhs)
{
if (this != &rhs)
{
if (rhs.ident() != ident()) return EC_IllegalCall;
*this = OFstatic_cast(const DcmUnsignedLongOffset &, rhs);
}
return EC_Normal;
}
// ********************************
DcmEVR DcmUnsignedLongOffset::ident() const
{
/* internal type identifier */
return EVR_up;
}
OFCondition DcmUnsignedLongOffset::clear()
{
/* call inherited method */
errorFlag = DcmUnsignedLong::clear();
/* remove reference to object */
nextRecord = NULL;
return errorFlag;
}
// ********************************
DcmObject* DcmUnsignedLongOffset::getNextRecord()
{
errorFlag = EC_Normal;
/* return pointer to currently stored object reference */
return nextRecord;
}
DcmObject *DcmUnsignedLongOffset::setNextRecord(DcmObject *record)
{
errorFlag = EC_Normal;
/* store new object reference */
nextRecord = record;
return record;
}
// ********************************
OFCondition DcmUnsignedLongOffset::verify(const OFBool autocorrect)
{
/* call inherited method */
errorFlag = DcmUnsignedLong::verify(autocorrect);
/* perform additional checks on the stored value */
Uint32 *uintVals;
errorFlag = getUint32Array(uintVals);
if (errorFlag.good() && (getLengthField() > 0) && (uintVals != NULL) && (*uintVals != 0) && (nextRecord == NULL))
errorFlag = EC_CorruptedData;
return errorFlag;
}
|