OGRE 14.3
Object-Oriented Graphics Rendering Engine
|
General purpose class used for encapsulating the reading and writing of data. More...
#include <OgreDataStream.h>
Public Types | |
enum | AccessMode { READ = 1 , WRITE = 2 } |
Public Member Functions | |
DataStream (const String &name, uint16 accessMode=READ) | |
Constructor for creating named streams. | |
DataStream (uint16 accessMode=READ) | |
Constructor for creating unnamed streams. | |
virtual | ~DataStream () |
virtual void | close (void)=0 |
Close the stream; this makes further operations invalid. | |
virtual bool | eof (void) const =0 |
Returns true if the stream has reached the end. | |
uint16 | getAccessMode () const |
Gets the access mode of the stream. | |
virtual String | getAsString (void) |
Returns a String containing the entire stream. | |
virtual String | getLine (bool trimAfter=true) |
Returns a String containing the next line of data, optionally trimmed for whitespace. | |
const String & | getName (void) |
Returns the name of the stream, if it has one. | |
virtual bool | isReadable () const |
Reports whether this stream is readable. | |
virtual bool | isWriteable () const |
Reports whether this stream is writeable. | |
template<typename T > | |
DataStream & | operator>> (T &val) |
virtual size_t | read (void *buf, size_t count)=0 |
Read the requisite number of bytes from the stream, stopping at the end of the file. | |
virtual size_t | readLine (char *buf, size_t maxCount, const String &delim="\n") |
Get a single line from the stream. | |
virtual void | seek (size_t pos)=0 |
Repositions the read point to a specified byte. | |
size_t | size (void) const |
Returns the total size of the data to be read from the stream, or 0 if this is indeterminate for this stream. | |
virtual void | skip (long count)=0 |
Skip a defined number of bytes. | |
virtual size_t | skipLine (const String &delim="\n") |
Skip a single line from the stream. | |
virtual size_t | tell (void) const =0 |
Returns the current byte offset from beginning. | |
virtual size_t | write (const void *buf, size_t count) |
Write the requisite number of bytes from the stream (only applicable to streams that are not read-only) | |
General purpose class used for encapsulating the reading and writing of data.
This class performs basically the same tasks as std::basic_istream, except that it does not have any formatting capabilities, and is designed to be subclassed to receive data from multiple sources, including libraries which have no compatibility with the STL's stream interfaces. As such, this is an abstraction of a set of wrapper classes which pretend to be standard stream classes but can actually be implemented quite differently.
Constructor for creating unnamed streams.
Constructor for creating named streams.
|
inlinevirtual |
Returns the name of the stream, if it has one.
|
inline |
Gets the access mode of the stream.
Reports whether this stream is readable.
Reports whether this stream is writeable.
DataStream & Ogre::DataStream::operator>> | ( | T & | val | ) |
Read the requisite number of bytes from the stream, stopping at the end of the file.
buf | Reference to a buffer pointer |
count | Number of bytes to read |
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
Write the requisite number of bytes from the stream (only applicable to streams that are not read-only)
buf | Pointer to a buffer containing the bytes to write |
count | Number of bytes to write |
Reimplemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
|
virtual |
Get a single line from the stream.
The delimiter character is not included in the data returned, and it is skipped over so the next read will occur after it. The buffer contents will include a terminating character.
buf | Reference to a buffer pointer |
maxCount | The maximum length of data to be read, excluding the terminating character |
delim | The delimiter to stop at |
Reimplemented in Ogre::MemoryDataStream, and Ogre::FileStreamDataStream.
Returns a String containing the next line of data, optionally trimmed for whitespace.
This is a convenience method for text streams only, allowing you to retrieve a String object containing the next line of data. The data is read up to the next newline character and the result trimmed if required.
trimAfter | If true, the line is trimmed for whitespace (as in String.trim(true,true)) |
Returns a String containing the entire stream.
This is a convenience method for text streams only, allowing you to retrieve a String object containing all the data in the stream.
Skip a single line from the stream.
Reimplemented in Ogre::MemoryDataStream.
Skip a defined number of bytes.
This can also be a negative value, in which case the file pointer rewinds a defined number of bytes.
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
Repositions the read point to a specified byte.
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
Returns the current byte offset from beginning.
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
Returns true if the stream has reached the end.
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.
Returns the total size of the data to be read from the stream, or 0 if this is indeterminate for this stream.
Close the stream; this makes further operations invalid.
Implemented in Ogre::MemoryDataStream, Ogre::FileStreamDataStream, Ogre::FileHandleDataStream, and Ogre::DeflateStream.