| DCMTK
    Version 3.6.3
    OFFIS DICOM Toolkit | 
Abstract base class for most classes in module dcmdata. More...
 Inheritance diagram for DcmObject:
 Inheritance diagram for DcmObject:| Classes | |
| class | PrintHelper | 
| helper class to print a DcmObject to an ostream using operator<<  More... | |
| Public Member Functions | |
| DcmObject (const DcmTag &tag, const Uint32 len=0) | |
| constructor.  More... | |
| DcmObject (const DcmObject &obj) | |
| copy constructor  More... | |
| virtual | ~DcmObject () | 
| destructor | |
| virtual DcmObject * | clone () const =0 | 
| clone method  More... | |
| DcmObject & | operator= (const DcmObject &obj) | 
| copy assignment operator  More... | |
| virtual OFCondition | copyFrom (const DcmObject &rhs)=0 | 
| Virtual object copying.  More... | |
| virtual DcmEVR | ident () const =0 | 
| return identifier for this class.  More... | |
| DcmEVR | getVR () const | 
| return the value representation assigned to this object.  More... | |
| OFBool | isaString () const | 
| check if this element is a string type, based on the VR.  More... | |
| virtual OFBool | isLeaf () const =0 | 
| check if this element is a leaf node in a dataset tree.  More... | |
| virtual OFBool | isNested () const | 
| check if this element is nested in a sequence of items, i.e. not a top-level or stand-alone element  More... | |
| virtual void | print (STD_NAMESPACE ostream &out, const size_t flags=0, const int level=0, const char *pixelFileName=NULL, size_t *pixelCounter=NULL)=0 | 
| print object to a stream  More... | |
| E_TransferState | transferState () const | 
| return the current transfer (read/write) state of this object.  More... | |
| virtual void | transferInit (void) | 
| initialize the transfer state of this object.  More... | |
| virtual void | transferEnd (void) | 
| finalize the transfer state of this object.  More... | |
| DcmItem * | getRootItem () | 
| get root dataset/item (top-level) that contains this object.  More... | |
| virtual DcmItem * | getParentItem () | 
| get parent item of this object.  More... | |
| DcmObject * | getParent () | 
| get parent of this object.  More... | |
| const DcmObject * | getParent () const | 
| get parent of this object.  More... | |
| void | setParent (DcmObject *parent) | 
| set parent of this object.  More... | |
| Uint16 | getGTag () const | 
| return the group number of the attribute tag for this object  More... | |
| Uint16 | getETag () const | 
| return the element number of the attribute tag for this object  More... | |
| const DcmTag & | getTag () const | 
| return const reference to the attribute tag for this object  More... | |
| void | setGTag (Uint16 gtag) | 
| assign group tag (but not element tag) of the attribute tag for this object.  More... | |
| virtual OFCondition | setVR (DcmEVR) | 
| assign a new Value Representation (VR) to this object.  More... | |
| virtual unsigned long | getVM ()=0 | 
| return value multiplicity of the current object  More... | |
| virtual Uint32 | calcElementLength (const E_TransferSyntax xfer, const E_EncodingType enctype)=0 | 
| calculate the length of this DICOM element when encoded with the given transfer syntax and the given encoding type for sequences.  More... | |
| virtual Uint32 | getLength (const E_TransferSyntax xfer=EXS_LittleEndianImplicit, const E_EncodingType enctype=EET_UndefinedLength)=0 | 
| calculate the value length (without attribute tag, VR and length field) of this DICOM element when encoded with the given transfer syntax and the given encoding type for sequences.  More... | |
| virtual OFBool | canWriteXfer (const E_TransferSyntax newXfer, const E_TransferSyntax oldXfer)=0 | 
| check if this DICOM object can be encoded in the given transfer syntax.  More... | |
| virtual OFCondition | read (DcmInputStream &inStream, const E_TransferSyntax ixfer, const E_GrpLenEncoding glenc=EGL_noChange, const Uint32 maxReadLength=DCM_MaxReadLength)=0 | 
| read object from a stream.  More... | |
| virtual OFCondition | write (DcmOutputStream &outStream, const E_TransferSyntax oxfer, const E_EncodingType enctype, DcmWriteCache *wcache)=0 | 
| write object to a stream (abstract)  More... | |
| virtual OFCondition | writeXML (STD_NAMESPACE ostream &out, const size_t flags=0) | 
| write object in XML format to a stream  More... | |
| virtual OFCondition | writeJson (STD_NAMESPACE ostream &out, DcmJsonFormat &format) | 
| write object in JSON format to a stream  More... | |
| virtual OFCondition | writeSignatureFormat (DcmOutputStream &outStream, const E_TransferSyntax oxfer, const E_EncodingType enctype, DcmWriteCache *wcache)=0 | 
| special write method for creation of digital signatures (abstract)  More... | |
| virtual OFBool | isSignable () const | 
| returns true if the current object may be included in a digital signature  More... | |
| virtual OFBool | containsUnknownVR () const | 
| returns true if the object contains an element with Unknown VR at any nesting level  More... | |
| virtual OFBool | containsExtendedCharacters (const OFBool checkAllStrings=OFFalse) | 
| check if this object contains non-ASCII characters  More... | |
| virtual OFBool | isAffectedBySpecificCharacterSet () const | 
| check if this object is affected by SpecificCharacterSet  More... | |
| virtual OFCondition | convertCharacterSet (DcmSpecificCharacterSet &converter) | 
| convert this object from the currently selected source character set to the currently selected destination character set (if affected by SpecificCharacterSet)  More... | |
| virtual OFBool | isEmpty (const OFBool normalize=OFTrue) | 
| check if this object is empty  More... | |
| virtual OFCondition | clear ()=0 | 
| clear (remove) attribute value  More... | |
| virtual OFCondition | verify (const OFBool autocorrect=OFFalse)=0 | 
| check the currently stored element value  More... | |
| virtual DcmObject * | nextInContainer (const DcmObject *obj) | 
| this method is only used in container classes derived from this class, that is, DcmItem and DcmSequenceOfItems.  More... | |
| virtual OFCondition | nextObject (DcmStack &stack, const OFBool intoSub) | 
| this method enables a stack based, depth-first traversal of a complete hierarchical DICOM dataset (that is, classes derived from DcmItem or DcmSequenceOfItems).  More... | |
| virtual OFCondition | search (const DcmTagKey &xtag, DcmStack &resultStack, E_SearchMode mode=ESM_fromHere, OFBool searchIntoSub=OFTrue) | 
| a complex, stack-based, hierarchical search method.  More... | |
| virtual OFCondition | loadAllDataIntoMemory ()=0 | 
| this method loads all attribute values maintained by this object and all sub-objects (in case of a container such as DcmDataset) into memory.  More... | |
| Uint32 | getLengthField () const | 
| return the current value of the Length field (which is different from the functionality of the public getLength() method).  More... | |
| Protected Member Functions | |
| void | printNestingLevel (STD_NAMESPACE ostream &out, const size_t flags, const int level) | 
| print line indentation, e.g. a couple of spaces for each nesting level.  More... | |
| void | printInfoLineStart (STD_NAMESPACE ostream &out, const size_t flags, const int level, DcmTag *tag=NULL) | 
| print beginning of the info line.  More... | |
| void | printInfoLineEnd (STD_NAMESPACE ostream &out, const size_t flags, const unsigned long printedLength=0xffffffff, DcmTag *tag=NULL) | 
| print end of the info line.  More... | |
| virtual void | printInfoLine (STD_NAMESPACE ostream &out, const size_t flags, const int level=0, const char *info=NULL, DcmTag *tag=NULL, const OFBool isInfo=OFTrue) | 
| print given text with element information.  More... | |
| virtual OFCondition | writeTagAndLength (DcmOutputStream &outStream, const E_TransferSyntax oxfer, Uint32 &writtenBytes) const | 
| write tag, VR and length field to the given output stream  More... | |
| virtual Uint32 | getTagAndLengthSize (const E_TransferSyntax oxfer) const | 
| return the number of bytes needed to serialize the tag, VR and length information of the current object using the given transfer syntax.  More... | |
| const char * | getTagName () | 
| return the DICOM attribute tag name for this object.  More... | |
| void | setTagVR (DcmEVR vr) | 
| set the VR for this attribute  More... | |
| E_TransferState | getTransferState () const | 
| return the current transfer state of this object during serialization/deserialization  More... | |
| void | setTransferState (E_TransferState newState) | 
| set the current transfer state of this object during serialization/deserialization  More... | |
| Uint32 | getTransferredBytes () const | 
| return the number of transferred bytes for this object during serialization/deserialization  More... | |
| void | setTransferredBytes (Uint32 val) | 
| set the number of transferred bytes for this object during serialization/deserialization  More... | |
| void | incTransferredBytes (Uint32 val) | 
| add to the number of transferred bytes for this object during serialization/deserialization  More... | |
| void | setLengthField (Uint32 val) | 
| set the current value of the Length field  More... | |
| Static Protected Member Functions | |
| static OFCondition | writeTag (DcmOutputStream &outStream, const DcmTag &tag, const E_TransferSyntax oxfer) | 
| static helper function that writes a given attribute tag to a binary output stream using the byte order indicated by the transfer syntax.  More... | |
| Protected Attributes | |
| OFCondition | errorFlag | 
| error flag for this object. | |
| Private Attributes | |
| DcmTag | Tag | 
| the DICOM attribute tag and VR for this object | |
| Uint32 | Length | 
| the length of this attribute as read from stream, may be undefined length | |
| E_TransferState | fTransferState | 
| transfer state during read and write operations | |
| Uint32 | fTransferredBytes | 
| number of bytes already read/written during transfer | |
| DcmObject * | Parent | 
| pointer to parent object if contained in a dataset/item (might be NULL) | |
Abstract base class for most classes in module dcmdata.
As a rule of thumb, everything that is either a dataset or that can be identified with a DICOM attribute tag is derived from class DcmObject.
| DcmObject::DcmObject | ( | const DcmTag & | tag, | 
| const Uint32 | len = 0 | ||
| ) | 
constructor.
Create new object from given tag and length.
| tag | DICOM tag for the new element | 
| len | value length for the new element | 
| DcmObject::DcmObject | ( | const DcmObject & | obj | ) | 
copy constructor
| obj | item to be copied | 
| 
 | pure virtual | 
