Stream which compresses / uncompresses data using the 'deflate' compression algorithm. More...
#include <OgreDeflate.h>

| Public Types | |
| enum | AccessMode { READ = 1, WRITE = 2 } | 
| Public Member Functions | |
| DeflateStream (const DataStreamPtr &compressedStream, const String &tmpFileName="") | |
| Constructor for creating unnamed stream wrapping another stream. | |
| DeflateStream (const String &name, const DataStreamPtr &compressedStream, const String &tmpFileName="") | |
| Constructor for creating named stream wrapping another stream. | |
| ~DeflateStream () | |
| bool | isCompressedStreamValid () const | 
| Returns whether the compressed stream is valid deflated data. | |
| size_t | read (void *buf, size_t count) | 
| size_t | write (const void *buf, size_t count) | 
| void | skip (long count) | 
| void | seek (size_t pos) | 
| size_t | tell (void) const | 
| bool | eof (void) const | 
| void | close (void) | 
| const String & | getName (void) | 
| Returns the name of the stream, if it has one. | |
| uint16 | getAccessMode () const | 
| Gets the access mode of the stream. | |
| 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 | readLine (char *buf, size_t maxCount, const String &delim="\n") | 
| Get a single line from the stream. | |
| 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. | |
| virtual size_t | skipLine (const String &delim="\n") | 
| Skip a single line from the 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. | |
| void * | operator new (size_t sz, const char *file, int line, const char *func) | 
| operator new, with debug line info | |
| void * | operator new (size_t sz) | 
| void * | operator new (size_t sz, void *ptr) | 
| placement operator new | |
| void * | operator new[] (size_t sz, const char *file, int line, const char *func) | 
| array operator new, with debug line info | |
| void * | operator new[] (size_t sz) | 
| 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 *) | 
| Protected Member Functions | |
| void | init () | 
| void | destroy () | 
| void | compressFinal () | 
| Protected Attributes | |
| DataStreamPtr | mCompressedStream | 
| DataStreamPtr | mTmpWriteStream | 
| String | mTempFileName | 
| z_stream * | mZStream | 
| size_t | mCurrentPos | 
| StaticCache < 16 *OGRE_STREAM_TEMP_SIZE > | mReadCache | 
| Cache for read data in case skipping around. | |
| unsigned char * | mTmp | 
| Intermediate buffer for read / write. | |
| bool | mIsCompressedValid | 
| Whether the underlying stream is valid compressed data. | |
| 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) | |
| uint16 | mAccess | 
| What type of access is allowed (AccessMode) | |
Stream which compresses / uncompresses data using the 'deflate' compression algorithm.
Definition at line 55 of file OgreDeflate.h.
| enum Ogre::DataStream::AccessMode  [inherited] | 
Definition at line 178 of file OgreDataStream.h.
| Ogre::DeflateStream::DeflateStream | ( | const DataStreamPtr & | compressedStream, | 
| const String & | tmpFileName = "" | ||
| ) | 
Constructor for creating unnamed stream wrapping another stream.
| compressedStream | The stream that this stream will use when reading / writing compressed data. The access mode from this stream will be matched. | 
| tmpFileName | Path/Filename to be used for temporary storage of incoming data | 
| Ogre::DeflateStream::DeflateStream | ( | const String & | name, | 
| const DataStreamPtr & | compressedStream, | ||
| const String & | tmpFileName = "" | ||
| ) | 
Constructor for creating named stream wrapping another stream.
| name | The name to give this stream | 
| compressedStream | The stream that this stream will use when reading / writing compressed data. The access mode from this stream will be matched. | 
| tmpFileName | Path/Filename to be used for temporary storage of incoming data | 
| void Ogre::DeflateStream::close | ( | void | ) |  [virtual] | 
Close the stream; this makes further operations invalid.
Implements Ogre::DataStream.
| void Ogre::DeflateStream::compressFinal | ( | ) |  [protected] | 
| void Ogre::DeflateStream::destroy | ( | ) |  [protected] | 
| bool Ogre::DeflateStream::eof | ( | void | ) | const  [virtual] | 
Returns true if the stream has reached the end.
Implements Ogre::DataStream.
| uint16 Ogre::DataStream::getAccessMode | ( | ) | const  [inherited] | 
Gets the access mode of the stream.
Definition at line 201 of file OgreDataStream.h.
| virtual String Ogre::DataStream::getAsString | ( | void | ) |  [virtual, inherited] | 
Returns a String containing the entire stream.
| virtual String Ogre::DataStream::getLine | ( | bool | trimAfter = true | ) |  [virtual, inherited] | 
Returns a String containing the next line of data, optionally trimmed for whitespace.
| 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 199 of file OgreDataStream.h.
| void Ogre::DeflateStream::init | ( | ) |  [protected] | 
| bool Ogre::DeflateStream::isCompressedStreamValid | ( | ) | const | 
Returns whether the compressed stream is valid deflated data.
Definition at line 100 of file OgreDeflate.h.
| virtual bool Ogre::DataStream::isReadable | ( | ) | const  [virtual, inherited] | 
Reports whether this stream is readable.
Definition at line 203 of file OgreDataStream.h.
| virtual bool Ogre::DataStream::isWriteable | ( | ) | const  [virtual, inherited] | 
Reports whether this stream is writeable.
Definition at line 205 of file OgreDataStream.h.
| void Ogre::AllocatedObject< Alloc >::operator delete | ( | void * | ptr | ) |  [inherited] | 
Definition at line 95 of file OgreMemoryAllocatedObject.h.
| void Ogre::AllocatedObject< Alloc >::operator delete | ( | void * | ptr, | 
| void * | |||
| ) |  [inherited] | 
Definition at line 101 of file OgreMemoryAllocatedObject.h.
| void Ogre::AllocatedObject< Alloc >::operator delete | ( | void * | ptr, | 
| const char * | , | ||
| int | , | ||
| const char * | |||
| ) |  [inherited] | 
Definition at line 107 of file OgreMemoryAllocatedObject.h.
| void Ogre::AllocatedObject< Alloc >::operator delete[] | ( | void * | ptr | ) |  [inherited] | 
Definition at line 112 of file OgreMemoryAllocatedObject.h.
| void Ogre::AllocatedObject< Alloc >::operator delete[] | ( | void * | ptr, | 
| const char * | , | ||
| int | , | ||
| const char * | |||
| ) |  [inherited] | 
Definition at line 118 of file OgreMemoryAllocatedObject.h.
| void* Ogre::AllocatedObject< Alloc >::operator new | ( | size_t | sz, | 
| const char * | file, | ||
| int | line, | ||
| const char * | func | ||
| ) |  [inherited] | 
operator new, with debug line info
Definition at line 67 of file OgreMemoryAllocatedObject.h.
| void* Ogre::AllocatedObject< Alloc >::operator new | ( | size_t | sz | ) |  [inherited] | 
Definition at line 72 of file OgreMemoryAllocatedObject.h.
| void* Ogre::AllocatedObject< Alloc >::operator new | ( | size_t | sz, | 
| void * | ptr | ||
| ) |  [inherited] | 
placement operator new
Definition at line 78 of file OgreMemoryAllocatedObject.h.
| void* Ogre::AllocatedObject< Alloc >::operator new[] | ( | size_t | sz, | 
| const char * | file, | ||
| int | line, | ||
| const char * | func | ||
| ) |  [inherited] | 
array operator new, with debug line info
Definition at line 85 of file OgreMemoryAllocatedObject.h.
| void* Ogre::AllocatedObject< Alloc >::operator new[] | ( | size_t | sz | ) |  [inherited] | 
Definition at line 90 of file OgreMemoryAllocatedObject.h.
| DataStream& Ogre::DataStream::operator>> | ( | T & | val | ) |  [inherited] | 
| size_t Ogre::DeflateStream::read | ( | void * | buf, | 
| size_t | count | ||
| ) |  [virtual] | 
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 | 
Implements Ogre::DataStream.
| virtual size_t Ogre::DataStream::readLine | ( | char * | buf, | 
| size_t | maxCount, | ||
| const String & | delim = "\n" | ||
| ) |  [virtual, inherited] | 
Get a single line from the stream.
| 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::FileStreamDataStream, and Ogre::MemoryDataStream.
| void Ogre::DeflateStream::seek | ( | size_t | pos | ) |  [virtual] | 
Repositions the read point to a specified byte.
Implements Ogre::DataStream.
| 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 296 of file OgreDataStream.h.
| void Ogre::DeflateStream::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.
| virtual size_t Ogre::DataStream::skipLine | ( | const String & | delim = "\n" | ) |  [virtual, inherited] | 
Skip a single line from the stream.
| delim | The delimiter(s) to stop at | 
Reimplemented in Ogre::MemoryDataStream.
| size_t Ogre::DeflateStream::tell | ( | void | ) | const  [virtual] | 
Returns the current byte offset from beginning.
Implements Ogre::DataStream.
| size_t Ogre::DeflateStream::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)
| buf | Pointer to a buffer containing the bytes to write | 
| count | Number of bytes to write | 
Reimplemented from Ogre::DataStream.
| uint16 Ogre::DataStream::mAccess  [protected, inherited] | 
What type of access is allowed (AccessMode)
Definition at line 189 of file OgreDataStream.h.
| DataStreamPtr Ogre::DeflateStream::mCompressedStream  [protected] | 
Definition at line 58 of file OgreDeflate.h.
| size_t Ogre::DeflateStream::mCurrentPos  [protected] | 
Definition at line 62 of file OgreDeflate.h.
| bool Ogre::DeflateStream::mIsCompressedValid  [protected] | 
Whether the underlying stream is valid compressed data.
Definition at line 71 of file OgreDeflate.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 185 of file OgreDataStream.h.
| StaticCache<16 * OGRE_STREAM_TEMP_SIZE> Ogre::DeflateStream::mReadCache  [protected] | 
Cache for read data in case skipping around.
Definition at line 65 of file OgreDeflate.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 187 of file OgreDataStream.h.
| String Ogre::DeflateStream::mTempFileName  [protected] | 
Definition at line 60 of file OgreDeflate.h.
| unsigned char* Ogre::DeflateStream::mTmp  [protected] | 
Intermediate buffer for read / write.
Definition at line 68 of file OgreDeflate.h.
| DataStreamPtr Ogre::DeflateStream::mTmpWriteStream  [protected] | 
Definition at line 59 of file OgreDeflate.h.
| z_stream* Ogre::DeflateStream::mZStream  [protected] | 
Definition at line 61 of file OgreDeflate.h.
Copyright © 2012 Torus Knot Software Ltd

This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.
		
Last modified Fri May 25 2012 21:48:55