Commit a7e80f7c authored by Alexander Alekhin's avatar Alexander Alekhin

Merge pull request #8645 from brian-armstrong-discord:bugfix_inmemory_exif

parents c4d4248e 40dc0bcd
...@@ -70,21 +70,21 @@ protected: ...@@ -70,21 +70,21 @@ protected:
std::ios_base::seekdir dir, std::ios_base::seekdir dir,
std::ios_base::openmode ) std::ios_base::openmode )
{ {
// get absolute offset char* whence = eback();
off_type off = offset;
if (dir == std::ios_base::cur) if (dir == std::ios_base::cur)
{ {
off += gptr() - eback(); whence = gptr();
} }
else if (dir == std::ios_base::end) else if (dir == std::ios_base::end)
{ {
off += egptr() - eback(); whence = egptr();
} }
char* to = whence + offset;
// check limits // check limits
if (off >= (off_type)0 && off <= egptr() - eback()) if (to >= eback() && to <= egptr())
{ {
setg(eback(), gptr() + off, egptr()); setg(eback(), to, egptr());
return gptr() - eback(); return gptr() - eback();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment