rework jpegload class
to match the radload pattern
This commit is contained in:
parent
561f410f0a
commit
96079202ef
@ -68,6 +68,10 @@
|
|||||||
typedef struct _VipsForeignLoadJpeg {
|
typedef struct _VipsForeignLoadJpeg {
|
||||||
VipsForeignLoad parent_object;
|
VipsForeignLoad parent_object;
|
||||||
|
|
||||||
|
/* Set by subclasses.
|
||||||
|
*/
|
||||||
|
VipsStreami *streami;
|
||||||
|
|
||||||
/* Shrink by this much during load.
|
/* Shrink by this much during load.
|
||||||
*/
|
*/
|
||||||
int shrink;
|
int shrink;
|
||||||
@ -83,12 +87,15 @@ typedef VipsForeignLoadClass VipsForeignLoadJpegClass;
|
|||||||
G_DEFINE_ABSTRACT_TYPE( VipsForeignLoadJpeg, vips_foreign_load_jpeg,
|
G_DEFINE_ABSTRACT_TYPE( VipsForeignLoadJpeg, vips_foreign_load_jpeg,
|
||||||
VIPS_TYPE_FOREIGN_LOAD );
|
VIPS_TYPE_FOREIGN_LOAD );
|
||||||
|
|
||||||
static VipsForeignFlags
|
static void
|
||||||
vips_foreign_load_jpeg_get_flags( VipsForeignLoad *load )
|
vips_foreign_load_jpeg_dispose( GObject *gobject )
|
||||||
{
|
{
|
||||||
/* The jpeg reader supports sequential read.
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) gobject;
|
||||||
*/
|
|
||||||
return( VIPS_FOREIGN_SEQUENTIAL );
|
VIPS_UNREF( jpeg->streami );
|
||||||
|
|
||||||
|
G_OBJECT_CLASS( vips_foreign_load_jpeg_parent_class )->
|
||||||
|
dispose( gobject );
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -112,6 +119,43 @@ vips_foreign_load_jpeg_build( VipsObject *object )
|
|||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static VipsForeignFlags
|
||||||
|
vips_foreign_load_jpeg_get_flags( VipsForeignLoad *load )
|
||||||
|
{
|
||||||
|
return( VIPS_FOREIGN_SEQUENTIAL );
|
||||||
|
}
|
||||||
|
|
||||||
|
static VipsForeignFlags
|
||||||
|
vips_foreign_load_jpeg_get_flags_filename( const char *filename )
|
||||||
|
{
|
||||||
|
return( VIPS_FOREIGN_SEQUENTIAL );
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
vips_foreign_load_jpeg_header( VipsForeignLoad *load )
|
||||||
|
{
|
||||||
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
||||||
|
|
||||||
|
if( vips__jpeg_read_stream( jpeg->streami,
|
||||||
|
load->out, TRUE, jpeg->shrink, load->fail, jpeg->autorotate ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
vips_foreign_load_jpeg_load( VipsForeignLoad *load )
|
||||||
|
{
|
||||||
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
||||||
|
|
||||||
|
if( vips__jpeg_read_stream( jpeg->streami,
|
||||||
|
load->real, FALSE, jpeg->shrink, load->fail,
|
||||||
|
jpeg->autorotate ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
vips_foreign_load_jpeg_class_init( VipsForeignLoadJpegClass *class )
|
vips_foreign_load_jpeg_class_init( VipsForeignLoadJpegClass *class )
|
||||||
{
|
{
|
||||||
@ -120,6 +164,7 @@ vips_foreign_load_jpeg_class_init( VipsForeignLoadJpegClass *class )
|
|||||||
VipsForeignClass *foreign_class = (VipsForeignClass *) class;
|
VipsForeignClass *foreign_class = (VipsForeignClass *) class;
|
||||||
VipsForeignLoadClass *load_class = (VipsForeignLoadClass *) class;
|
VipsForeignLoadClass *load_class = (VipsForeignLoadClass *) class;
|
||||||
|
|
||||||
|
gobject_class->dispose = vips_foreign_load_jpeg_dispose;
|
||||||
gobject_class->set_property = vips_object_set_property;
|
gobject_class->set_property = vips_object_set_property;
|
||||||
gobject_class->get_property = vips_object_get_property;
|
gobject_class->get_property = vips_object_get_property;
|
||||||
|
|
||||||
@ -131,7 +176,11 @@ vips_foreign_load_jpeg_class_init( VipsForeignLoadJpegClass *class )
|
|||||||
*/
|
*/
|
||||||
foreign_class->priority = 50;
|
foreign_class->priority = 50;
|
||||||
|
|
||||||
|
load_class->get_flags_filename =
|
||||||
|
vips_foreign_load_jpeg_get_flags_filename;
|
||||||
load_class->get_flags = vips_foreign_load_jpeg_get_flags;
|
load_class->get_flags = vips_foreign_load_jpeg_get_flags;
|
||||||
|
load_class->header = vips_foreign_load_jpeg_header;
|
||||||
|
load_class->load = vips_foreign_load_jpeg_load;
|
||||||
|
|
||||||
VIPS_ARG_INT( class, "shrink", 20,
|
VIPS_ARG_INT( class, "shrink", 20,
|
||||||
_( "Shrink" ),
|
_( "Shrink" ),
|
||||||
@ -168,27 +217,19 @@ G_DEFINE_TYPE( VipsForeignLoadJpegStream, vips_foreign_load_jpeg_stream,
|
|||||||
vips_foreign_load_jpeg_get_type() );
|
vips_foreign_load_jpeg_get_type() );
|
||||||
|
|
||||||
static int
|
static int
|
||||||
vips_foreign_load_jpeg_stream_header( VipsForeignLoad *load )
|
vips_foreign_load_jpeg_stream_build( VipsObject *object )
|
||||||
{
|
{
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) object;
|
||||||
VipsForeignLoadJpegStream *stream = (VipsForeignLoadJpegStream *) load;
|
VipsForeignLoadJpegStream *stream =
|
||||||
|
(VipsForeignLoadJpegStream *) object;
|
||||||
|
|
||||||
if( vips__jpeg_read_stream( stream->streami,
|
if( stream->streami ) {
|
||||||
load->out, TRUE, jpeg->shrink, load->fail, jpeg->autorotate ) )
|
jpeg->streami = stream->streami;
|
||||||
return( -1 );
|
g_object_ref( jpeg->streami );
|
||||||
|
}
|
||||||
|
|
||||||
return( 0 );
|
if( VIPS_OBJECT_CLASS( vips_foreign_load_jpeg_stream_parent_class )->
|
||||||
}
|
build( object ) )
|
||||||
|
|
||||||
static int
|
|
||||||
vips_foreign_load_jpeg_stream_load( VipsForeignLoad *load )
|
|
||||||
{
|
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
|
||||||
VipsForeignLoadJpegStream *stream = (VipsForeignLoadJpegStream *) load;
|
|
||||||
|
|
||||||
if( vips__jpeg_read_stream( stream->streami,
|
|
||||||
load->real, FALSE, jpeg->shrink, load->fail,
|
|
||||||
jpeg->autorotate ) )
|
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
@ -213,10 +254,9 @@ vips_foreign_load_jpeg_stream_class_init(
|
|||||||
|
|
||||||
object_class->nickname = "jpegload_stream";
|
object_class->nickname = "jpegload_stream";
|
||||||
object_class->description = _( "load image from jpeg stream" );
|
object_class->description = _( "load image from jpeg stream" );
|
||||||
|
object_class->build = vips_foreign_load_jpeg_stream_build;
|
||||||
|
|
||||||
load_class->is_a_stream = vips_foreign_load_jpeg_stream_is_a_stream;
|
load_class->is_a_stream = vips_foreign_load_jpeg_stream_is_a_stream;
|
||||||
load_class->header = vips_foreign_load_jpeg_stream_header;
|
|
||||||
load_class->load = vips_foreign_load_jpeg_stream_load;
|
|
||||||
|
|
||||||
VIPS_ARG_OBJECT( class, "streami", 1,
|
VIPS_ARG_OBJECT( class, "streami", 1,
|
||||||
_( "Streami" ),
|
_( "Streami" ),
|
||||||
@ -244,6 +284,24 @@ typedef VipsForeignLoadJpegClass VipsForeignLoadJpegFileClass;
|
|||||||
G_DEFINE_TYPE( VipsForeignLoadJpegFile, vips_foreign_load_jpeg_file,
|
G_DEFINE_TYPE( VipsForeignLoadJpegFile, vips_foreign_load_jpeg_file,
|
||||||
vips_foreign_load_jpeg_get_type() );
|
vips_foreign_load_jpeg_get_type() );
|
||||||
|
|
||||||
|
static int
|
||||||
|
vips_foreign_load_jpeg_file_build( VipsObject *object )
|
||||||
|
{
|
||||||
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) object;
|
||||||
|
VipsForeignLoadJpegFile *file = (VipsForeignLoadJpegFile *) object;
|
||||||
|
|
||||||
|
if( file->filename &&
|
||||||
|
!(jpeg->streami =
|
||||||
|
vips_streami_new_from_file( file->filename )) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
if( VIPS_OBJECT_CLASS( vips_foreign_load_jpeg_file_parent_class )->
|
||||||
|
build( object ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
vips_foreign_load_jpeg_file_is_a( const char *filename )
|
vips_foreign_load_jpeg_file_is_a( const char *filename )
|
||||||
{
|
{
|
||||||
@ -252,52 +310,12 @@ vips_foreign_load_jpeg_file_is_a( const char *filename )
|
|||||||
|
|
||||||
if( !(streami = vips_streami_new_from_file( filename )) )
|
if( !(streami = vips_streami_new_from_file( filename )) )
|
||||||
return( FALSE );
|
return( FALSE );
|
||||||
result = vips__isjpeg_stream( streami );
|
result = vips_foreign_load_jpeg_stream_is_a_stream( streami );
|
||||||
VIPS_UNREF( streami );
|
VIPS_UNREF( streami );
|
||||||
|
|
||||||
return( result );
|
return( result );
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
vips_foreign_load_jpeg_file_header( VipsForeignLoad *load )
|
|
||||||
{
|
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
|
||||||
VipsForeignLoadJpegFile *file = (VipsForeignLoadJpegFile *) load;
|
|
||||||
|
|
||||||
VipsStreami *streami;
|
|
||||||
|
|
||||||
if( !(streami = vips_streami_new_from_file( file->filename )) )
|
|
||||||
return( -1 );
|
|
||||||
if( vips__jpeg_read_stream( streami, load->out,
|
|
||||||
TRUE, jpeg->shrink, load->fail, jpeg->autorotate ) ) {
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
return( -1 );
|
|
||||||
}
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
vips_foreign_load_jpeg_file_load( VipsForeignLoad *load )
|
|
||||||
{
|
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
|
||||||
VipsForeignLoadJpegFile *file = (VipsForeignLoadJpegFile *) load;
|
|
||||||
|
|
||||||
VipsStreami *streami;
|
|
||||||
|
|
||||||
if( !(streami = vips_streami_new_from_file( file->filename )) )
|
|
||||||
return( -1 );
|
|
||||||
if( vips__jpeg_read_stream( streami, load->real,
|
|
||||||
FALSE, jpeg->shrink, load->fail, jpeg->autorotate ) ) {
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
return( -1 );
|
|
||||||
}
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
vips_foreign_load_jpeg_file_class_init( VipsForeignLoadJpegFileClass *class )
|
vips_foreign_load_jpeg_file_class_init( VipsForeignLoadJpegFileClass *class )
|
||||||
{
|
{
|
||||||
@ -311,12 +329,11 @@ vips_foreign_load_jpeg_file_class_init( VipsForeignLoadJpegFileClass *class )
|
|||||||
|
|
||||||
object_class->nickname = "jpegload";
|
object_class->nickname = "jpegload";
|
||||||
object_class->description = _( "load jpeg from file" );
|
object_class->description = _( "load jpeg from file" );
|
||||||
|
object_class->build = vips_foreign_load_jpeg_file_build;
|
||||||
|
|
||||||
foreign_class->suffs = vips__jpeg_suffs;
|
foreign_class->suffs = vips__jpeg_suffs;
|
||||||
|
|
||||||
load_class->is_a = vips_foreign_load_jpeg_file_is_a;
|
load_class->is_a = vips_foreign_load_jpeg_file_is_a;
|
||||||
load_class->header = vips_foreign_load_jpeg_file_header;
|
|
||||||
load_class->load = vips_foreign_load_jpeg_file_load;
|
|
||||||
|
|
||||||
VIPS_ARG_STRING( class, "filename", 1,
|
VIPS_ARG_STRING( class, "filename", 1,
|
||||||
_( "Filename" ),
|
_( "Filename" ),
|
||||||
@ -343,6 +360,26 @@ typedef VipsForeignLoadJpegClass VipsForeignLoadJpegBufferClass;
|
|||||||
G_DEFINE_TYPE( VipsForeignLoadJpegBuffer, vips_foreign_load_jpeg_buffer,
|
G_DEFINE_TYPE( VipsForeignLoadJpegBuffer, vips_foreign_load_jpeg_buffer,
|
||||||
vips_foreign_load_jpeg_get_type() );
|
vips_foreign_load_jpeg_get_type() );
|
||||||
|
|
||||||
|
static int
|
||||||
|
vips_foreign_load_jpeg_buffer_build( VipsObject *object )
|
||||||
|
{
|
||||||
|
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) object;
|
||||||
|
VipsForeignLoadJpegBuffer *buffer =
|
||||||
|
(VipsForeignLoadJpegBuffer *) object;
|
||||||
|
|
||||||
|
if( buffer->blob &&
|
||||||
|
!(jpeg->streami = vips_streami_new_from_memory(
|
||||||
|
VIPS_AREA( buffer->blob )->data,
|
||||||
|
VIPS_AREA( buffer->blob )->length )) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
if( VIPS_OBJECT_CLASS( vips_foreign_load_jpeg_buffer_parent_class )->
|
||||||
|
build( object ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
vips_foreign_load_jpeg_buffer_is_a_buffer( const void *buf, size_t len )
|
vips_foreign_load_jpeg_buffer_is_a_buffer( const void *buf, size_t len )
|
||||||
{
|
{
|
||||||
@ -351,52 +388,12 @@ vips_foreign_load_jpeg_buffer_is_a_buffer( const void *buf, size_t len )
|
|||||||
|
|
||||||
if( !(streami = vips_streami_new_from_memory( buf, len )) )
|
if( !(streami = vips_streami_new_from_memory( buf, len )) )
|
||||||
return( FALSE );
|
return( FALSE );
|
||||||
result = vips__isjpeg_stream( streami );
|
result = vips_foreign_load_jpeg_stream_is_a_stream( streami );
|
||||||
VIPS_UNREF( streami );
|
VIPS_UNREF( streami );
|
||||||
|
|
||||||
return( result );
|
return( result );
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
vips_foreign_load_jpeg_buffer_header( VipsForeignLoad *load )
|
|
||||||
{
|
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
|
||||||
VipsForeignLoadJpegBuffer *buffer = (VipsForeignLoadJpegBuffer *) load;
|
|
||||||
|
|
||||||
VipsStreami *streami;
|
|
||||||
|
|
||||||
if( !(streami = vips_streami_new_from_blob( buffer->blob )) )
|
|
||||||
return( -1 );
|
|
||||||
if( vips__jpeg_read_stream( streami, load->out,
|
|
||||||
TRUE, jpeg->shrink, load->fail, jpeg->autorotate ) ) {
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
return( -1 );
|
|
||||||
}
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
vips_foreign_load_jpeg_buffer_load( VipsForeignLoad *load )
|
|
||||||
{
|
|
||||||
VipsForeignLoadJpeg *jpeg = (VipsForeignLoadJpeg *) load;
|
|
||||||
VipsForeignLoadJpegBuffer *buffer = (VipsForeignLoadJpegBuffer *) load;
|
|
||||||
|
|
||||||
VipsStreami *streami;
|
|
||||||
|
|
||||||
if( !(streami = vips_streami_new_from_blob( buffer->blob )) )
|
|
||||||
return( -1 );
|
|
||||||
if( vips__jpeg_read_stream( streami, load->real,
|
|
||||||
FALSE, jpeg->shrink, load->fail, jpeg->autorotate ) ) {
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
return( -1 );
|
|
||||||
}
|
|
||||||
VIPS_UNREF( streami );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
vips_foreign_load_jpeg_buffer_class_init(
|
vips_foreign_load_jpeg_buffer_class_init(
|
||||||
VipsForeignLoadJpegBufferClass *class )
|
VipsForeignLoadJpegBufferClass *class )
|
||||||
@ -410,10 +407,9 @@ vips_foreign_load_jpeg_buffer_class_init(
|
|||||||
|
|
||||||
object_class->nickname = "jpegload_buffer";
|
object_class->nickname = "jpegload_buffer";
|
||||||
object_class->description = _( "load jpeg from buffer" );
|
object_class->description = _( "load jpeg from buffer" );
|
||||||
|
object_class->build = vips_foreign_load_jpeg_buffer_build;
|
||||||
|
|
||||||
load_class->is_a_buffer = vips_foreign_load_jpeg_buffer_is_a_buffer;
|
load_class->is_a_buffer = vips_foreign_load_jpeg_buffer_is_a_buffer;
|
||||||
load_class->header = vips_foreign_load_jpeg_buffer_header;
|
|
||||||
load_class->load = vips_foreign_load_jpeg_buffer_load;
|
|
||||||
|
|
||||||
VIPS_ARG_BOXED( class, "buffer", 1,
|
VIPS_ARG_BOXED( class, "buffer", 1,
|
||||||
_( "Buffer" ),
|
_( "Buffer" ),
|
||||||
|
@ -315,7 +315,7 @@ typedef struct _VipsForeignLoadPngBuffer {
|
|||||||
|
|
||||||
/* Load from a buffer.
|
/* Load from a buffer.
|
||||||
*/
|
*/
|
||||||
VipsArea *buf;
|
VipsBlob *blob;
|
||||||
|
|
||||||
} VipsForeignLoadPngBuffer;
|
} VipsForeignLoadPngBuffer;
|
||||||
|
|
||||||
@ -330,9 +330,10 @@ vips_foreign_load_png_buffer_build( VipsObject *object )
|
|||||||
VipsForeignLoadPng *png = (VipsForeignLoadPng *) object;
|
VipsForeignLoadPng *png = (VipsForeignLoadPng *) object;
|
||||||
VipsForeignLoadPngBuffer *buffer = (VipsForeignLoadPngBuffer *) object;
|
VipsForeignLoadPngBuffer *buffer = (VipsForeignLoadPngBuffer *) object;
|
||||||
|
|
||||||
if( buffer->buf &&
|
if( buffer->blob &&
|
||||||
!(png->streami = vips_streami_new_from_memory(
|
!(png->streami = vips_streami_new_from_memory(
|
||||||
buffer->buf->data, buffer->buf->length )) )
|
VIPS_AREA( buffer->blob )->data,
|
||||||
|
VIPS_AREA( buffer->blob )->length )) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
if( VIPS_OBJECT_CLASS( vips_foreign_load_png_buffer_parent_class )->
|
if( VIPS_OBJECT_CLASS( vips_foreign_load_png_buffer_parent_class )->
|
||||||
@ -376,7 +377,7 @@ vips_foreign_load_png_buffer_class_init( VipsForeignLoadPngBufferClass *class )
|
|||||||
_( "Buffer" ),
|
_( "Buffer" ),
|
||||||
_( "Buffer to load from" ),
|
_( "Buffer to load from" ),
|
||||||
VIPS_ARGUMENT_REQUIRED_INPUT,
|
VIPS_ARGUMENT_REQUIRED_INPUT,
|
||||||
G_STRUCT_OFFSET( VipsForeignLoadPngBuffer, buf ),
|
G_STRUCT_OFFSET( VipsForeignLoadPngBuffer, blob ),
|
||||||
VIPS_TYPE_BLOB );
|
VIPS_TYPE_BLOB );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -291,7 +291,7 @@ typedef struct _VipsForeignLoadRadBuffer {
|
|||||||
|
|
||||||
/* Load from a buffer.
|
/* Load from a buffer.
|
||||||
*/
|
*/
|
||||||
VipsArea *buf;
|
VipsBlob *blob;
|
||||||
|
|
||||||
} VipsForeignLoadRadBuffer;
|
} VipsForeignLoadRadBuffer;
|
||||||
|
|
||||||
@ -306,9 +306,10 @@ vips_foreign_load_rad_buffer_build( VipsObject *object )
|
|||||||
VipsForeignLoadRad *rad = (VipsForeignLoadRad *) object;
|
VipsForeignLoadRad *rad = (VipsForeignLoadRad *) object;
|
||||||
VipsForeignLoadRadBuffer *buffer = (VipsForeignLoadRadBuffer *) object;
|
VipsForeignLoadRadBuffer *buffer = (VipsForeignLoadRadBuffer *) object;
|
||||||
|
|
||||||
if( buffer->buf &&
|
if( buffer->blob &&
|
||||||
!(rad->streami = vips_streami_new_from_memory(
|
!(rad->streami = vips_streami_new_from_memory(
|
||||||
buffer->buf->data, buffer->buf->length )) )
|
VIPS_AREA( buffer->blob )->data,
|
||||||
|
VIPS_AREA( buffer->blob )->length )) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
if( VIPS_OBJECT_CLASS( vips_foreign_load_rad_file_parent_class )->
|
if( VIPS_OBJECT_CLASS( vips_foreign_load_rad_file_parent_class )->
|
||||||
@ -352,7 +353,7 @@ vips_foreign_load_rad_buffer_class_init( VipsForeignLoadRadBufferClass *class )
|
|||||||
_( "Buffer" ),
|
_( "Buffer" ),
|
||||||
_( "Buffer to load from" ),
|
_( "Buffer to load from" ),
|
||||||
VIPS_ARGUMENT_REQUIRED_INPUT,
|
VIPS_ARGUMENT_REQUIRED_INPUT,
|
||||||
G_STRUCT_OFFSET( VipsForeignLoadRadBuffer, buf ),
|
G_STRUCT_OFFSET( VipsForeignLoadRadBuffer, blob ),
|
||||||
VIPS_TYPE_BLOB );
|
VIPS_TYPE_BLOB );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user