vips_pngload_buffer() works

fix a bug in vips_jpegload_buffer() too
This commit is contained in:
John Cupitt 2013-06-17 09:41:22 +01:00
parent 005984226e
commit dcd2dbb756
6 changed files with 47 additions and 26 deletions

View File

@ -5,6 +5,7 @@
- add im_vips2dz(): run the deepzoom writer from vips7 - add im_vips2dz(): run the deepzoom writer from vips7
- vips_magickload() has an option to read all images in a sequence - vips_magickload() has an option to read all images in a sequence
- redo im_make_xy(), im_*eye(), im_zone*(), im_sines() as classes - redo im_make_xy(), im_*eye(), im_zone*(), im_sines() as classes
- added vips_pngload_buffer()
12/3/13 started 7.33.0 12/3/13 started 7.33.0
- vipsthumbnail lets you specify the sharpening mask - vipsthumbnail lets you specify the sharpening mask

8
TODO
View File

@ -1,4 +1,3 @@
- need png load from buffer?
- could we support streaming read? how would it work? - could we support streaming read? how would it work?
@ -18,6 +17,13 @@
reader.kick reader.kick
end end
looks ugly and stupid :(
could maybe read from a socket? would we need to be able to pass file ids
in? can named sockets work like this?

View File

@ -1999,10 +1999,14 @@ vips_jpegsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
VipsArea *area; VipsArea *area;
int result; int result;
area = NULL;
va_start( ap, len ); va_start( ap, len );
result = vips_call_split( "jpegsave_buffer", ap, in, &area ); result = vips_call_split( "jpegsave_buffer", ap, in, &area );
va_end( ap ); va_end( ap );
if( !result &&
area ) {
if( buf ) { if( buf ) {
*buf = area->data; *buf = area->data;
area->free_fn = NULL; area->free_fn = NULL;
@ -2011,6 +2015,7 @@ vips_jpegsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
*len = area->length; *len = area->length;
vips_area_unref( area ); vips_area_unref( area );
}
return( result ); return( result );
} }
@ -2341,10 +2346,14 @@ vips_pngsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
VipsArea *area; VipsArea *area;
int result; int result;
area = NULL;
va_start( ap, len ); va_start( ap, len );
result = vips_call_split( "pngsave_buffer", ap, in, &area ); result = vips_call_split( "pngsave_buffer", ap, in, &area );
va_end( ap ); va_end( ap );
if( !result &&
area ) {
if( buf ) { if( buf ) {
*buf = area->data; *buf = area->data;
area->free_fn = NULL; area->free_fn = NULL;
@ -2353,6 +2362,7 @@ vips_pngsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
*len = area->length; *len = area->length;
vips_area_unref( area ); vips_area_unref( area );
}
return( result ); return( result );
} }

View File

@ -165,8 +165,8 @@ vips_foreign_load_png_buffer_header( VipsForeignLoad *load )
{ {
VipsForeignLoadPngBuffer *png = (VipsForeignLoadPngBuffer *) load; VipsForeignLoadPngBuffer *png = (VipsForeignLoadPngBuffer *) load;
if( vips__png_header_buffer( load->out, if( vips__png_header_buffer( png->buf->data, png->buf->length,
png->buf->data, png->buf->length ) ) load->out ) )
return( -1 ); return( -1 );
return( 0 ); return( 0 );
@ -177,8 +177,8 @@ vips_foreign_load_png_buffer_load( VipsForeignLoad *load )
{ {
VipsForeignLoadPngBuffer *png = (VipsForeignLoadPngBuffer *) load; VipsForeignLoadPngBuffer *png = (VipsForeignLoadPngBuffer *) load;
if( vips__png_read_buffer( load->out, if( vips__png_read_buffer( png->buf->data, png->buf->length,
png->buf->data, png->buf->length ) ) load->real ) )
return( -1 ); return( -1 );
return( 0 ); return( 0 );

View File

@ -501,7 +501,7 @@ vips__png_isinterlaced( const char *filename )
} }
static int static int
read_all( Read *read, VipsImage *out ) png2vips_image( Read *read, VipsImage *out )
{ {
int interlace_type = png_get_interlace_type( read->pPng, read->pInfo ); int interlace_type = png_get_interlace_type( read->pPng, read->pInfo );
VipsImage **t = (VipsImage **) VipsImage **t = (VipsImage **)
@ -543,7 +543,7 @@ vips__png_read( const char *filename, VipsImage *out )
#endif /*DEBUG*/ #endif /*DEBUG*/
if( !(read = read_new_filename( out, filename )) || if( !(read = read_new_filename( out, filename )) ||
read_all( read, out ) ) png2vips_image( read, out ) )
return( -1 ); return( -1 );
#ifdef DEBUG #ifdef DEBUG
@ -567,6 +567,10 @@ vips_png_read_buffer( png_structp pPng, png_bytep data, png_size_t length )
{ {
Read *read = png_get_io_ptr( pPng ); Read *read = png_get_io_ptr( pPng );
#ifdef DEBUG
printf( "vips_png_read_buffer: read %zd bytes\n", length );
#endif /*DEBUG*/
if( read->read_pos + length > read->length ) if( read->read_pos + length > read->length )
png_error( pPng, "not enough data in buffer" ); png_error( pPng, "not enough data in buffer" );
@ -596,7 +600,7 @@ read_new_buffer( VipsImage *out, char *buffer, size_t length )
} }
int int
vips__png_header_buffer( VipsImage *out, char *buffer, size_t length ) vips__png_header_buffer( char *buffer, size_t length, VipsImage *out )
{ {
Read *read; Read *read;
@ -608,12 +612,12 @@ vips__png_header_buffer( VipsImage *out, char *buffer, size_t length )
} }
int int
vips__png_read_buffer( VipsImage *out, char *buffer, size_t length ) vips__png_read_buffer( char *buffer, size_t length, VipsImage *out )
{ {
Read *read; Read *read;
if( !(read = read_new_buffer( out, buffer, length )) || if( !(read = read_new_buffer( out, buffer, length )) ||
read_all( read, out ) ) png2vips_image( read, out ) )
return( -1 ); return( -1 );
return( 0 ); return( 0 );

View File

@ -40,8 +40,8 @@ int vips__png_read( const char *name, VipsImage *out );
int vips__png_ispng( const char *filename ); int vips__png_ispng( const char *filename );
gboolean vips__png_isinterlaced( const char *filename ); gboolean vips__png_isinterlaced( const char *filename );
extern const char *vips__png_suffs[]; extern const char *vips__png_suffs[];
int vips__png_read_buffer( VipsImage *out, char *buffer, size_t length ); int vips__png_read_buffer( char *buffer, size_t length, VipsImage *out );
int vips__png_header_buffer( VipsImage *out, char *buffer, size_t length ); int vips__png_header_buffer( char *buffer, size_t length, VipsImage *out );
int vips__png_write( VipsImage *in, const char *filename, int vips__png_write( VipsImage *in, const char *filename,
int compress, int interlace ); int compress, int interlace );