2009-12-19 07:26:01 +00:00
|
|
|
#ifndef MANGLE_STREAM_INPUT_H
|
|
|
|
#define MANGLE_STREAM_INPUT_H
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
2009-12-31 14:37:01 +00:00
|
|
|
#include "../tools/shared_ptr.h"
|
2010-01-01 10:31:09 +00:00
|
|
|
#include <assert.h>
|
2009-12-19 07:26:01 +00:00
|
|
|
|
|
|
|
namespace Mangle {
|
|
|
|
namespace Stream {
|
|
|
|
|
|
|
|
/// An abstract interface for a stream data.
|
2009-12-28 13:09:17 +00:00
|
|
|
class Stream
|
2009-12-19 07:26:01 +00:00
|
|
|
{
|
|
|
|
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;
|
|
|
|
|
2010-01-01 10:31:09 +00:00
|
|
|
/// If true, the getPtr() functions work
|
|
|
|
bool hasPtr;
|
|
|
|
|
|
|
|
/// Initialize all bools to false by default
|
|
|
|
Stream() :
|
|
|
|
isSeekable(false), hasPosition(false), hasSize(false),
|
|
|
|
hasPtr(false) {}
|
|
|
|
|
2009-12-19 07:26:01 +00:00
|
|
|
/// Virtual destructor
|
2009-12-28 13:09:17 +00:00
|
|
|
virtual ~Stream() {}
|
2009-12-19 07:26:01 +00:00
|
|
|
|
|
|
|
/** 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;
|
2010-01-01 10:31:09 +00:00
|
|
|
|
|
|
|
/// 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.
|
2010-03-04 10:12:22 +00:00
|
|
|
virtual const void *getPtr() { assert(0); return NULL; }
|
2010-01-01 10:31:09 +00:00
|
|
|
|
|
|
|
/// Get a pointer to a memory region of 'size' bytes starting from
|
|
|
|
/// position 'pos'
|
2010-03-04 10:12:22 +00:00
|
|
|
virtual const void *getPtr(size_t pos, size_t size) { assert(0); return NULL; }
|
2010-01-04 10:55:38 +00:00
|
|
|
|
|
|
|
/// Get a pointer to a memory region of 'size' bytes from the
|
|
|
|
/// current position. Unlike the two other getPtr variants, this
|
|
|
|
/// will advance the position past the returned area.
|
2010-03-04 10:12:22 +00:00
|
|
|
virtual const void *getPtr(size_t size) { assert(0); return NULL; }
|
2009-12-19 07:26:01 +00:00
|
|
|
};
|
|
|
|
|
2009-12-31 14:37:01 +00:00
|
|
|
typedef boost::shared_ptr<Stream> StreamPtr;
|
|
|
|
|
2009-12-19 07:26:01 +00:00
|
|
|
}} // namespaces
|
|
|
|
#endif
|