Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Namespace Members | Class Members | File Members | Related Pages

Ogre::MemoryDataStream Class Reference

Common subclass of DataStream for handling data from chunks of memory. More...

#include <OgreDataStream.h>

Inheritance diagram for Ogre::MemoryDataStream:

Ogre::DataStream List of all members.

Public Member Functions

 MemoryDataStream (void *pMem, size_t size, bool freeOnClose=false)
 Wrap an existing memory chunk in a stream.

 MemoryDataStream (const String &name, void *pMem, size_t size, bool freeOnClose=false)
 Wrap an existing memory chunk in a named stream.

 MemoryDataStream (DataStream &sourceStream, bool freeOnClose=true)
 Create a stream which pre-buffers the contents of another stream.

 MemoryDataStream (DataStreamPtr &sourceStream, bool freeOnClose=true)
 Create a stream which pre-buffers the contents of another stream.

 MemoryDataStream (const String &name, DataStream &sourceStream, bool freeOnClose=true)
 Create a named stream which pre-buffers the contents of another stream.

 MemoryDataStream (const String &name, const DataStreamPtr &sourceStream, bool freeOnClose=true)
 Create a named stream which pre-buffers the contents of another stream.

 MemoryDataStream (size_t size, bool freeOnClose=true)
 Create a stream with a brand new empty memory chunk.

 MemoryDataStream (const String &name, size_t size, bool freeOnClose=true)
 Create a named stream with a brand new empty memory chunk.

 ~MemoryDataStream ()
uchargetPtr (void)
 Get a pointer to the start of the memory block this stream holds.

uchargetCurrentPtr (void)
 Get a pointer to the current position in the memory block this stream holds.

size_t read (void *buf, size_t count)
 
Parameters:
buf Reference to a buffer pointer
count Number of bytes to read
Returns:
The number of bytes read


size_t readLine (char *buf, size_t maxCount, const String &delim="\n")
 
Remarks:
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.
Parameters:
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
Returns:
The number of bytes read, excluding the terminating character


size_t skipLine (const String &delim="\n")
 
Parameters:
delim The delimiter(s) to stop at
Returns:
The number of bytes skipped


void skip (long count)
 This can also be a negative value, in which case the file pointer rewinds a defined number of bytes.

void seek (size_t pos)
 

size_t tell (void) const
 

bool eof (void) const
 

void close (void)
 

void setFreeOnClose (bool free)
 Sets whether or not to free the encapsulated memory on close.

const StringgetName (void)
 Returns the name of the stream, if it has one.

template<typename T> DataStreamoperator>> (T &val)
virtual String getLine (bool trimAfter=true)
 Returns a String containing the next line of data, optionally trimmed for whitespace.

virtual String getAsString (void)
 Returns a String containing the entire stream.

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.


Protected Attributes

ucharmData
 Pointer to the start of the data area.

ucharmPos
 Pointer to the current position in the memory.

ucharmEnd
 Pointer to the end of the memory.

bool mFreeOnClose
 Do we delete the memory on close.

String mName
 The name (e.g. resource name) that can be used to identify the source fot his data (optional).

size_t mSize
 Size of the data in the stream (may be 0 if size cannot be determined).

char mTmpArea [OGRE_STREAM_TEMP_SIZE]
 Temporary buffer area used for formatted read.


Detailed Description

Common subclass of DataStream for handling data from chunks of memory.

Definition at line 158 of file OgreDataStream.h.


Constructor & Destructor Documentation

Ogre::MemoryDataStream::MemoryDataStream void *  pMem,
size_t  size,
bool  freeOnClose = false
 

Wrap an existing memory chunk in a stream.

Parameters:
pMem Pointer to the exising memory
size The size of the memory chunk in bytes
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream const String name,
void *  pMem,
size_t  size,
bool  freeOnClose = false
 

Wrap an existing memory chunk in a named stream.

Parameters:
name The name to give the stream
pMem Pointer to the exising memory
size The size of the memory chunk in bytes
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream DataStream sourceStream,
bool  freeOnClose = true
 

Create a stream which pre-buffers the contents of another stream.

Remarks:
This constructor can be used to intentionally read in the entire contents of another stream, copying them to the internal buffer and thus making them available in memory as a single unit.
Parameters:
sourceStream Another DataStream which will provide the source of data
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream DataStreamPtr sourceStream,
bool  freeOnClose = true
 

Create a stream which pre-buffers the contents of another stream.

Remarks:
This constructor can be used to intentionally read in the entire contents of another stream, copying them to the internal buffer and thus making them available in memory as a single unit.
Parameters:
sourceStream Weak reference to another DataStream which will provide the source of data
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream const String name,
DataStream sourceStream,
bool  freeOnClose = true
 

Create a named stream which pre-buffers the contents of another stream.

Remarks:
This constructor can be used to intentionally read in the entire contents of another stream, copying them to the internal buffer and thus making them available in memory as a single unit.
Parameters:
name The name to give the stream
sourceStream Another DataStream which will provide the source of data
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream const String name,
const DataStreamPtr sourceStream,
bool  freeOnClose = true
 

