try to get the path for the stream

This commit is contained in:
John Cupitt 2020-12-28 18:26:02 +00:00
parent aa6046d728
commit f368c0add9
2 changed files with 66 additions and 12 deletions

View File

@ -330,6 +330,9 @@ typedef struct _VipsSourceGInputStream {
*/ */
GInputStream *stream; GInputStream *stream;
GSeekable *seekable;
GFileInfo *info;
} VipsSourceGInputStream; } VipsSourceGInputStream;
typedef struct _VipsSourceGInputStreamClass { typedef struct _VipsSourceGInputStreamClass {

View File

@ -32,8 +32,8 @@
*/ */
/* /*
#define VIPS_DEBUG
*/ */
#define VIPS_DEBUG
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include <config.h> #include <config.h>
@ -64,8 +64,59 @@ G_DEFINE_TYPE( VipsSourceGInputStream, vips_source_g_input_stream,
/* TODO: /* TODO:
* - can get get a fileno out? it'd be useful if we could make * - can get get a fileno out? it'd be useful if we could make
* vips_source_map() work for eg. vips or ppm images * vips_source_map() work for eg. vips or ppm images
* - can we set the filename? it would let eg. openslide work
*/ */
static int
vips_source_g_input_stream_build( VipsObject *object )
{
VipsSource *source = VIPS_SOURCE( object );
VipsSourceGInputStream *source_ginput =
VIPS_SOURCE_G_INPUT_STREAM( source );
GError *error = NULL;
VIPS_DEBUG_MSG( "vips_source_g_input_stream_build: %p\n", source );
if( VIPS_OBJECT_CLASS( vips_source_g_input_stream_parent_class )->
build( object ) )
return( -1 );
if( G_IS_FILE_INPUT_STREAM( source_ginput->stream ) ) {
if( !(source_ginput->info = g_file_input_stream_query_info(
G_FILE_INPUT_STREAM( source_ginput->stream ),
G_FILE_ATTRIBUTE_STANDARD_NAME, NULL, &error )) ) {
vips_g_error( &error );
return( -1 );
}
#ifdef VIPS_DEBUG
{
char **attributes;
int i;
attributes = g_file_info_list_attributes(
source_ginput->info, NULL );
printf( "stream attributes:\n" );
for( i = 0; attributes[i]; i++ )
printf( "\t%s\n", attributes[i] );
}
#endif /*VIPS_DEBUG*/
printf( "setting filename: %s\n",
g_file_info_get_name( source_ginput->info ) );
g_object_set( object,
"filename", g_file_info_get_name( source_ginput->info ),
NULL );
}
if( G_IS_SEEKABLE( source_ginput->stream ) &&
g_seekable_can_seek( G_SEEKABLE( source_ginput->stream ) ) )
source_ginput->seekable = G_SEEKABLE( source_ginput->stream );
return( 0 );
}
static gint64 static gint64
vips_source_g_input_stream_read( VipsSource *source, vips_source_g_input_stream_read( VipsSource *source,
void *buffer, size_t length ) void *buffer, size_t length )
@ -115,24 +166,22 @@ vips_source_g_input_stream_seek( VipsSource *source, gint64 offset, int whence )
GSeekType type = lseek_to_seek_type( whence ); GSeekType type = lseek_to_seek_type( whence );
GError *error = NULL; GError *error = NULL;
GSeekable *seekable;
gint64 new_position; gint64 new_position;
VIPS_DEBUG_MSG( "vips_source_g_input_stream_seek: " VIPS_DEBUG_MSG( "vips_source_g_input_stream_seek: "
"offset = %zd, whence = %d\n", offset, whence ); "offset = %zd, whence = %d\n", offset, whence );
if( !G_IS_SEEKABLE( source_ginput->stream ) ) if( source_ginput->seekable ) {
return( -1 ); if( !g_seekable_seek( source_ginput->seekable,
seekable = G_SEEKABLE( source_ginput->stream ); offset, type, NULL, &error ) ) {
if( !g_seekable_can_seek( seekable ) ) vips_g_error( &error );
return( -1 ); return( -1 );
}
if( !g_seekable_seek( seekable, offset, type, NULL, &error ) ) { new_position = g_seekable_tell( source_ginput->seekable );
vips_g_error( &error );
return( -1 );
} }
else
new_position = g_seekable_tell( seekable ); new_position = -1;
VIPS_DEBUG_MSG( " (new position = %zd)\n", new_position ); VIPS_DEBUG_MSG( " (new position = %zd)\n", new_position );
@ -152,6 +201,8 @@ vips_source_g_input_stream_class_init( VipsSourceGInputStreamClass *class )
object_class->nickname = "source_g_input_stream"; object_class->nickname = "source_g_input_stream";
object_class->description = _( "GInputStream source" ); object_class->description = _( "GInputStream source" );
object_class->build = vips_source_g_input_stream_build;
source_class->read = vips_source_g_input_stream_read; source_class->read = vips_source_g_input_stream_read;
source_class->seek = vips_source_g_input_stream_seek; source_class->seek = vips_source_g_input_stream_seek;