calculate the length of this DICOM element when encoded with the given transfer syntax and the given encoding type for sequences.
For elements, the length includes the length of the tag, length field, VR field and the value itself, for items and sequences it returns the length of the complete item or sequence including delimitation tags if applicable. Never returns undefined length.
| xfer | transfer syntax for length calculation | 
| enctype | sequence encoding type for length calculation | 
Implemented in DcmPixelData, DcmSequenceOfItems, DcmItem, DcmFileFormat, DcmDataset, DcmMetaInfo, DcmPixelSequence, DcmElement, and DcmPixelItem.
| 
 | pure virtual | 
check if this DICOM object can be encoded in the given transfer syntax.
| newXfer | transfer syntax in which the DICOM object is to be encoded | 
| oldXfer | transfer syntax in which the DICOM object was read or created. | 
Implemented in DcmPixelData, DcmSequenceOfItems, DcmItem, DcmPixelSequence, DcmFileFormat, DcmDataset, DcmElement, and DcmOtherByteOtherWord.
| 
 | pure virtual | 
clear (remove) attribute value
Implemented in DcmItem, DcmSequenceOfItems, DcmElement, DcmByteString, DcmFileFormat, DcmUnsignedLongOffset, and DcmDataset.
| 
 | pure virtual | 
clone method
Implemented in DcmPixelData, DcmDirectoryRecord, DcmItem, DcmByteString, DcmSequenceOfItems, DcmOtherByteOtherWord, DcmAttributeTag, DcmFloatingPointSingle, DcmSignedLong, DcmSignedShort, DcmUnsignedLong, DcmUnsignedShort, DcmFloatingPointDouble, DcmPixelSequence, DcmFileFormat, DcmCharString, DcmMetaInfo, DcmPixelItem, DcmOverlayData, DcmOtherLong, DcmUnsignedLongOffset, DcmDecimalString, DcmOtherDouble, DcmOtherFloat, DcmShortString, DcmDataset, DcmIntegerString, DcmLongString, DcmPersonName, DcmTime, DcmUniversalResourceIdentifierOrLocator, DcmApplicationEntity, DcmAgeString, DcmCodeString, DcmDate, DcmDateTime, DcmUnlimitedCharacters, DcmUnlimitedText, DcmShortText, DcmUniqueIdentifier, DcmLongText, and DcmPolymorphOBOW.
| 
 | virtual | 
