#include <avi_surface.h>
Public Member Functions | |
uint32 | read (void *dataPtr, uint32 dataSize) override |
bool | eos () const override |
int64 | pos () const override |
int64 | size () const override |
bool | seek (int64 offset, int whence=SEEK_SET) override |
bool | skip (uint32 offset) override |
char * | readLine (char *s, size_t bufSize, bool handleCR=true) override |
Common::String | readLine (bool handleCR=true) override |
Public Member Functions inherited from Common::SeekableReadStream | |
void | hexdump (int len, int bytesPerLine=16, int startOffset=0) |
Public Member Functions inherited from Common::ReadStream | |
byte | readByte () |
FORCEINLINE int8 | readSByte () |
uint16 | readUint16LE () |
uint32 | readUint32LE () |
uint64 | readUint64LE () |
uint16 | readUint16BE () |
uint32 | readUint32BE () |
uint64 | readUint64BE () |
FORCEINLINE int16 | readSint16LE () |
FORCEINLINE int32 | readSint32LE () |
FORCEINLINE int64 | readSint64LE () |
FORCEINLINE int16 | readSint16BE () |
FORCEINLINE int32 | readSint32BE () |
FORCEINLINE int64 | readSint64BE () |
FORCEINLINE float | readFloatLE () |
FORCEINLINE float | readFloatBE () |
FORCEINLINE double | readDoubleLE () |
FORCEINLINE double | readDoubleBE () |
template<class TDataFormat , class... T> | |
bool | readMultiple (const TDataFormat &dataFormat, T &...values) |
template<class... T> | |
bool | readMultipleEndian (bool isLittle, T &...values) |
template<class... T> | |
bool | readMultipleLE (T &...values) |
template<class... T> | |
bool | readMultipleBE (T &...values) |
SeekableReadStream * | readStream (uint32 dataSize) |
String | readString (char terminator=0, size_t len=String::npos) |
Common::String | readPascalString (bool transformCR=true) |
Public Member Functions inherited from Common::Stream | |
virtual bool | err () const |
virtual void | clearErr () |
This implements a special read stream for the y222.avi video that fixes that totalFrames field of the header from it's incorrect value of 1 to a correct 1085.
|
overridevirtual |
Read data from the stream.
Subclasses must implement this method. All other read methods are implemented using it.
dataPtr | Pointer to a buffer into which the data is read. |
dataSize | Number of bytes to be read. |
Implements Common::ReadStream.
|
inlineoverridevirtual |
Return true if a read failed because the stream end has been reached.
This flag is cleared by clearErr(). For a SeekableReadStream, the flag is also cleared by a successful seek.
Implements Common::ReadStream.
|
inlineoverridevirtual |
Obtain the current value of the stream position indicator.
Implements Common::SeekableReadStream.
|
inlineoverridevirtual |
Obtain the total size of the stream, measured in bytes. If this value is unknown or cannot be computed, -1 is returned.
Implements Common::SeekableReadStream.
|
inlineoverridevirtual |
Set the stream position indicator for the stream.
The new position, measured in bytes, is obtained by adding offset bytes to the position specified by whence. If whence is set to SEEK_SET, SEEK_CUR, or SEEK_END, the offset is relative to the start of the file, the current position indicator, or end-of-stream, respectively. A successful call to the seek() method clears the end-of-stream indicator for the stream.
offset | Relative offset in bytes. |
whence | Seek reference: SEEK_SET, SEEK_CUR, or SEEK_END. |
Implements Common::SeekableReadStream.
|
inlineoverridevirtual |
Skip the given number of bytes in the stream.
This is equivalent to calling:
to add the given number of bytes to the current position indicator of the stream.
Reimplemented from Common::SeekableReadStream.
|
inlineoverridevirtual |
Read at most one less than the number of characters specified by bufSize
from the stream and store them in the string buffer.
Reading stops when the end of a line is reached (CR, CR/LF, or LF), and at end-of-stream or error. The newline, if any, is retained (CR and CR/LF are translated to LF = 0xA = '\n'
). If any characters are read and there is no error, a \0
character is appended to end the string.
Upon successful completion, return a pointer to the string. If end-of-stream occurs before any characters are read, returns NULL and the buffer contents remain unchanged. If an error occurs, returns NULL and the buffer contents are indeterminate. This method does not distinguish between end-of-stream and error; callers must use err() or eos() to determine which occurred.
s | The buffer to store into. |
bufSize | Size of the buffer. |
handleCR | If set (default), then CR and CR/LF are handled, as well as LF. |
Reimplemented from Common::SeekableReadStream.
|
inlineoverridevirtual |
Read a full line and returns it as a Common::String.
Reading stops when the end of a line is reached (CR, CR/LF, or LF), and at end-of-stream or error.
Upon successful completion, return a string with the content of the line, without the end of a line marker. This method does not indicate whether an error occurred. Callers must use err() or eos() to determine whether an exception occurred.
handleCR | If set (default), then CR and CR/LF are handled, as well as LF. |
Reimplemented from Common::SeekableReadStream.