DCMTK
Version 3.6.2
OFFIS DICOM Toolkit
|
consumer class that stores data in a buffer provided by the caller. More...
Public Member Functions | |
DcmBufferConsumer (void *buf, offile_off_t bufLen) | |
constructor More... | |
virtual | ~DcmBufferConsumer () |
destructor | |
virtual OFBool | good () const |
returns the status of the consumer. More... | |
virtual OFCondition | status () const |
returns the status of the consumer as an OFCondition object. More... | |
virtual OFBool | isFlushed () const |
returns true if the consumer is flushed, i.e. More... | |
virtual offile_off_t | avail () const |
returns the minimum number of bytes that can be written with the next call to write(). More... | |
virtual offile_off_t | write (const void *buf, offile_off_t buflen) |
processes as many bytes as possible from the given input block. More... | |
virtual void | flush () |
instructs the consumer to flush its internal content until either the consumer becomes "flushed" or I/O suspension occurs. More... | |
virtual void | flushBuffer (void *&buffer, offile_off_t &length) |
retrieves and flushes the underlying buffer. More... | |
virtual offile_off_t | filled () |
query the number of bytes in buffer without flushing it. More... | |
![]() | |
virtual | ~DcmConsumer () |
destructor | |
Private Member Functions | |
DcmBufferConsumer (const DcmBufferConsumer &) | |
private unimplemented copy constructor | |
DcmBufferConsumer & | operator= (const DcmBufferConsumer &) |
private unimplemented copy assignment operator | |
Private Attributes | |
unsigned char * | buffer_ |
the buffer we're actually writing to | |
offile_off_t | bufSize_ |
size of the buffer, in bytes | |
offile_off_t | filled_ |
number of bytes filled in buffer | |
OFCondition | status_ |
status | |
consumer class that stores data in a buffer provided by the caller.
Used for DICOM network communication.
DcmBufferConsumer::DcmBufferConsumer | ( | void * | buf, |
offile_off_t | bufLen | ||
) |
constructor
buf | buffer in which data is stored. Must be allocated by caller and remain valid during the lifetime of this object. |
bufLen | buffer length, must be even number > 0. |
|
virtual |
returns the minimum number of bytes that can be written with the next call to write().
The DcmObject write methods rely on avail to return a value > 0 if there is no I/O suspension since certain data such as tag and length are only written "en bloc", i.e. all or nothing.
Implements DcmConsumer.
|
virtual |
query the number of bytes in buffer without flushing it.
|
virtual |
instructs the consumer to flush its internal content until either the consumer becomes "flushed" or I/O suspension occurs.
After a call to flush(), a call to write() will produce undefined behaviour.
Implements DcmConsumer.
|
virtual |
retrieves and flushes the underlying buffer.
After return of this method, the buffer is considered to have been flushed (copied, stored) by the caller and is reused by the next write operation.
buffer | pointer to user provided buffer returned in this parameter |
length | number of bytes in buffer returned in this parameter |
|
virtual |
returns the status of the consumer.
Unless the status is good, the consumer will not permit any operation.
Implements DcmConsumer.
|
virtual |
returns true if the consumer is flushed, i.e.
has no more data pending in it's internal state that needs to be flushed before the stream is closed.
Implements DcmConsumer.
|
virtual |
returns the status of the consumer as an OFCondition object.
Unless the status is good, the consumer will not permit any operation.
Implements DcmConsumer.
|
virtual |
processes as many bytes as possible from the given input block.
buf | pointer to memory block, must not be NULL |
buflen | length of memory block |
Implements DcmConsumer.