OGRE  2.0
Object-Oriented Graphics Rendering Engine
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups 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:
+ Collaboration diagram for Ogre::MemoryDataStream:

Public Types

enum  AccessMode { READ = 1, WRITE = 2 }
 

Public Member Functions

 MemoryDataStream (void *pMem, size_t size, bool freeOnClose=false, bool readOnly=false)
 Wrap an existing memory chunk in a stream. More...
 
 MemoryDataStream (const String &name, void *pMem, size_t size, bool freeOnClose=false, bool readOnly=false)
 Wrap an existing memory chunk in a named stream. More...
 
 MemoryDataStream (DataStream &sourceStream, bool freeOnClose=true, bool readOnly=false)
 Create a stream which pre-buffers the contents of another stream. More...
 
 MemoryDataStream (DataStreamPtr &sourceStream, bool freeOnClose=true, bool readOnly=false)
 Create a stream which pre-buffers the contents of another stream. More...
 
 MemoryDataStream (const String &name, DataStream &sourceStream, bool freeOnClose=true, bool readOnly=false)
 Create a named stream which pre-buffers the contents of another stream. More...
 
 MemoryDataStream (const String &name, const DataStreamPtr &sourceStream, bool freeOnClose=true, bool readOnly=false)
 Create a named stream which pre-buffers the contents of another stream. More...
 
 MemoryDataStream (size_t size, bool freeOnClose=true, bool readOnly=false)
 Create a stream with a brand new empty memory chunk. More...
 
 MemoryDataStream (const String &name, size_t size, bool freeOnClose=true, bool readOnly=false)
 Create a named stream with a brand new empty memory chunk. More...
 
 ~MemoryDataStream ()
 
void close (void)
 Close the stream; this makes further operations invalid. More...
 
bool eof (void) const
 Returns true if the stream has reached the end. More...
 
uint16 getAccessMode () const
 Gets the access mode of the stream. More...
 
virtual String getAsString (void)
 Returns a String containing the entire stream. More...
 
uchargetCurrentPtr (void)
 Get a pointer to the current position in the memory block this stream holds. More...
 
virtual String getLine (bool trimAfter=true)
 Returns a String containing the next line of data, optionally trimmed for whitespace. More...
 
const StringgetName (void)
 Returns the name of the stream, if it has one. More...
 
uchargetPtr (void)
 Get a pointer to the start of the memory block this stream holds. More...
 
virtual bool isReadable () const
 Reports whether this stream is readable. More...
 
virtual bool isWriteable () const
 Reports whether this stream is writeable. More...
 
void operator delete (void *ptr)
 
void operator delete (void *ptr, void *)
 
void operator delete (void *ptr, const char *, int, const char *)
 
void operator delete[] (void *ptr)
 
void operator delete[] (void *ptr, const char *, int, const char *)
 
void * operator new (size_t sz, const char *file, int line, const char *func)
 operator new, with debug line info More...
 
void * operator new (size_t sz)
 
void * operator new (size_t sz, void *ptr)
 placement operator new More...
 
void * operator new[] (size_t sz, const char *file, int line, const char *func)
 array operator new, with debug line info More...
 
void * operator new[] (size_t sz)
 
template<typename T >
DataStreamoperator>> (T &val)
 
size_t read (void *buf, size_t count)
 Read the requisite number of bytes from the stream, stopping at the end of the file. More...
 
size_t readLine (char *buf, size_t maxCount, const String &delim="\n")
 Get a single line from the stream. More...
 
void seek (size_t pos)
 Repositions the read point to a specified byte. More...
 
void setFreeOnClose (bool free)
 Sets whether or not to free the encapsulated memory on close. More...
 
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. More...
 
void skip (long count)
 Skip a defined number of bytes. More...
 
size_t skipLine (const String &delim="\n")
 Skip a single line from the stream. More...
 
size_t tell (void) const
 Returns the current byte offset from beginning. More...
 
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) More...
 

Protected Attributes

uint16 mAccess
 What type of access is allowed (AccessMode) More...
 
ucharmData
 Pointer to the start of the data area. More...
 
ucharmEnd
 Pointer to the end of the memory. More...
 
bool mFreeOnClose
 Do we delete the memory on close. More...
 
String mName
 The name (e.g. resource name) that can be used to identify the source for this data (optional) More...
 
ucharmPos
 Pointer to the current position in the memory. More...
 
size_t mSize
 Size of the data in the stream (may be 0 if size cannot be determined) More...
 

Detailed Description

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

Definition at line 314 of file OgreDataStream.h.

Member Enumeration Documentation

Enumerator
READ 
WRITE 

Definition at line 181 of file OgreDataStream.h.

Constructor & Destructor Documentation

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

Wrap an existing memory chunk in a stream.

Parameters
pMemPointer to the existing memory
sizeThe size of the memory chunk in bytes
freeOnCloseIf true, the memory associated will be destroyed when the stream is closed. Note: it's important that if you set this option to true, that you allocated the memory using OGRE_ALLOC_T with a category of MEMCATEGORY_GENERAL to ensure the freeing of memory matches up.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( const String name,
void *  pMem,
size_t  size,
bool  freeOnClose = false,
bool  readOnly = false 
)

Wrap an existing memory chunk in a named stream.

Parameters
nameThe name to give the stream
pMemPointer to the existing memory
sizeThe size of the memory chunk in bytes
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed. Note: it's important that if you set this option to true, that you allocated the memory using OGRE_ALLOC_T with a category of MEMCATEGORY_GENERAL ensure the freeing of memory matches up.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( DataStream sourceStream,
bool  freeOnClose = true,
bool  readOnly = false 
)

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
sourceStreamAnother DataStream which will provide the source of data
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( DataStreamPtr sourceStream,
bool  freeOnClose = true,
bool  readOnly = false 
)

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
sourceStreamAnother DataStream which will provide the source of data
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( const String name,
DataStream sourceStream,
bool  freeOnClose = true,
bool  readOnly = false 
)

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
nameThe name to give the stream
sourceStreamAnother DataStream which will provide the source of data
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( const String name,
const DataStreamPtr sourceStream,
bool  freeOnClose = true,
bool  readOnly = false 
)

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
nameThe name to give the stream
sourceStreamAnother DataStream which will provide the source of data
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( size_t  size,
bool  freeOnClose = true,
bool  readOnly = false 
)

Create a stream with a brand new empty memory chunk.

Parameters
sizeThe size of the memory chunk to create in bytes
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::MemoryDataStream ( const String name,
size_t  size,
bool  freeOnClose = true,
bool  readOnly = false 
)

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

Parameters
nameThe name to give the stream
sizeThe size of the memory chunk to create in bytes
freeOnCloseIf true, the memory associated will be destroyed when the stream is destroyed.
readOnlyWhether to make the stream on this memory read-only once created
Ogre::MemoryDataStream::~MemoryDataStream ( )

Member Function Documentation

void Ogre::MemoryDataStream::close ( void  )
virtual

Close the stream; this makes further operations invalid.

Implements Ogre::DataStream.

bool Ogre::MemoryDataStream::eof ( void  ) const
virtual

Returns true if the stream has reached the end.

Implements Ogre::DataStream.

uint16 Ogre::DataStream::getAccessMode ( ) const
inlineinherited

Gets the access mode of the stream.

Definition at line 204 of file OgreDataStream.h.

virtual String Ogre::DataStream::getAsString ( void  )
virtualinherited

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  )
inline

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

Definition at line 436 of file OgreDataStream.h.

virtual String Ogre::DataStream::getLine ( bool  trimAfter = true)
virtualinherited

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.
Note
If you used this function, you must open the stream in binary mode, otherwise, it'll produce unexpected results.
Parameters
trimAfterIf true, the line is trimmed for whitespace (as in String.trim(true,true))
const String& Ogre::DataStream::getName ( void  )
inlineinherited

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

Definition at line 202 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::getPtr ( void  )
inline

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

Definition at line 433 of file OgreDataStream.h.

