Specialisation of DataStream to handle streaming data from zip archives. More...
#include <OgreZip.h>

| Public Types | |
| enum | AccessMode { READ = 1, WRITE = 2 } | 
| Public Member Functions | |
| ZipDataStream (ZZIP_FILE *zzipFile, size_t uncompressedSize) | |
| Unnamed constructor. | |
| ZipDataStream (const String &name, ZZIP_FILE *zzipFile, size_t uncompressedSize) | |
| Constructor for creating named streams. | |
| ~ZipDataStream () | |
| size_t | read (void *buf, size_t count) | 
| size_t | write (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 | 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) | |
| 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 Attributes | |
| ZZIP_FILE * | mZzipFile | 
| StaticCache < 2 *OGRE_STREAM_TEMP_SIZE > | mCache | 
| We need caching because sometimes serializers step back in data stream and zziplib behaves slow. | |
| 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) | |
Specialisation of DataStream to handle streaming data from zip archives.
| enum Ogre::DataStream::AccessMode  [inherited] | 
Definition at line 178 of file OgreDataStream.h.
| Ogre::ZipDataStream::ZipDataStream | ( | ZZIP_FILE * | zzipFile, | 
| size_t | uncompressedSize | ||
| ) | 
Unnamed constructor.
| Ogre::ZipDataStream::ZipDataStream | ( | const String & | name, | 
| ZZIP_FILE * | zzipFile, | ||
| size_t | uncompressedSize | ||
| ) | 
Constructor for creating named streams.
| void Ogre::ZipDataStream::close | ( | void | ) |  [virtual] | 
Close the stream; this makes further operations invalid.
Implements Ogre::DataStream.
| bool Ogre::ZipDataStream::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.
| 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::ZipDataStream::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::ZipDataStream::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::ZipDataStream::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::ZipDataStream::tell | ( | void | ) | const  [virtual] | 
Repositions the read point to a specified byte.
Implements Ogre::DataStream.
| size_t Ogre::ZipDataStream::write | ( | void * | buf, | 
| size_t | count | ||
| ) | 
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 | 
| virtual size_t Ogre::DataStream::write | ( | const void * | buf, | 
| size_t | count | ||
| ) |  [virtual, inherited] | 
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::FileHandleDataStream, Ogre::FileStreamDataStream, Ogre::MemoryDataStream, and Ogre::DeflateStream.
Definition at line 222 of file OgreDataStream.h.
| uint16 Ogre::DataStream::mAccess  [protected, inherited] | 
What type of access is allowed (AccessMode)
Definition at line 189 of file OgreDataStream.h.
| StaticCache<2 * OGRE_STREAM_TEMP_SIZE> Ogre::ZipDataStream::mCache  [protected] | 
| 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.
| 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.
| ZZIP_FILE* Ogre::ZipDataStream::mZzipFile  [protected] | 
Copyright © 2012 Torus Knot Software Ltd

This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.
		
Last modified Sun Sep 2 2012 07:27:42