Merge branch '8.13'

This commit is contained in:
John Cupitt 2022-08-14 17:28:26 +01:00
commit 332d3a9093
5 changed files with 72 additions and 34 deletions

View File

@ -16,6 +16,7 @@ master
- better 0 detection in unpremultiply - better 0 detection in unpremultiply
- fix low bitdepth spng save [jeffska] - fix low bitdepth spng save [jeffska]
- fix PNG low bitdepth save of high bitdepth images - fix PNG low bitdepth save of high bitdepth images
- add support for libjxl 0.7 [kleisauke]
21/11/21 started 8.13 21/11/21 started 8.13
- configure fails for requested but unmet dependencies [remicollet] - configure fails for requested but unmet dependencies [remicollet]

View File

@ -158,21 +158,6 @@ vips_foreign_load_jxl_build( VipsObject *object )
jxl->runner = JxlThreadParallelRunnerCreate( NULL, jxl->runner = JxlThreadParallelRunnerCreate( NULL,
vips_concurrency_get() ); vips_concurrency_get() );
jxl->decoder = JxlDecoderCreate( NULL );
if( JxlDecoderSubscribeEvents( jxl->decoder,
JXL_DEC_COLOR_ENCODING |
JXL_DEC_BASIC_INFO |
JXL_DEC_FULL_IMAGE ) ) {
vips_foreign_load_jxl_error( jxl, "JxlDecoderSubscribeEvents" );
return( -1 );
}
if( JxlDecoderSetParallelRunner( jxl->decoder,
JxlThreadParallelRunner, jxl->runner ) ) {
vips_foreign_load_jxl_error( jxl,
"JxlDecoderSetParallelRunner" );
return( -1 );
}
if( VIPS_OBJECT_CLASS( vips_foreign_load_jxl_parent_class )-> if( VIPS_OBJECT_CLASS( vips_foreign_load_jxl_parent_class )->
build( object ) ) build( object ) )
@ -378,10 +363,13 @@ vips_foreign_load_jxl_process( VipsForeignLoadJxl *jxl )
JXL_DEC_NEED_MORE_INPUT ) { JXL_DEC_NEED_MORE_INPUT ) {
size_t bytes_remaining; size_t bytes_remaining;
#ifdef DEBUG
printf( "vips_foreign_load_jxl_process: reading ...\n" );
#endif /*DEBUG*/
bytes_remaining = JxlDecoderReleaseInput( jxl->decoder ); bytes_remaining = JxlDecoderReleaseInput( jxl->decoder );
if( vips_foreign_load_jxl_fill_input( jxl, bytes_remaining ) ) if( vips_foreign_load_jxl_fill_input( jxl, bytes_remaining ) )
return( JXL_DEC_ERROR ); return( JXL_DEC_ERROR );
JxlDecoderSetInput( jxl->decoder, JxlDecoderSetInput( jxl->decoder,
jxl->input_buffer, jxl->bytes_in_buffer ); jxl->input_buffer, jxl->bytes_in_buffer );
} }
@ -505,10 +493,24 @@ vips_foreign_load_jxl_header( VipsForeignLoad *load )
printf( "vips_foreign_load_jxl_header:\n" ); printf( "vips_foreign_load_jxl_header:\n" );
#endif /*DEBUG*/ #endif /*DEBUG*/
if( vips_source_rewind( jxl->source ) ) /* Build the decoder we will use for the header.
*/
jxl->decoder = JxlDecoderCreate( NULL );
if( JxlDecoderSubscribeEvents( jxl->decoder,
JXL_DEC_COLOR_ENCODING |
JXL_DEC_BASIC_INFO ) ) {
vips_foreign_load_jxl_error( jxl, "JxlDecoderSubscribeEvents" );
return( -1 ); return( -1 );
}
if( JxlDecoderSetParallelRunner( jxl->decoder,
JxlThreadParallelRunner, jxl->runner ) ) {
vips_foreign_load_jxl_error( jxl,
"JxlDecoderSetParallelRunner" );
return( -1 );
}
if( vips_foreign_load_jxl_fill_input( jxl, 0 ) ) if( vips_source_rewind( jxl->source ) ||
vips_foreign_load_jxl_fill_input( jxl, 0 ) )
return( -1 ); return( -1 );
JxlDecoderSetInput( jxl->decoder, JxlDecoderSetInput( jxl->decoder,
jxl->input_buffer, jxl->bytes_in_buffer ); jxl->input_buffer, jxl->bytes_in_buffer );
@ -618,13 +620,26 @@ vips_foreign_load_jxl_load( VipsForeignLoad *load )
if( vips_foreign_load_jxl_set_header( jxl, t[0] ) ) if( vips_foreign_load_jxl_set_header( jxl, t[0] ) )
return( -1 ); return( -1 );
/* We have to reset the reader ... we can't reply onb the read point /* We have to make a new decoder ... we can't be certain the header
* being left just after the header. * decoder left the input in the correct place.
*/ */
if( vips_source_rewind( jxl->source ) ) VIPS_FREEF( JxlDecoderDestroy, jxl->decoder );
return( -1 );
if( vips_foreign_load_jxl_fill_input( jxl, 0 ) ) jxl->decoder = JxlDecoderCreate( NULL );
if( JxlDecoderSubscribeEvents( jxl->decoder,
JXL_DEC_FULL_IMAGE ) ) {
vips_foreign_load_jxl_error( jxl, "JxlDecoderSubscribeEvents" );
return( -1 );
}
if( JxlDecoderSetParallelRunner( jxl->decoder,
JxlThreadParallelRunner, jxl->runner ) ) {
vips_foreign_load_jxl_error( jxl,
"JxlDecoderSetParallelRunner" );
return( -1 );
}
if( vips_source_rewind( jxl->source ) ||
vips_foreign_load_jxl_fill_input( jxl, 0 ) )
return( -1 ); return( -1 );
JxlDecoderSetInput( jxl->decoder, JxlDecoderSetInput( jxl->decoder,
jxl->input_buffer, jxl->bytes_in_buffer ); jxl->input_buffer, jxl->bytes_in_buffer );

