mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-02-28 15:09:40 +00:00
Merge branch 'seekable-membuf' into 'master'
Make in-memory buffers seekable to fix fog of war See merge request OpenMW/openmw!129
This commit is contained in:
commit
4d5debafdf
1 changed files with 23 additions and 3 deletions
|
@ -9,11 +9,31 @@ namespace Files
|
|||
struct MemBuf : std::streambuf
|
||||
{
|
||||
MemBuf(char const* buffer, size_t size)
|
||||
{
|
||||
// a streambuf isn't specific to istreams, so we need a non-const pointer :/
|
||||
char* nonconstBuffer = (const_cast<char*>(buffer));
|
||||
this->setg(nonconstBuffer, nonconstBuffer, nonconstBuffer + size);
|
||||
: bufferStart(const_cast<char*>(buffer))
|
||||
, bufferEnd(bufferStart + size)
|
||||
{
|
||||
this->setg(bufferStart, bufferStart, bufferEnd);
|
||||
}
|
||||
|
||||
pos_type seekoff(off_type off, std::ios_base::seekdir dir, std::ios_base::openmode which) override
|
||||
{
|
||||
if (dir == std::ios_base::cur)
|
||||
gbump(off);
|
||||
else
|
||||
setg(bufferStart, (dir == std::ios_base::beg ? bufferStart : bufferEnd) + off, bufferEnd);
|
||||
|
||||
return gptr() - bufferStart;
|
||||
}
|
||||
|
||||
pos_type seekpos(pos_type pos, std::ios_base::openmode which) override
|
||||
{
|
||||
return seekoff(pos, std::ios_base::beg, which);
|
||||
}
|
||||
|
||||
protected:
|
||||
char* bufferStart;
|
||||
char* bufferEnd;
|
||||
};
|
||||
|
||||
/// @brief A variant of std::istream that reads from a constant in-memory buffer.
|
||||
|
|
Loading…
Reference in a new issue