check if this object contains non-ASCII characters
| checkAllStrings | not used in this class | 
Reimplemented in DcmSequenceOfItems, DcmItem, DcmByteString, and DcmCharString.
| 
 | virtual | 
returns true if the object contains an element with Unknown VR at any nesting level
Reimplemented in DcmSequenceOfItems, and DcmItem.
| 
 | virtual | 
convert this object from the currently selected source character set to the currently selected destination character set (if affected by SpecificCharacterSet)
| converter | character set converter to be used to convert the element values | 
Reimplemented in DcmFileFormat, DcmItem, DcmSequenceOfItems, DcmDirectoryRecord, and DcmCharString.
| 
 | pure virtual | 
Virtual object copying.
This method can be used for DcmObject and derived classes to get a deep copy of an object. Internally the assignment operator is called if the given DcmObject parameter is of the same type as "this" object instance. If not, an error is returned. This function permits copying an object by value in a virtual way which therefore is different to just calling the assignment operator of DcmElement which could result in slicing the object.
| rhs | - [in] The instance to copy from. Has to be of the same class type as "this" object | 
Implemented in DcmPixelData, DcmDirectoryRecord, DcmItem, DcmByteString, DcmSequenceOfItems, DcmElement, DcmOtherByteOtherWord, DcmAttributeTag, DcmFloatingPointSingle, DcmSignedLong, DcmSignedShort, DcmUnsignedLong, DcmUnsignedShort, DcmFloatingPointDouble, DcmPixelSequence, DcmPolymorphOBOW, DcmFileFormat, DcmCharString, DcmPixelItem, DcmMetaInfo, DcmOverlayData, DcmOtherLong, DcmUnsignedLongOffset, DcmDecimalString, DcmOtherDouble, DcmOtherFloat, DcmShortString, DcmDataset, DcmIntegerString, DcmLongString, DcmPersonName, DcmTime, DcmUniversalResourceIdentifierOrLocator, DcmApplicationEntity, DcmAgeString, DcmCodeString, DcmDate, DcmDateTime, DcmUnlimitedCharacters, DcmUnlimitedText, DcmShortText, DcmUniqueIdentifier, and DcmLongText.
| 
 | inline | 
