mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 12:23:53 +00:00
75 lines
2 KiB
C++
75 lines
2 KiB
C++
#ifndef MANGLE_STREAM_INPUT_H
|
|
#define MANGLE_STREAM_INPUT_H
|
|
|
|
#include <stdlib.h>
|
|
#include "../tools/shared_ptr.h"
|
|
#include <assert.h>
|
|
|
|
namespace Mangle {
|
|
namespace Stream {
|
|
|
|
/// An abstract interface for a stream data.
|
|
class Stream
|
|
{
|
|
public:
|
|
// Feature options. These should be set in the constructor.
|
|
|
|
/// If true, seek() works
|
|
bool isSeekable;
|
|
|
|
/// If true, tell() works
|
|
bool hasPosition;
|
|
|
|
/// If true, size() works
|
|
bool hasSize;
|
|
|
|
/// If true, the getPtr() functions work
|
|
bool hasPtr;
|
|
|
|
/// Initialize all bools to false by default
|
|
Stream() :
|
|
isSeekable(false), hasPosition(false), hasSize(false),
|
|
hasPtr(false) {}
|
|
|
|
/// Virtual destructor
|
|
virtual ~Stream() {}
|
|
|
|
/** Read a given number of bytes from the stream. Returns the actual
|
|
number read. If the return value is less than count, then the
|
|
stream is empty or an error occured.
|
|
*/
|
|
virtual size_t read(void* buf, size_t count) = 0;
|
|
|
|
/// Seek to an absolute position in this stream. Not all streams are
|
|
/// seekable.
|
|
virtual void seek(size_t pos) = 0;
|
|
|
|
/// Get the current position in the stream. Non-seekable streams are
|
|
/// not required to keep track of this.
|
|
virtual size_t tell() const = 0;
|
|
|
|
/// Return the total size of the stream. For streams where this is
|
|
/// not applicable, size() should return zero.
|
|
virtual size_t size() const = 0;
|
|
|
|
/// Returns true if the stream is empty
|
|
virtual bool eof() const = 0;
|
|
|
|
/// Return a pointer to the entire stream. This function (and the
|
|
/// other getPtr() variants below) should only be implemented for
|
|
/// memory-based streams where using them would be an optimization.
|
|
virtual const void *getPtr() { assert(0); }
|
|
|
|
/// Get a pointer to a memory region of 'size' bytes from the
|
|
/// current position.
|
|
virtual const void *getPtr(size_t size) { assert(0); }
|
|
|
|
/// Get a pointer to a memory region of 'size' bytes starting from
|
|
/// position 'pos'
|
|
virtual const void *getPtr(size_t pos, size_t size) { assert(0); }
|
|
};
|
|
|
|
typedef boost::shared_ptr<Stream> StreamPtr;
|
|
|
|
}} // namespaces
|
|
#endif
|