Move descriptor test to vips_source_seek_real
Since subclasses could override the seek method without setting the file descriptor.
This commit is contained in:
parent
2eeeedc957
commit
e437805fc1
@ -153,8 +153,7 @@ vips_source_test_features( VipsSource *source )
|
|||||||
* vips_source_seek() etc. or we might trigger seek emulation.
|
* vips_source_seek() etc. or we might trigger seek emulation.
|
||||||
*/
|
*/
|
||||||
if( source->data ||
|
if( source->data ||
|
||||||
(VIPS_CONNECTION( source )->descriptor != -1 &&
|
class->seek( source, 0, SEEK_CUR ) != -1 ) {
|
||||||
class->seek( source, 0, SEEK_CUR ) != -1) ) {
|
|
||||||
gint64 length;
|
gint64 length;
|
||||||
|
|
||||||
VIPS_DEBUG_MSG( " seekable source\n" );
|
VIPS_DEBUG_MSG( " seekable source\n" );
|
||||||
@ -349,16 +348,15 @@ vips_source_seek_real( VipsSource *source, gint64 offset, int whence )
|
|||||||
{
|
{
|
||||||
VipsConnection *connection = VIPS_CONNECTION( source );
|
VipsConnection *connection = VIPS_CONNECTION( source );
|
||||||
|
|
||||||
gint64 new_pos;
|
|
||||||
|
|
||||||
VIPS_DEBUG_MSG( "vips_source_seek_real:\n" );
|
VIPS_DEBUG_MSG( "vips_source_seek_real:\n" );
|
||||||
|
|
||||||
/* Like _read_real(), we must not set a vips_error. We need to use the
|
/* Like _read_real(), we must not set a vips_error. We need to use the
|
||||||
* vips__seek() wrapper so we can seek long files on Windows.
|
* vips__seek() wrapper so we can seek long files on Windows.
|
||||||
*/
|
*/
|
||||||
new_pos = vips__seek_no_error( connection->descriptor, offset, whence );
|
if( connection->descriptor != -1 )
|
||||||
|
return( vips__seek_no_error( connection->descriptor, offset, whence ) );
|
||||||
|
|
||||||
return( new_pos );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user