return the element number of the attribute tag for this object
| 
 | inline | 
return the group number of the attribute tag for this object
| 
 | pure virtual | 
calculate the value length (without attribute tag, VR and length field) of this DICOM element when encoded with the given transfer syntax and the given encoding type for sequences.
Never returns undefined length.
| xfer | transfer syntax for length calculation | 
| enctype | sequence encoding type for length calculation | 
Implemented in DcmPixelData, DcmSequenceOfItems, DcmItem, DcmByteString, and DcmElement.
| 
 | inline | 
return the current value of the Length field (which is different from the functionality of the public getLength() method).
Only needed for internal purposes and for checker tools that verify values against the length field.
Referenced by DcmElement::getLength(), and DcmElement::valueLoaded().
| 
 | inline | 
get parent of this object.
If this object is an element that has been inserted into a dataset/item, the parent is this particular dataset/item. If this object is an item that has been inserted into a sequence, the parent is this particular sequence. If this object has not been inserted into a dataset/item or sequence, NULL is returned.
| 
 | inline | 
get parent of this object.
If this object is an element that has been inserted into a dataset/item, the parent is this particular dataset/item. If this object is an item that has been inserted into a sequence, the parent is this particular sequence. If this object has not been inserted into a dataset/item or sequence, NULL is returned.
| 
 | virtual | 
get parent item of this object.
In case of a top-level element, this is either the main dataset or the file meta-information. In case of a nested element, this is the surrounding item.
Reimplemented in DcmItem, and DcmPixelItem.
| DcmItem* DcmObject::getRootItem | ( | ) | 
get root dataset/item (top-level) that contains this object.
Internally, the list of parent pointers is followed in order to find the root. If this object has no parent item, a pointer to this object is returned instead.
| 
 | inline | 
return const reference to the attribute tag for this object
| 
 | protectedvirtual | 
return the number of bytes needed to serialize the tag, VR and length information of the current object using the given transfer syntax.
| oxfer | The transfer syntax used for encoding | 
| 
 | inlineprotected | 
return the DICOM attribute tag name for this object.
If not known yet, will be looked up in the dictionary and cached. Therefore, method is not const.
| 
 | inlineprotected | 
return the number of transferred bytes for this object during serialization/deserialization
| 
 | inlineprotected | 
return the current transfer state of this object during serialization/deserialization
| 
 | pure virtual | 
return value multiplicity of the current object
Implemented in DcmSequenceOfItems, DcmByteString, DcmItem, DcmAttributeTag, DcmOtherByteOtherWord, DcmSignedShort, DcmFloatingPointSingle, DcmSignedLong, DcmUnsignedLong, DcmUnsignedShort, DcmFloatingPointDouble, DcmOtherLong, DcmOtherDouble, DcmOtherFloat, DcmUnlimitedText, DcmShortText, DcmUniversalResourceIdentifierOrLocator, and DcmLongText.
Referenced by DcmIODUtil::copyFromUint8Array().
| 
 | inline | 
return the value representation assigned to this object.
If object was read from a stream, this method returns the VR that was defined in the stream for this object. It is, therefore, possible that the VR does not match the one defined in the data dictionary for the tag assigned to this object.
| 
 | pure virtual | 
return identifier for this class.
Every class derived from this class returns a unique value of type enum DcmEVR for this call. This is used as a "poor man's RTTI" to correctly identify instances derived from this class even on compilers not supporting RTTI.
Implemented in DcmPixelData, DcmDirectoryRecord, DcmItem, DcmByteString, DcmSequenceOfItems, DcmOtherByteOtherWord, DcmAttributeTag, DcmFloatingPointSingle, DcmSignedLong, DcmSignedShort, DcmUnsignedLong, DcmUnsignedShort, DcmFloatingPointDouble, DcmPixelSequence, DcmOverlayData, DcmFileFormat, DcmMetaInfo, DcmOtherLong, DcmUnsignedLongOffset, DcmDecimalString, DcmOtherDouble, DcmOtherFloat, DcmShortString, DcmDataset, DcmIntegerString, DcmLongString, DcmPersonName, DcmTime, DcmUniversalResourceIdentifierOrLocator, DcmApplicationEntity, DcmAgeString, DcmCodeString, DcmDate, DcmDateTime, DcmUnlimitedCharacters, DcmUnlimitedText, DcmShortText, DcmUniqueIdentifier, DcmLongText, and DcmPixelItem.
Referenced by DcmOverlayData::copyFrom().
| 
 | inlineprotected | 
add to the number of transferred bytes for this object during serialization/deserialization
| val | number of additional transferred bytes to add to existing value | 
| 
 | virtual | 
check if this object is affected by SpecificCharacterSet
Reimplemented in DcmSequenceOfItems, DcmItem, DcmByteString, and DcmCharString.
| 
 | inline | 
check if this element is a string type, based on the VR.
Since the check is based on the VR and not on the class, the result of this method is not a guarantee that the object can be safely casted to one of the string-VR subclasses.
check if this object is empty
| normalize | normalize value before checking (ignore non-significant characters) | 
Reimplemented in DcmItem, DcmSequenceOfItems, and DcmByteString.
| 
 | pure virtual | 
check if this element is a leaf node in a dataset tree.
All subclasses of DcmElement except for DcmSequenceOfItems are leaf nodes, while DcmSequenceOfItems, DcmItem, DcmDataset etc. are not.
Implemented in DcmItem, DcmElement, and DcmSequenceOfItems.
| 
 | virtual | 
check if this element is nested in a sequence of items, i.e. not a top-level or stand-alone element
Reimplemented in DcmItem, and DcmPixelItem.
| 
 | virtual | 
returns true if the current object may be included in a digital signature
Reimplemented in DcmSequenceOfItems.
| 
 | pure virtual | 
this method loads all attribute values maintained by this object and all sub-objects (in case of a container such as DcmDataset) into memory.
After a call to this method, the file from which a dataset was read may safely be deleted or replaced. For large files, this method may obviously allocate large amounts of memory.
Implemented in DcmItem, DcmSequenceOfItems, DcmPixelData, and DcmElement.
this method is only used in container classes derived from this class, that is, DcmItem and DcmSequenceOfItems.
It returns a pointer to the next object in the list AFTER the given object. If the caller passes NULL, a pointer to the first object in the list is returned. If the given object is not found, the given object is the last one in the list or the list is empty, NULL is returned.
| obj | pointer to one object in the container; we are looking for the next entry after this one. NULL if looking for the first entry. | 
Reimplemented in DcmItem, and DcmSequenceOfItems.
| 
 | virtual | 
this method enables a stack based, depth-first traversal of a complete hierarchical DICOM dataset (that is, classes derived from DcmItem or DcmSequenceOfItems).
With each call of this method, the next object in the tree is located and marked on the stack.
| stack | "cursor" for current position in the dataset. The stack will contain a pointer to each dataset, sequence, item and element from the main dataset down to the current element, and is updated upon each call to this method. An empty stack is equivalent to a stack containing a pointer to this object only. | 
| intoSub | if true, the nextObject method will perform a hierarchical search through the dataset (depth-first), if false, only the current container object will be traversed (e.g., all elements of an item or all items of a sequence). | 
Reimplemented in DcmItem, and DcmSequenceOfItems.
copy assignment operator
| obj | object to be copied | 
| 
 | pure virtual | 
print object to a stream
| out | output stream | 
| flags | optional flag used to customize the output (see DCMTypes::PF_xxx) | 
| level | current level of nested items. Used for indentation. | 
| pixelFileName | not used (used in certain sub-classes of this class) | 
| pixelCounter | not used (used in certain sub-classes of this class) | 
Implemented in DcmPixelData, DcmDirectoryRecord, DcmByteString, DcmItem, DcmOtherByteOtherWord, DcmDataset, DcmSequenceOfItems, DcmAttributeTag, DcmFloatingPointSingle, DcmSignedShort, DcmFloatingPointDouble, DcmSignedLong, DcmUnsignedLong, DcmUnsignedShort, DcmFileFormat, DcmMetaInfo, DcmPixelItem, DcmPixelSequence, and DcmUniqueIdentifier.
Referenced by operator<<().
| 
 | protectedvirtual | 
print given text with element information.
Calls printInfoLineStart() and printInfoLineEnd() to frame the 'info' text.
| out | output stream | 
| flags | used to customize the output (see DCMTypes::PF_xxx) | 
| level | current level of nested items. Used for indentation. | 
| info | text to be printed | 
| tag | optional tag used to print the data element information | 
| isInfo | optional flag indicating whether this text is really given for informational purposes only. Used to choose the correct output color. | 
| 
 | protected | 
print end of the info line.
The default output is length, value multiplicity and tag name, though other visualizations are possible depending on the value of 'flags'.
| out | output stream | 
| flags | used to customize the output (see DCMTypes::PF_xxx) | 
| printedLength | number of characters printed after line start. Used for padding purposes. | 
| tag | optional tag used to print the data element information | 
| 
 | protected | 
print beginning of the info line.
The default output is tag and value representation, though other visualizations are possible depending on the value of 'flags'.
| out | output stream | 
| flags | used to customize the output (see DCMTypes::PF_xxx) | 
| level | current level of nested items. Used for indentation. | 
| tag | optional tag used to print the data element information | 
| 
 | protected | 
print line indentation, e.g. a couple of spaces for each nesting level.
Depending on the value of 'flags' other visualizations are also possible.
| out | output stream | 
| flags | used to customize the output (see DCMTypes::PF_xxx) | 
| level | current level of nested items. Used for indentation. | 
| 
 | pure virtual | 
read object from a stream.
| inStream | DICOM input stream | 
| ixfer | transfer syntax to use when parsing | 
| glenc | handling of group length parameters | 
| maxReadLength | attribute values larger than this value are skipped while parsing and read later upon first access if the stream type supports this. | 
Implemented in DcmPixelData, DcmDirectoryRecord, DcmSequenceOfItems, DcmItem, DcmPixelSequence, DcmDataset, DcmFileFormat, DcmElement, DcmMetaInfo, and DcmPolymorphOBOW.
| 
 | virtual | 
a complex, stack-based, hierarchical search method.
It allows for a search for a DICOM object with a given attribute within a given container, hierarchically, from a starting position identified through a cursor stack.
| xtag | the DICOM attribute tag we are searching for | 
| resultStack | Depending on the search mode (see below), this parameter either serves as an input and output parameter, or as an output parameter only (the latter being the default). When used as an input parameter, the cursor stack defines the start position for the search within a hierarchical DICOM dataset. Upon successful return, the stack contains the position of the element found, in the form of a pointer to each dataset, sequence, item and element from the main dataset down to the found element. | 
| mode | search mode, controls how the search stack is handled. In the default mode, ESM_fromHere, the stack is ignored on input, and the search starts in the object for which this method is called. In the other modes, the stack is used both as an input and an output parameter and defines the starting point for the search. | 
| searchIntoSub | if true, the search will be performed hierarchically descending into the sequences and items of the dataset. If false, only the current container (sequence or item) will be traversed. | 
Reimplemented in DcmItem, DcmSequenceOfItems, and DcmDirectoryRecord.
| 
 | inline | 
assign group tag (but not element tag) of the attribute tag for this object.
This is sometimes useful when creating repeating group elements.
| gtag | new attribute group tag | 
| 
 | inlineprotected | 
set the current value of the Length field
| val | new value of the Length field | 
| 
 | inline | 
set parent of this object.
NULL means no parent. NB: This method is used by derived classes for internal purposes only.
| parent | pointer to the parent of this object | 
| 
 | inlineprotected | 
set the VR for this attribute
| vr | new VR for this attribute. | 
Referenced by DcmPixelData::recalcVR().
| 
 | inlineprotected | 
set the number of transferred bytes for this object during serialization/deserialization
| val | number of transferred bytes | 
| 
 | inlineprotected | 
set the current transfer state of this object during serialization/deserialization
| newState | new transfer state of this object | 
| 
 | inlinevirtual | 
assign a new Value Representation (VR) to this object.
This operation is only supported for very few subclasses derived from this class, in particular for classes handling pixel data which may either be of OB or OW value representation.
| vr | value representation | 
Reimplemented in DcmPixelData, and DcmOtherByteOtherWord.
References EC_IllegalCall.
| 
 | virtual | 
