don't use new source API for new_from_file etc.
We were attempting to load images in new_from_file using the new source API first, then only falling back to the file loaders if that failed. However, this meant that we did not respect the priority ordering on loaders, so openslide iamges (for example) were being loaded by the tiff loader.
This commit is contained in:
parent
1338def535
commit
51fc2ff64e
@ -1,3 +1,7 @@
|
|||||||
|
20/6/19 started 8.9.1
|
||||||
|
- don't use the new source loaders for new_from_file or new_from_buffer, it
|
||||||
|
will break the loader priority system
|
||||||
|
|
||||||
20/6/19 started 8.9.0
|
20/6/19 started 8.9.0
|
||||||
- add vips_image_get/set_array_int()
|
- add vips_image_get/set_array_int()
|
||||||
- disable webp alpha output if all frame fill the canvas and are solid
|
- disable webp alpha output if all frame fill the canvas and are solid
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# also update the version number in the m4 macros below
|
# also update the version number in the m4 macros below
|
||||||
|
|
||||||
AC_INIT([vips], [8.9.0], [vipsip@jiscmail.ac.uk])
|
AC_INIT([vips], [8.9.1], [vipsip@jiscmail.ac.uk])
|
||||||
# required for gobject-introspection
|
# required for gobject-introspection
|
||||||
AC_PREREQ(2.62)
|
AC_PREREQ(2.62)
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ AC_CONFIG_MACRO_DIR([m4])
|
|||||||
# user-visible library versioning
|
# user-visible library versioning
|
||||||
m4_define([vips_major_version], [8])
|
m4_define([vips_major_version], [8])
|
||||||
m4_define([vips_minor_version], [9])
|
m4_define([vips_minor_version], [9])
|
||||||
m4_define([vips_micro_version], [0])
|
m4_define([vips_micro_version], [1])
|
||||||
m4_define([vips_version],
|
m4_define([vips_version],
|
||||||
[vips_major_version.vips_minor_version.vips_micro_version])
|
[vips_major_version.vips_minor_version.vips_micro_version])
|
||||||
|
|
||||||
@ -38,7 +38,7 @@ VIPS_VERSION_STRING=$VIPS_VERSION-`date -u -r ChangeLog`
|
|||||||
# binary interface changes not backwards compatible?: reset age to 0
|
# binary interface changes not backwards compatible?: reset age to 0
|
||||||
|
|
||||||
LIBRARY_CURRENT=54
|
LIBRARY_CURRENT=54
|
||||||
LIBRARY_REVISION=0
|
LIBRARY_REVISION=1
|
||||||
LIBRARY_AGE=12
|
LIBRARY_AGE=12
|
||||||
|
|
||||||
# patched into include/vips/version.h
|
# patched into include/vips/version.h
|
||||||
|
@ -1907,7 +1907,6 @@ vips_image_new_from_file( const char *name, ... )
|
|||||||
{
|
{
|
||||||
char filename[VIPS_PATH_MAX];
|
char filename[VIPS_PATH_MAX];
|
||||||
char option_string[VIPS_PATH_MAX];
|
char option_string[VIPS_PATH_MAX];
|
||||||
VipsSource *source;
|
|
||||||
const char *operation_name;
|
const char *operation_name;
|
||||||
va_list ap;
|
va_list ap;
|
||||||
int result;
|
int result;
|
||||||
@ -1917,27 +1916,6 @@ vips_image_new_from_file( const char *name, ... )
|
|||||||
|
|
||||||
vips__filename_split8( name, filename, option_string );
|
vips__filename_split8( name, filename, option_string );
|
||||||
|
|
||||||
/* Search with the new source API first, then fall back to the older
|
|
||||||
* mechanism in case the loader we need has not been converted yet.
|
|
||||||
*
|
|
||||||
* We need to hide any errors from this first phase.
|
|
||||||
*/
|
|
||||||
if( !(source = vips_source_new_from_file( filename )) )
|
|
||||||
return( NULL );
|
|
||||||
|
|
||||||
vips_error_freeze();
|
|
||||||
operation_name = vips_foreign_find_load_source( source );
|
|
||||||
vips_error_thaw();
|
|
||||||
|
|
||||||
if( operation_name ) {
|
|
||||||
va_start( ap, name );
|
|
||||||
result = vips_call_split_option_string( operation_name,
|
|
||||||
option_string, ap, source, &out );
|
|
||||||
va_end( ap );
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/* Fall back to the old file loader system.
|
|
||||||
*/
|
|
||||||
if( !(operation_name = vips_foreign_find_load( filename )) )
|
if( !(operation_name = vips_foreign_find_load( filename )) )
|
||||||
return( NULL );
|
return( NULL );
|
||||||
|
|
||||||
@ -1945,9 +1923,6 @@ vips_image_new_from_file( const char *name, ... )
|
|||||||
result = vips_call_split_option_string( operation_name,
|
result = vips_call_split_option_string( operation_name,
|
||||||
option_string, ap, filename, &out );
|
option_string, ap, filename, &out );
|
||||||
va_end( ap );
|
va_end( ap );
|
||||||
}
|
|
||||||
|
|
||||||
VIPS_UNREF( source );
|
|
||||||
|
|
||||||
if( result )
|
if( result )
|
||||||
return( NULL );
|
return( NULL );
|
||||||
@ -2159,29 +2134,14 @@ VipsImage *
|
|||||||
vips_image_new_from_buffer( const void *buf, size_t len,
|
vips_image_new_from_buffer( const void *buf, size_t len,
|
||||||
const char *option_string, ... )
|
const char *option_string, ... )
|
||||||
{
|
{
|
||||||
VipsSource *source;
|
|
||||||
const char *operation_name;
|
const char *operation_name;
|
||||||
va_list ap;
|
va_list ap;
|
||||||
int result;
|
int result;
|
||||||
VipsImage *out;
|
VipsImage *out;
|
||||||
|
VipsBlob *blob;
|
||||||
|
|
||||||
vips_check_init();
|
vips_check_init();
|
||||||
|
|
||||||
/* Search with the new source API first, then fall back to the older
|
|
||||||
* mechanism in case the loader we need has not been converted yet.
|
|
||||||
*/
|
|
||||||
if( !(source = vips_source_new_from_memory( buf, len )) )
|
|
||||||
return( NULL );
|
|
||||||
|
|
||||||
if( (operation_name = vips_foreign_find_load_source( source )) ) {
|
|
||||||
va_start( ap, option_string );
|
|
||||||
result = vips_call_split_option_string( operation_name,
|
|
||||||
option_string, ap, source, &out );
|
|
||||||
va_end( ap );
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
VipsBlob *blob;
|
|
||||||
|
|
||||||
if( !(operation_name =
|
if( !(operation_name =
|
||||||
vips_foreign_find_load_buffer( buf, len )) )
|
vips_foreign_find_load_buffer( buf, len )) )
|
||||||
return( NULL );
|
return( NULL );
|
||||||
@ -2196,9 +2156,6 @@ vips_image_new_from_buffer( const void *buf, size_t len,
|
|||||||
va_end( ap );
|
va_end( ap );
|
||||||
|
|
||||||
vips_area_unref( VIPS_AREA( blob ) );
|
vips_area_unref( VIPS_AREA( blob ) );
|
||||||
}
|
|
||||||
|
|
||||||
VIPS_UNREF( source );
|
|
||||||
|
|
||||||
if( result )
|
if( result )
|
||||||
return( NULL );
|
return( NULL );
|
||||||
|
Loading…
Reference in New Issue
Block a user