reorder load tests
and a slight memory saving on ifthenelse
This commit is contained in:
parent
52384606dd
commit
6ca9a907b8
@ -1,5 +1,7 @@
|
|||||||
12/1/16 started 8.2.2
|
12/1/16 started 8.2.2
|
||||||
- changes to ease compiling C++ binding with MSVC
|
- changes to ease compiling C++ binding with MSVC
|
||||||
|
- reorder file tests to put slow loaders last
|
||||||
|
- ifthenelse needs less C stack during eval
|
||||||
|
|
||||||
1/1/16 started 8.2.1
|
1/1/16 started 8.2.1
|
||||||
- add a compat stub, thanks Benjamin
|
- add a compat stub, thanks Benjamin
|
||||||
|
@ -437,8 +437,15 @@ vips_ifthenelse_build( VipsObject *object )
|
|||||||
|
|
||||||
/* Condition is cast to uchar, then/else to a common type.
|
/* Condition is cast to uchar, then/else to a common type.
|
||||||
*/
|
*/
|
||||||
|
if( size[2]->BandFmt != VIPS_FORMAT_UCHAR ) {
|
||||||
if( vips_cast( size[2], &format[2], VIPS_FORMAT_UCHAR, NULL ) )
|
if( vips_cast( size[2], &format[2], VIPS_FORMAT_UCHAR, NULL ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
format[2] = size[2];
|
||||||
|
g_object_ref( format[2] );
|
||||||
|
}
|
||||||
|
|
||||||
if( vips__formatalike_vec( size, format, 2 ) )
|
if( vips__formatalike_vec( size, format, 2 ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
|
@ -118,6 +118,10 @@ vips_foreign_load_analyze_class_init( VipsForeignLoadAnalyzeClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips_foreign_analyze_suffs;
|
foreign_class->suffs = vips_foreign_analyze_suffs;
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
load_class->is_a = vips__isanalyze;
|
load_class->is_a = vips__isanalyze;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_analyze_get_flags_filename;
|
vips_foreign_load_analyze_get_flags_filename;
|
||||||
|
@ -125,6 +125,10 @@ vips_foreign_load_csv_class_init( VipsForeignLoadCsvClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__foreign_csv_suffs;
|
foreign_class->suffs = vips__foreign_csv_suffs;
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_csv_get_flags_filename;
|
vips_foreign_load_csv_get_flags_filename;
|
||||||
load_class->get_flags = vips_foreign_load_csv_get_flags;
|
load_class->get_flags = vips_foreign_load_csv_get_flags;
|
||||||
|
@ -109,6 +109,10 @@ vips_foreign_load_fits_class_init( VipsForeignLoadFitsClass *class )
|
|||||||
object_class->nickname = "fitsload";
|
object_class->nickname = "fitsload";
|
||||||
object_class->description = _( "load a FITS image" );
|
object_class->description = _( "load a FITS image" );
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
foreign_class->suffs = vips__fits_suffs;
|
foreign_class->suffs = vips__fits_suffs;
|
||||||
|
|
||||||
load_class->is_a = vips__fits_isfits;
|
load_class->is_a = vips__fits_isfits;
|
||||||
|
@ -240,6 +240,10 @@ vips_foreign_load_jpeg_file_class_init( VipsForeignLoadJpegFileClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = jpeg_suffs;
|
foreign_class->suffs = jpeg_suffs;
|
||||||
|
|
||||||
|
/* We are fast at is_a(), so high priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 200;
|
||||||
|
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_jpeg_file_get_flags_filename;
|
vips_foreign_load_jpeg_file_get_flags_filename;
|
||||||
load_class->is_a = vips_foreign_load_jpeg_file_is_a;
|
load_class->is_a = vips_foreign_load_jpeg_file_is_a;
|
||||||
|
@ -138,6 +138,10 @@ vips_foreign_load_matrix_class_init( VipsForeignLoadMatrixClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__foreign_matrix_suffs;
|
foreign_class->suffs = vips__foreign_matrix_suffs;
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
load_class->is_a = vips__matrix_ismatrix;
|
load_class->is_a = vips__matrix_ismatrix;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_matrix_get_flags_filename;
|
vips_foreign_load_matrix_get_flags_filename;
|
||||||
|
@ -129,6 +129,10 @@ vips_foreign_load_openexr_class_init( VipsForeignLoadOpenexrClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips_foreign_openexr_suffs;
|
foreign_class->suffs = vips_foreign_openexr_suffs;
|
||||||
|
|
||||||
|
/* We are fast at is_a(), so high priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 200;
|
||||||
|
|
||||||
load_class->is_a = vips__openexr_isexr;
|
load_class->is_a = vips__openexr_isexr;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_openexr_get_flags_filename;
|
vips_foreign_load_openexr_get_flags_filename;
|
||||||
|
@ -129,6 +129,10 @@ vips_foreign_load_png_class_init( VipsForeignLoadPngClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__png_suffs;
|
foreign_class->suffs = vips__png_suffs;
|
||||||
|
|
||||||
|
/* We are fast at is_a(), so high priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 200;
|
||||||
|
|
||||||
load_class->is_a = vips__png_ispng;
|
load_class->is_a = vips__png_ispng;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_png_get_flags_filename;
|
vips_foreign_load_png_get_flags_filename;
|
||||||
|
@ -118,6 +118,10 @@ vips_foreign_load_ppm_class_init( VipsForeignLoadPpmClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__ppm_suffs;
|
foreign_class->suffs = vips__ppm_suffs;
|
||||||
|
|
||||||
|
/* We are fast at is_a(), so high priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 200;
|
||||||
|
|
||||||
load_class->is_a = vips__ppm_isppm;
|
load_class->is_a = vips__ppm_isppm;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_ppm_get_flags_filename;
|
vips_foreign_load_ppm_get_flags_filename;
|
||||||
|
@ -121,6 +121,10 @@ vips_foreign_load_rad_class_init( VipsForeignLoadRadClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__rad_suffs;
|
foreign_class->suffs = vips__rad_suffs;
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
load_class->is_a = vips__rad_israd;
|
load_class->is_a = vips__rad_israd;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
vips_foreign_load_rad_get_flags_filename;
|
vips_foreign_load_rad_get_flags_filename;
|
||||||
|
@ -179,6 +179,10 @@ vips_foreign_load_tiff_file_class_init( VipsForeignLoadTiffFileClass *class )
|
|||||||
object_class->nickname = "tiffload";
|
object_class->nickname = "tiffload";
|
||||||
object_class->description = _( "load tiff from file" );
|
object_class->description = _( "load tiff from file" );
|
||||||
|
|
||||||
|
/* We are fast, but must test after openslideload.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 50;
|
||||||
|
|
||||||
foreign_class->suffs = vips__foreign_tiff_suffs;
|
foreign_class->suffs = vips__foreign_tiff_suffs;
|
||||||
|
|
||||||
load_class->is_a = vips__istiff;
|
load_class->is_a = vips__istiff;
|
||||||
|
@ -123,6 +123,10 @@ vips_foreign_load_vips_class_init( VipsForeignLoadVipsClass *class )
|
|||||||
|
|
||||||
foreign_class->suffs = vips__suffs;
|
foreign_class->suffs = vips__suffs;
|
||||||
|
|
||||||
|
/* We are fast at is_a(), so high priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = 200;
|
||||||
|
|
||||||
load_class->is_a = vips_foreign_load_vips_is_a;
|
load_class->is_a = vips_foreign_load_vips_is_a;
|
||||||
load_class->get_flags = vips_foreign_load_vips_get_flags;
|
load_class->get_flags = vips_foreign_load_vips_get_flags;
|
||||||
load_class->get_flags_filename =
|
load_class->get_flags_filename =
|
||||||
|
@ -229,6 +229,7 @@ vips_foreign_load_webp_buffer_class_init(
|
|||||||
{
|
{
|
||||||
GObjectClass *gobject_class = G_OBJECT_CLASS( class );
|
GObjectClass *gobject_class = G_OBJECT_CLASS( class );
|
||||||
VipsObjectClass *object_class = (VipsObjectClass *) class;
|
VipsObjectClass *object_class = (VipsObjectClass *) class;
|
||||||
|
VipsForeignClass *foreign_class = (VipsForeignClass *) class;
|
||||||
VipsForeignLoadClass *load_class = (VipsForeignLoadClass *) class;
|
VipsForeignLoadClass *load_class = (VipsForeignLoadClass *) class;
|
||||||
|
|
||||||
gobject_class->set_property = vips_object_set_property;
|
gobject_class->set_property = vips_object_set_property;
|
||||||
@ -237,6 +238,10 @@ vips_foreign_load_webp_buffer_class_init(
|
|||||||
object_class->nickname = "webpload_buffer";
|
object_class->nickname = "webpload_buffer";
|
||||||
object_class->description = _( "load webp from buffer" );
|
object_class->description = _( "load webp from buffer" );
|
||||||
|
|
||||||
|
/* is_a() is not that quick ... lower the priority.
|
||||||
|
*/
|
||||||
|
foreign_class->priority = -50;
|
||||||
|
|
||||||
load_class->is_a_buffer = vips__iswebp_buffer;
|
load_class->is_a_buffer = vips__iswebp_buffer;
|
||||||
load_class->header = vips_foreign_load_webp_buffer_header;
|
load_class->header = vips_foreign_load_webp_buffer_header;
|
||||||
load_class->load = vips_foreign_load_webp_buffer_load;
|
load_class->load = vips_foreign_load_webp_buffer_load;
|
||||||
|
Loading…
Reference in New Issue
Block a user