finalize the transfer state of this object.
This method must be called when reading/writing this object from/to a stream has been completed.
Reimplemented in DcmPixelData, DcmSequenceOfItems, DcmItem, DcmPolymorphOBOW, and DcmMetaInfo.
| 
 | virtual | 
initialize the transfer state of this object.
This method must be called before this object is written to a stream or read (parsed) from a stream.
Reimplemented in DcmPixelData, DcmSequenceOfItems, DcmItem, DcmPolymorphOBOW, DcmElement, and DcmMetaInfo.
| 
 | inline | 
return the current transfer (read/write) state of this object.
| 
 | pure virtual | 
check the currently stored element value
| autocorrect | correct value length if OFTrue | 
Implemented in DcmItem, DcmSequenceOfItems, DcmDirectoryRecord, DcmOtherByteOtherWord, DcmByteString, DcmAttributeTag, DcmFloatingPointSingle, DcmFloatingPointDouble, DcmSignedLong, DcmSignedShort, DcmUnsignedLong, DcmUnsignedShort, DcmUnsignedLongOffset, and DcmCharString.
| 
 | pure virtual | 
write object to a stream (abstract)
| outStream | DICOM output stream | 
| oxfer | output transfer syntax | 
| enctype | encoding types (undefined or explicit length) | 
| wcache | pointer to write cache object, may be NULL | 
Implemented in DcmPixelData, DcmItem, DcmSequenceOfItems, DcmDataset, DcmFileFormat, DcmPixelSequence, DcmElement, DcmByteString, DcmMetaInfo, DcmOtherByteOtherWord, and DcmPolymorphOBOW.
| 
 | virtual | 
write object in JSON format to a stream
| out | output stream to which the JSON document is written | 
| format | used to format and customize the output | 
Reimplemented in DcmItem, DcmByteString, DcmSequenceOfItems, DcmDataset, DcmFileFormat, DcmElement, DcmMetaInfo, DcmOtherByteOtherWord, DcmPersonName, DcmAttributeTag, DcmDecimalString, DcmCharString, DcmIntegerString, DcmOtherLong, DcmOtherDouble, DcmOtherFloat, DcmShortString, and DcmLongString.
| 
 | pure virtual | 
special write method for creation of digital signatures (abstract)
| outStream | DICOM output stream | 
| oxfer | output transfer syntax | 
| enctype | encoding types (undefined or explicit length) | 
| wcache | pointer to write cache object, may be NULL | 
Implemented in DcmPixelData, DcmItem, DcmSequenceOfItems, DcmDataset, DcmElement, DcmPixelSequence, DcmOtherByteOtherWord, DcmByteString, DcmPolymorphOBOW, and DcmPixelItem.
| 
 | staticprotected | 
static helper function that writes a given attribute tag to a binary output stream using the byte order indicated by the transfer syntax.
| outStream | output stream | 
| tag | tag to write to the stream | 
| oxfer | transfer syntax defining the byte order | 
| 
 | protectedvirtual | 
write tag, VR and length field to the given output stream
| outStream | output stream | 
| oxfer | transfer syntax for writing | 
| writtenBytes | number of bytes written to stream returned in this parameter | 
Reimplemented in DcmPixelItem.
| 
 | virtual | 
write object in XML format to a stream
| out | output stream to which the XML document is written | 
| flags | optional flag used to customize the output (see DCMTypes::XF_xxx) | 
Reimplemented in DcmPixelData, DcmDirectoryRecord, DcmItem, DcmSequenceOfItems, DcmDataset, DcmFileFormat, DcmPixelSequence, DcmElement, DcmMetaInfo, DcmOtherByteOtherWord, DcmPersonName, DcmAttributeTag, DcmPixelItem, DcmDecimalString, DcmOtherLong, DcmOtherDouble, and DcmOtherFloat.