Public Member Functions | Protected Attributes | List of all members
Ogre::StaticCache< cacheSize > Class Template Reference

Template version of cache based on static array. More...

#include <OgreDataStream.h>

Public Member Functions

 StaticCache ()
 Constructor. More...
 
size_t avail () const
 Returns number of bytes available for reading in cache after rewinding. More...
 
size_t cacheData (const void *buf, size_t count)
 Cache data pointed by 'buf'. More...
 
void clear ()
 Clear the cache. More...
 
bool ff (size_t count)
 Step forward in cached stream by 'count' bytes. More...
 
size_t read (void *buf, size_t count)
 Read data from cache to 'buf' (maximum 'count' bytes). More...
 
bool rewind (size_t count)
 Step back in cached stream by 'count' bytes. More...
 

Protected Attributes

char mBuffer [cacheSize]
 Static buffer. More...
 
size_t mPos
 Current read position. More...
 
size_t mValidBytes
 Number of bytes valid in cache (written from the beginning of static buffer) More...
 

Detailed Description

template<size_t cacheSize>
class Ogre::StaticCache< cacheSize >

Template version of cache based on static array.

'cacheSize' defines size of cache in bytes.

Definition at line 42 of file OgreDataStream.h.

Constructor & Destructor Documentation

◆ StaticCache()

template<size_t cacheSize>
Ogre::StaticCache< cacheSize >::StaticCache ( )

Constructor.

Definition at line 55 of file OgreDataStream.h.

Member Function Documentation

◆ avail()

template<size_t cacheSize>
size_t Ogre::StaticCache< cacheSize >::avail ( ) const

Returns number of bytes available for reading in cache after rewinding.

Definition at line 136 of file OgreDataStream.h.

Referenced by Ogre::StaticCache< 16 *OGRE_STREAM_TEMP_SIZE >::cacheData(), Ogre::StaticCache< 16 *OGRE_STREAM_TEMP_SIZE >::ff(), and Ogre::StaticCache< 16 *OGRE_STREAM_TEMP_SIZE >::read().

◆ cacheData()

template<size_t cacheSize>
size_t Ogre::StaticCache< cacheSize >::cacheData ( const void *  buf,
size_t  count 
)

Cache data pointed by 'buf'.

If 'count' is greater than cache size, we cache only last bytes. Returns number of bytes written to cache.

Definition at line 63 of file OgreDataStream.h.

◆ clear()

template<size_t cacheSize>
void Ogre::StaticCache< cacheSize >::clear ( void  )

◆ ff()

template<size_t cacheSize>
bool Ogre::StaticCache< cacheSize >::ff ( size_t  count)

Step forward in cached stream by 'count' bytes.

Returns 'true' if cache contains resulting position.

Definition at line 121 of file OgreDataStream.h.

◆ read()

template<size_t cacheSize>
size_t Ogre::StaticCache< cacheSize >::read ( void *  buf,
size_t  count 
)

Read data from cache to 'buf' (maximum 'count' bytes).

Returns number of bytes read from cache.

Definition at line 97 of file OgreDataStream.h.

Referenced by Ogre::MemoryDataStream::getCurrentPtr(), and Ogre::DataStream::~DataStream().

◆ rewind()

template<size_t cacheSize>
bool Ogre::StaticCache< cacheSize >::rewind ( size_t  count)

Step back in cached stream by 'count' bytes.

Returns 'true' if cache contains resulting position.

Definition at line 107 of file OgreDataStream.h.

Member Data Documentation

◆ mBuffer

template<size_t cacheSize>
char Ogre::StaticCache< cacheSize >::mBuffer[cacheSize]
protected

Static buffer.

Definition at line 46 of file OgreDataStream.h.

◆ mPos

template<size_t cacheSize>
size_t Ogre::StaticCache< cacheSize >::mPos
protected

Current read position.

Definition at line 51 of file OgreDataStream.h.

Referenced by Ogre::StaticCache< 16 *OGRE_STREAM_TEMP_SIZE >::avail(), and Ogre::MemoryDataStream::getCurrentPtr().

◆ mValidBytes

template<size_t cacheSize>
size_t Ogre::StaticCache< cacheSize >::mValidBytes
protected

Number of bytes valid in cache (written from the beginning of static buffer)

Definition at line 49 of file OgreDataStream.h.

Referenced by Ogre::StaticCache< 16 *OGRE_STREAM_TEMP_SIZE >::cacheData().


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

Copyright © 2012 Torus Knot Software Ltd
Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.