Create a named stream which pre-buffers the contents of another stream.

Remarks:
This constructor can be used to intentionally read in the entire contents of another stream, copying them to the internal buffer and thus making them available in memory as a single unit.
Parameters:
name The name to give the stream
sourceStream Another DataStream which will provide the source of data
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream size_t  size,
bool  freeOnClose = true
 

Create a stream with a brand new empty memory chunk.

Parameters:
size The size of the memory chunk to create in bytes
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::MemoryDataStream const String name,
size_t  size,
bool  freeOnClose = true
 

Create a named stream with a brand new empty memory chunk.

Parameters:
name The name to give the stream
size The size of the memory chunk to create in bytes
freeOnClose If true, the memory associated will be destroyed when the stream is destroyed.

Ogre::MemoryDataStream::~MemoryDataStream  ) 
 


Member Function Documentation

void Ogre::MemoryDataStream::close void   )  [virtual]
 

Implements Ogre::DataStream.

bool Ogre::MemoryDataStream::eof void   )  const [virtual]
 

Implements Ogre::DataStream.

virtual String Ogre::DataStream::getAsString void   )  [virtual, inherited]
 

Returns a String containing the entire stream.

Remarks:
This is a convenience method for text streams only, allowing you to retrieve a String object containing all the data in the stream.

uchar* Ogre::MemoryDataStream::getCurrentPtr void   ) 
 

Get a pointer to the current position in the memory block this stream holds.

Definition at line 266 of file OgreDataStream.h.

References Ogre::uchar.

virtual String Ogre::DataStream::getLine bool  trimAfter = true  )  [virtual, inherited]
 

Returns a String containing the next line of data, optionally trimmed for whitespace.

Remarks:
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.
Parameters:
trimAfter If true, the line is trimmed for whitespace (as in String.trim(true,true))

const String& Ogre::DataStream::getName void   )  [inherited]
 

Returns the name of the stream, if it has one.

Definition at line 70 of file OgreDataStream.h.

References Ogre::String.

uchar* Ogre::MemoryDataStream::getPtr void   ) 
 

Get a pointer to the start of the memory block this stream holds.

Definition at line 263 of file OgreDataStream.h.

References Ogre::uchar.

template<typename T>
DataStream& Ogre::DataStream::operator>> T &  val  )  [inherited]
 

size_t Ogre::MemoryDataStream::read void *  buf,
size_t  count
[virtual]
 

Parameters:
buf Reference to a buffer pointer
count Number of bytes to read
Returns:
The number of bytes read

Implements Ogre::DataStream.

size_t Ogre::MemoryDataStream::readLine char *  buf,
size_t  maxCount,
const String delim = "\n"
[virtual]
 

Remarks:
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.
Parameters:
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
Returns:
The number of bytes read, excluding the terminating character

Implements Ogre::DataStream.

void Ogre::MemoryDataStream::seek size_t  pos  )  [virtual]
 

Implements Ogre::DataStream.

void Ogre::MemoryDataStream::setFreeOnClose bool  free  ) 
 

Sets whether or not to free the encapsulated memory on close.

Definition at line 300 of file OgreDataStream.h.

size_t Ogre::DataStream::size void   )  const [inherited]
 

Returns the total size of the data to be read from the stream, or 0 if this is indeterminate for this stream.

Definition at line 138 of file OgreDataStream.h.

void Ogre::MemoryDataStream::skip long  count  )  [virtual]
 

This can also be a negative value, in which case the file pointer rewinds a defined number of bytes.

Implements Ogre::DataStream.

size_t Ogre::MemoryDataStream::skipLine const String delim = "\n"  )  [virtual]
 

Parameters:
delim The delimiter(s) to stop at
Returns:
The number of bytes skipped

Implements Ogre::DataStream.

size_t Ogre::MemoryDataStream::tell void   )  const [virtual]
 

Implements Ogre::DataStream.


Member Data Documentation

uchar* Ogre::MemoryDataStream::mData [protected]
 

Pointer to the start of the data area.

Definition at line 162 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::mEnd [protected]
 

Pointer to the end of the memory.

Definition at line 166 of file OgreDataStream.h.

bool Ogre::MemoryDataStream::mFreeOnClose [protected]
 

Do we delete the memory on close.

Definition at line 168 of file OgreDataStream.h.

String Ogre::DataStream::mName [protected, inherited]
 

The name (e.g. resource name) that can be used to identify the source fot his data (optional).

Definition at line 58 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::mPos [protected]
 

Pointer to the current position in the memory.

Definition at line 164 of file OgreDataStream.h.

size_t Ogre::DataStream::mSize [protected, inherited]
 

Size of the data in the stream (may be 0 if size cannot be determined).

Definition at line 60 of file OgreDataStream.h.

char Ogre::DataStream::mTmpArea[OGRE_STREAM_TEMP_SIZE] [protected, inherited]
 

Temporary buffer area used for formatted read.

Definition at line 63 of file OgreDataStream.h.


The documentation for this class was generated from the following file:

Copyright © 2000-2005 by The OGRE Team
Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 2.5 License.
Last modified Sun Feb 12 13:00:18 2006