View File

@ -229,7 +229,11 @@ vips_foreign_save_jxl_build( VipsObject *object )
VipsForeignSaveJxl *jxl = (VipsForeignSaveJxl *) object; VipsForeignSaveJxl *jxl = (VipsForeignSaveJxl *) object;
VipsImage **t = (VipsImage **) vips_object_local_array( object, 5 ); VipsImage **t = (VipsImage **) vips_object_local_array( object, 5 );
JxlEncoderOptions *options; #ifdef HAVE_LIBJXL_0_7
JxlEncoderFrameSettings *frame_settings;
#else
JxlEncoderOptions *frame_settings;
#endif
JxlEncoderStatus status; JxlEncoderStatus status;
VipsImage *in; VipsImage *in;
VipsBandFormat format; VipsBandFormat format;
@ -415,29 +419,44 @@ vips_foreign_save_jxl_build( VipsObject *object )
if( vips_image_wio_input( in ) ) if( vips_image_wio_input( in ) )
return( -1 ); return( -1 );
options = JxlEncoderOptionsCreate( jxl->encoder, NULL ); #ifdef HAVE_LIBJXL_0_7
JxlEncoderOptionsSetDecodingSpeed( options, jxl->tier ); frame_settings = JxlEncoderFrameSettingsCreate( jxl->encoder, NULL );
JxlEncoderOptionsSetDistance( options, jxl->distance ); JxlEncoderFrameSettingsSetOption( frame_settings,
JxlEncoderOptionsSetEffort( options, jxl->effort ); JXL_ENC_FRAME_SETTING_DECODING_SPEED, jxl->tier );
JxlEncoderOptionsSetLossless( options, jxl->lossless ); JxlEncoderSetFrameDistance( frame_settings, jxl->distance );
JxlEncoderFrameSettingsSetOption( frame_settings,
JXL_ENC_FRAME_SETTING_EFFORT, jxl->effort );
JxlEncoderSetFrameLossless( frame_settings, jxl->lossless );
#else
frame_settings = JxlEncoderOptionsCreate( jxl->encoder, NULL );
JxlEncoderOptionsSetDecodingSpeed( frame_settings, jxl->tier );
JxlEncoderOptionsSetDistance( frame_settings, jxl->distance );
JxlEncoderOptionsSetEffort( frame_settings, jxl->effort );
JxlEncoderOptionsSetLossless( frame_settings, jxl->lossless );
#endif
#ifdef DEBUG #ifdef DEBUG
vips_foreign_save_jxl_print_info( &jxl->info ); vips_foreign_save_jxl_print_info( &jxl->info );
vips_foreign_save_jxl_print_format( &jxl->format ); vips_foreign_save_jxl_print_format( &jxl->format );
printf( "JxlEncoderOptions:\n" ); printf( "JxlEncoderFrameSettings:\n" );
printf( " tier = %d\n", jxl->tier ); printf( " tier = %d\n", jxl->tier );
printf( " distance = %g\n", jxl->distance ); printf( " distance = %g\n", jxl->distance );
printf( " effort = %d\n", jxl->effort ); printf( " effort = %d\n", jxl->effort );
printf( " lossless = %d\n", jxl->lossless ); printf( " lossless = %d\n", jxl->lossless );
#endif /*DEBUG*/ #endif /*DEBUG*/
if( JxlEncoderAddImageFrame( options, &jxl->format, if( JxlEncoderAddImageFrame( frame_settings, &jxl->format,
VIPS_IMAGE_ADDR( in, 0, 0 ), VIPS_IMAGE_ADDR( in, 0, 0 ),
VIPS_IMAGE_SIZEOF_IMAGE( in ) ) ) { VIPS_IMAGE_SIZEOF_IMAGE( in ) ) ) {
vips_foreign_save_jxl_error( jxl, "JxlEncoderAddImageFrame" ); vips_foreign_save_jxl_error( jxl, "JxlEncoderAddImageFrame" );
return( -1 ); return( -1 );
} }
/* This function must be called after the final frame and/or box,
* otherwise the codestream will not be encoded correctly.
*/
JxlEncoderCloseInput( jxl->encoder );
do { do {
uint8_t *out; uint8_t *out;
size_t avail_out; size_t avail_out;

View File

@ -42,9 +42,9 @@
*/ */
/* /*
*/
#define DEBUG_VERBOSE #define DEBUG_VERBOSE
#define DEBUG #define DEBUG
*/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include <config.h> #include <config.h>

View File

@ -484,6 +484,9 @@ if libjxl_found
if cc.has_function('JxlEncoderInitBasicInfo', prefix: '#include <jxl/encode.h>', dependencies: libjxl_dep) if cc.has_function('JxlEncoderInitBasicInfo', prefix: '#include <jxl/encode.h>', dependencies: libjxl_dep)
cfg_var.set('HAVE_LIBJXL_JXLENCODERINITBASICINFO', '1') cfg_var.set('HAVE_LIBJXL_JXLENCODERINITBASICINFO', '1')
endif endif
if libjxl_dep.version().version_compare('>=0.7')
cfg_var.set('HAVE_LIBJXL_0_7', '1')
endif
endif endif
libpoppler_dep = dependency('poppler-glib', version: '>=0.16.0', required: get_option('poppler')) libpoppler_dep = dependency('poppler-glib', version: '>=0.16.0', required: get_option('poppler'))