Backported buffered seeking fix from dev branch.
This commit is contained in:
parent
969bf3d341
commit
58fac19bb4
17
physfs.c
17
physfs.c
|
@ -1863,7 +1863,22 @@ int PHYSFS_seek(PHYSFS_file *handle, PHYSFS_uint64 pos)
|
||||||
{
|
{
|
||||||
FileHandle *h = (FileHandle *) handle->opaque;
|
FileHandle *h = (FileHandle *) handle->opaque;
|
||||||
BAIL_IF_MACRO(!PHYSFS_flush(handle), NULL, 0);
|
BAIL_IF_MACRO(!PHYSFS_flush(handle), NULL, 0);
|
||||||
h->buffill = h->bufpos = 0; /* just in case. */
|
|
||||||
|
if (h->buffer && h->forReading)
|
||||||
|
{
|
||||||
|
/* avoid throwing away our precious buffer if seeking within it. */
|
||||||
|
PHYSFS_sint64 offset = pos - PHYSFS_tell(handle);
|
||||||
|
if ( /* seeking within the already-buffered range? */
|
||||||
|
((offset >= 0) && (offset <= h->buffill - h->bufpos)) /* forwards */
|
||||||
|
|| ((offset < 0) && (-offset <= h->bufpos)) /* backwards */ )
|
||||||
|
{
|
||||||
|
h->bufpos += offset;
|
||||||
|
return(1); /* successful seek */
|
||||||
|
} /* if */
|
||||||
|
} /* if */
|
||||||
|
|
||||||
|
/* we have to fall back to a 'raw' seek. */
|
||||||
|
h->buffill = h->bufpos = 0;
|
||||||
return(h->funcs->seek(h, pos));
|
return(h->funcs->seek(h, pos));
|
||||||
} /* PHYSFS_seek */
|
} /* PHYSFS_seek */
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue