[Scummvm-cvs-logs] SF.net SVN: scummvm: [25754] scummvm/trunk/common
fingolfin at users.sourceforge.net
fingolfin at users.sourceforge.net
Tue Feb 20 22:41:02 CET 2007
Revision: 25754
http://scummvm.svn.sourceforge.net/scummvm/?rev=25754&view=rev
Author: fingolfin
Date: 2007-02-20 13:41:01 -0800 (Tue, 20 Feb 2007)
Log Message:
-----------
Added new ReadStream::readStream method which can be used to read a portion of an arbitrary ReadStream into a memory buffer wrapped by a MemoryReadStream
Modified Paths:
--------------
scummvm/trunk/common/stream.cpp
scummvm/trunk/common/stream.h
Modified: scummvm/trunk/common/stream.cpp
===================================================================
--- scummvm/trunk/common/stream.cpp 2007-02-20 19:23:07 UTC (rev 25753)
+++ scummvm/trunk/common/stream.cpp 2007-02-20 21:41:01 UTC (rev 25754)
@@ -31,14 +31,41 @@
write(str.c_str(), str.size());
}
+MemoryReadStream *ReadStream::readStream(uint32 dataSize) {
+ void *buf = malloc(dataSize);
+ dataSize = read(buf, dataSize);
+ assert(dataSize > 0);
+ return new MemoryReadStream((byte *)buf, dataSize, true);
+}
+
+
+uint32 MemoryReadStream::read(void *dataPtr, uint32 dataSize) {
+ // Read at most as many bytes as are still available...
+ if (dataSize > _size - _pos)
+ dataSize = _size - _pos;
+ memcpy(dataPtr, _ptr, dataSize);
+
+ if (_encbyte) {
+ byte *p = (byte *)dataPtr;
+ byte *end = p + dataSize;
+ while (p < end)
+ *p++ ^= _encbyte;
+ }
+
+ _ptr += dataSize;
+ _pos += dataSize;
+
+ return dataSize;
+}
+
void MemoryReadStream::seek(int32 offs, int whence) {
// Pre-Condition
- assert(_pos <= _bufSize);
+ assert(_pos <= _size);
switch (whence) {
case SEEK_END:
// SEEK_END works just like SEEK_SET, only 'reversed',
// i.e. from the end.
- offs = _bufSize - offs;
+ offs = _size - offs;
// Fall through
case SEEK_SET:
_ptr = _ptrOrig + offs;
@@ -51,7 +78,7 @@
break;
}
// Post-Condition
- assert(_pos <= _bufSize);
+ assert(_pos <= _size);
}
#define LF 0x0A
Modified: scummvm/trunk/common/stream.h
===================================================================
--- scummvm/trunk/common/stream.h 2007-02-20 19:23:07 UTC (rev 25753)
+++ scummvm/trunk/common/stream.h 2007-02-20 21:41:01 UTC (rev 25754)
@@ -29,6 +29,7 @@
namespace Common {
class String;
+class MemoryReadStream;
/**
* Virtual base class for both ReadStream and WriteStream.
@@ -201,6 +202,13 @@
int32 readSint32BE() {
return (int32)readUint32BE();
}
+
+ /**
+ * Read the specified amount of data into a malloc'ed buffer
+ * which then is wrapped into a MemoryReadStream.
+ */
+ MemoryReadStream *readStream(uint32 dataSize);
+
};
@@ -284,51 +292,40 @@
*/
class MemoryReadStream : public SeekableReadStream {
private:
- const byte *_ptr;
const byte * const _ptrOrig;
- const uint32 _bufSize;
+ const byte *_ptr;
+ const uint32 _size;
uint32 _pos;
byte _encbyte;
bool _disposeMemory;
public:
- MemoryReadStream(const byte *buf, uint32 len, bool disposeMemory = false) :
- _ptr(buf),
- _ptrOrig(buf),
- _bufSize(len),
+
+ /**
+ * This constructor takes a pointer to a memory buffer and a length, and
+ * wraps it. If disposeMemory is true, the MemoryReadStream takes ownership
+ * of the buffer and hence free's it when destructed.
+ */
+ MemoryReadStream(const byte *dataPtr, uint32 dataSize, bool disposeMemory = false) :
+ _ptrOrig(dataPtr),
+ _ptr(dataPtr),
+ _size(dataSize),
_pos(0),
_encbyte(0),
_disposeMemory(disposeMemory) {}
~MemoryReadStream() {
if (_disposeMemory)
- free((void *)_ptrOrig);
+ free(const_cast<byte *>(_ptrOrig));
}
void setEnc(byte value) { _encbyte = value; }
- uint32 read(void *dataPtr, uint32 dataSize) {
- // Read at most as many bytes as are still available...
- if (dataSize > _bufSize - _pos)
- dataSize = _bufSize - _pos;
- memcpy(dataPtr, _ptr, dataSize);
+ uint32 read(void *dataPtr, uint32 dataSize);
- if (_encbyte) {
- byte *p = (byte *)dataPtr;
- byte *end = p + dataSize;
- while (p < end)
- *p++ ^= _encbyte;
- }
-
- _ptr += dataSize;
- _pos += dataSize;
-
- return dataSize;
- }
-
- bool eos() const { return _pos == _bufSize; }
+ bool eos() const { return _pos == _size; }
uint32 pos() const { return _pos; }
- uint32 size() const { return _bufSize; }
+ uint32 size() const { return _size; }
void seek(int32 offs, int whence = SEEK_SET);
};
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
More information about the Scummvm-git-logs
mailing list