virtual bool Ogre::DataStream::isReadable ( ) const
inlinevirtualinherited

Reports whether this stream is readable.

Definition at line 206 of file OgreDataStream.h.

virtual bool Ogre::DataStream::isWriteable ( ) const
inlinevirtualinherited

Reports whether this stream is writeable.

Definition at line 208 of file OgreDataStream.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr)
inlineinherited

Definition at line 96 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
void *   
)
inlineinherited

Definition at line 102 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
const char *  ,
int  ,
const char *   
)
inlineinherited

Definition at line 108 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr)
inlineinherited

Definition at line 113 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr,
const char *  ,
int  ,
const char *   
)
inlineinherited

Definition at line 119 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
const char *  file,
int  line,
const char *  func 
)
inlineinherited

operator new, with debug line info

Definition at line 68 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz)
inlineinherited

Definition at line 73 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
void *  ptr 
)
inlineinherited

placement operator new

Definition at line 79 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz,
const char *  file,
int  line,
const char *  func 
)
inlineinherited

array operator new, with debug line info

Definition at line 86 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz)
inlineinherited

Definition at line 91 of file OgreMemoryAllocatedObject.h.

template<typename T >
DataStream& Ogre::DataStream::operator>> ( T &  val)
inherited
size_t Ogre::MemoryDataStream::read ( void *  buf,
size_t  count 
)
virtual

Read the requisite number of bytes from the stream, stopping at the end of the file.

Parameters
bufReference to a buffer pointer
countNumber 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

Get a single line from the stream.

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.
Note
If you used this function, you must open the stream in binary mode, otherwise, it'll produce unexpected results.
Parameters
bufReference to a buffer pointer
maxCountThe maximum length of data to be read, excluding the terminating character
delimThe delimiter to stop at
Returns
The number of bytes read, excluding the terminating character

Reimplemented from Ogre::DataStream.

void Ogre::MemoryDataStream::seek ( size_t  pos)
virtual

Repositions the read point to a specified byte.

Implements Ogre::DataStream.

void Ogre::MemoryDataStream::setFreeOnClose ( bool  free)
inline

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

Definition at line 475 of file OgreDataStream.h.

size_t Ogre::DataStream::size ( void  ) const
inlineinherited

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 299 of file OgreDataStream.h.

void Ogre::MemoryDataStream::skip ( long  count)
virtual

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.

Implements Ogre::DataStream.

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

Skip a single line from the stream.

Note
If you used this function, you must open the stream in binary mode, otherwise, it'll produce unexpected results.
Parameters
delimThe delimiter(s) to stop at
Returns
The number of bytes skipped

Reimplemented from Ogre::DataStream.

size_t Ogre::MemoryDataStream::tell ( void  ) const
virtual

Returns the current byte offset from beginning.

Implements Ogre::DataStream.

size_t Ogre::MemoryDataStream::write ( const void *  buf,
size_t  count 
)
virtual

Write the requisite number of bytes from the stream (only applicable to streams that are not read-only)

Parameters
bufPointer to a buffer containing the bytes to write
countNumber of bytes to write
Returns
The number of bytes written

Reimplemented from Ogre::DataStream.

Member Data Documentation

uint16 Ogre::DataStream::mAccess
protectedinherited

What type of access is allowed (AccessMode)

Definition at line 192 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::mData
protected

Pointer to the start of the data area.

Definition at line 318 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::mEnd
protected

Pointer to the end of the memory.

Definition at line 322 of file OgreDataStream.h.

bool Ogre::MemoryDataStream::mFreeOnClose
protected

Do we delete the memory on close.

Definition at line 324 of file OgreDataStream.h.

String Ogre::DataStream::mName
protectedinherited

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

Definition at line 188 of file OgreDataStream.h.

uchar* Ogre::MemoryDataStream::mPos
protected

Pointer to the current position in the memory.

Definition at line 320 of file OgreDataStream.h.

size_t Ogre::DataStream::mSize
protectedinherited

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

Definition at line 190 of file OgreDataStream.h.


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