revise formatting, add docs

fix up some formatting from https://github.com/libvips/libvips/pull/1552

plus some other small changes
This commit is contained in:
John Cupitt 2020-02-18 17:37:56 +00:00
parent fefefdf3e2
commit 0a23bf3578
6 changed files with 61 additions and 58 deletions

View File

@ -11,6 +11,7 @@
- add vips_pipe_read_limit_set(), --vips-pipe-read-limit, - add vips_pipe_read_limit_set(), --vips-pipe-read-limit,
VIPS_PIPE_READ_LIMIT VIPS_PIPE_READ_LIMIT
- revise gifload to fix BACKGROUND and PREVIOUS dispose [alon-ne] - revise gifload to fix BACKGROUND and PREVIOUS dispose [alon-ne]
- add subsample_mode, deprecate no_subsample in jpegsave [Elad-Laufer]
31/1/19 started 8.9.2 31/1/19 started 8.9.2
- fix a deadlock with --vips-leak [DarthSim] - fix a deadlock with --vips-leak [DarthSim]

View File

@ -2,6 +2,8 @@
* *
* 24/11/11 * 24/11/11
* - wrap a class around the jpeg writer * - wrap a class around the jpeg writer
* 18/2/20 Elad-Laufer
* - add subsample_mode, deprecate no_subsample
*/ */
/* /*
@ -77,12 +79,12 @@ typedef struct _VipsForeignSaveJpeg {
*/ */
gboolean no_subsample; gboolean no_subsample;
/* Select chroma subsampling mode: /* Select chroma subsampling mode:
* auto will disable subsampling for Q >= 90 * auto will disable subsampling for Q >= 90
* on will always enable subsampling * on will always enable subsampling
* off will always disable subsampling * off will always disable subsampling
*/ */
VipsForeignJpegSubsample subsample_mode; VipsForeignJpegSubsample subsample_mode;
/* Apply trellis quantisation to each 8x8 block. /* Apply trellis quantisation to each 8x8 block.
*/ */
@ -113,26 +115,28 @@ G_DEFINE_ABSTRACT_TYPE( VipsForeignSaveJpeg, vips_foreign_save_jpeg,
/* Type promotion for save ... just always go to uchar. /* Type promotion for save ... just always go to uchar.
*/ */
static int bandfmt_jpeg[10] = { static int bandfmt_jpeg[10] = {
/* UC C US S UI I F X D DX */ /* UC C US S UI I F X D DX */
UC, UC, UC, UC, UC, UC, UC, UC, UC, UC UC, UC, UC, UC, UC, UC, UC, UC, UC, UC
}; };
static int static int
vips_foreign_save_jpeg_build( VipsObject *object ) vips_foreign_save_jpeg_build( VipsObject *object )
{ {
VipsForeignSaveJpeg *jpeg = (VipsForeignSaveJpeg *) object; VipsForeignSaveJpeg *jpeg = (VipsForeignSaveJpeg *) object;
if( VIPS_OBJECT_CLASS( vips_foreign_save_jpeg_parent_class )-> if( VIPS_OBJECT_CLASS( vips_foreign_save_jpeg_parent_class )->
build( object ) ) build( object ) )
return( -1 ); return( -1 );
/* no_subsample is deprecated, but we retain backwards compatibility /* no_subsample is deprecated, but we retain backwards compatibility
* new code should use subsample_mode * new code should use subsample_mode
*/ */
if( vips_object_argument_isset(object, "no_subsample") ) if( vips_object_argument_isset( object, "no_subsample" ) )
jpeg->subsample_mode = jpeg->no_subsample ? VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF : VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO; jpeg->subsample_mode = jpeg->no_subsample ?
VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF :
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO;
return( 0 ); return( 0 );
} }
static void static void
@ -148,7 +152,7 @@ vips_foreign_save_jpeg_class_init( VipsForeignSaveJpegClass *class )
object_class->nickname = "jpegsave_base"; object_class->nickname = "jpegsave_base";
object_class->description = _( "save jpeg" ); object_class->description = _( "save jpeg" );
object_class->build = vips_foreign_save_jpeg_build; object_class->build = vips_foreign_save_jpeg_build;
foreign_class->suffs = vips__jpeg_suffs; foreign_class->suffs = vips__jpeg_suffs;
@ -220,19 +224,20 @@ vips_foreign_save_jpeg_class_init( VipsForeignSaveJpegClass *class )
G_STRUCT_OFFSET( VipsForeignSaveJpeg, quant_table ), G_STRUCT_OFFSET( VipsForeignSaveJpeg, quant_table ),
0, 8, 0 ); 0, 8, 0 );
VIPS_ARG_ENUM( class, "subsample_mode", 19, VIPS_ARG_ENUM( class, "subsample_mode", 19,
_( "Subsample mode" ), _( "Subsample mode" ),
_( "Select chroma subsample operation mode" ), _( "Select chroma subsample operation mode" ),
VIPS_ARGUMENT_OPTIONAL_INPUT, VIPS_ARGUMENT_OPTIONAL_INPUT,
G_STRUCT_OFFSET( VipsForeignSaveJpeg, subsample_mode ), G_STRUCT_OFFSET( VipsForeignSaveJpeg, subsample_mode ),
VIPS_TYPE_FOREIGN_JPEG_SUBSAMPLE, VIPS_TYPE_FOREIGN_JPEG_SUBSAMPLE,
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO ); VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO );
} }
static void static void
vips_foreign_save_jpeg_init( VipsForeignSaveJpeg *jpeg ) vips_foreign_save_jpeg_init( VipsForeignSaveJpeg *jpeg )
{ {
jpeg->Q = 75; jpeg->Q = 75;
jpeg->subsample_mode = VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO;
} }
typedef struct _VipsForeignSaveJpegTarget { typedef struct _VipsForeignSaveJpegTarget {
@ -524,7 +529,7 @@ vips_foreign_save_jpeg_mime_init( VipsForeignSaveJpegMime *mime )
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables * * @optimize_coding: %gboolean, compute optimal Huffman coding tables
* * @interlace: %gboolean, write an interlaced (progressive) jpeg * * @interlace: %gboolean, write an interlaced (progressive) jpeg
* * @strip: %gboolean, remove all metadata from image * * @strip: %gboolean, remove all metadata from image
* * @no_subsample: %gboolean, disable chroma subsampling * * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block * * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values * * @overshoot_deringing: %gboolean, overshoot samples with extreme values
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans * * @optimize_scans: %gboolean, split DCT coefficients into separate scans
@ -552,8 +557,8 @@ vips_foreign_save_jpeg_mime_init( VipsForeignSaveJpegMime *mime )
* If @strip is set, no EXIF data, IPTC data, ICC profile or XMP metadata is * If @strip is set, no EXIF data, IPTC data, ICC profile or XMP metadata is
* written into the output file. * written into the output file.
* *
* If @no_subsample is set, chrominance subsampling is disabled. This will * Chroma subsampling is normally automatically disabled for Q > 90. You can
* improve quality at the cost of larger file size. Useful for high Q factors. * force the subsampling mode with @@subsample_mode.
* *
* If @trellis_quant is set and the version of libjpeg supports it * If @trellis_quant is set and the version of libjpeg supports it
* (e.g. mozjpeg >= 3.0), apply trellis quantisation to each 8x8 block. * (e.g. mozjpeg >= 3.0), apply trellis quantisation to each 8x8 block.
@ -640,7 +645,7 @@ vips_jpegsave( VipsImage *in, const char *filename, ... )
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables * * @optimize_coding: %gboolean, compute optimal Huffman coding tables
* * @interlace: %gboolean, write an interlaced (progressive) jpeg * * @interlace: %gboolean, write an interlaced (progressive) jpeg
* * @strip: %gboolean, remove all metadata from image * * @strip: %gboolean, remove all metadata from image
* * @no_subsample: %gboolean, disable chroma subsampling * * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block * * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values * * @overshoot_deringing: %gboolean, overshoot samples with extreme values
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans * * @optimize_scans: %gboolean, split DCT coefficients into separate scans
@ -679,7 +684,7 @@ vips_jpegsave_target( VipsImage *in, VipsTarget *target, ... )
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables * * @optimize_coding: %gboolean, compute optimal Huffman coding tables
* * @interlace: %gboolean, write an interlaced (progressive) jpeg * * @interlace: %gboolean, write an interlaced (progressive) jpeg
* * @strip: %gboolean, remove all metadata from image * * @strip: %gboolean, remove all metadata from image
* * @no_subsample: %gboolean, disable chroma subsampling * * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block * * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values * * @overshoot_deringing: %gboolean, overshoot samples with extreme values
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans * * @optimize_scans: %gboolean, split DCT coefficients into separate scans
@ -735,7 +740,7 @@ vips_jpegsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables * * @optimize_coding: %gboolean, compute optimal Huffman coding tables
* * @interlace: %gboolean, write an interlaced (progressive) jpeg * * @interlace: %gboolean, write an interlaced (progressive) jpeg
* * @strip: %gboolean, remove all metadata from image * * @strip: %gboolean, remove all metadata from image
* * @no_subsample: %gboolean, disable chroma subsampling * * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block * * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values * * @overshoot_deringing: %gboolean, overshoot samples with extreme values
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans * * @optimize_scans: %gboolean, split DCT coefficients into separate scans

View File

@ -49,7 +49,7 @@ void vips__tiff_init( void );
int vips__tiff_write( VipsImage *in, const char *filename, int vips__tiff_write( VipsImage *in, const char *filename,
VipsForeignTiffCompression compression, int Q, VipsForeignTiffCompression compression, int Q,
VipsForeignTiffPredictor predictor, VipsForeignTiffPredictor predictor,
char *profile, char *profile,
gboolean tile, int tile_width, int tile_height, gboolean tile, int tile_width, int tile_height,
gboolean pyramid, gboolean pyramid,

View File

@ -92,6 +92,8 @@
* - ignore large XMP * - ignore large XMP
* 14/10/19 * 14/10/19
* - revise for target IO * - revise for target IO
* 18/2/20 Elad-Laufer
* - add subsample_mode, deprecate no_subsample
*/ */
/* /*
@ -481,7 +483,7 @@ write_vips( Write *write, int qfac, const char *profile,
gboolean optimize_coding, gboolean progressive, gboolean strip, gboolean optimize_coding, gboolean progressive, gboolean strip,
gboolean trellis_quant, gboolean overshoot_deringing, gboolean trellis_quant, gboolean overshoot_deringing,
gboolean optimize_scans, int quant_table, gboolean optimize_scans, int quant_table,
VipsForeignJpegSubsample subsample_mode) VipsForeignJpegSubsample subsample_mode )
{ {
VipsImage *in; VipsImage *in;
J_COLOR_SPACE space; J_COLOR_SPACE space;
@ -628,24 +630,15 @@ write_vips( Write *write, int qfac, const char *profile,
if( progressive ) if( progressive )
jpeg_simple_progression( &write->cinfo ); jpeg_simple_progression( &write->cinfo );
switch ( subsample_mode ) { if( subsample_mode == VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF ||
case VIPS_FOREIGN_JPEG_SUBSAMPLE_ON: (subsample_mode == VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO &&
break; qfac >= 90) ) {
case VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO: int i;
/* Turn off chroma subsampling. Follow IM and do it automatically for
* high Q. for( i = 0; i < in->Bands; i++ ) {
*/ write->cinfo.comp_info[i].h_samp_factor = 1;
if( qfac < 90 ) write->cinfo.comp_info[i].v_samp_factor = 1;
break; }
case VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF:
default:
{
int i;
for ( i = 0; i < in->Bands; i++ ) {
write->cinfo.comp_info[i].h_samp_factor = 1;
write->cinfo.comp_info[i].v_samp_factor = 1;
}
}
} }
/* Don't write the APP0 JFIF headers if we are stripping. /* Don't write the APP0 JFIF headers if we are stripping.
@ -783,8 +776,8 @@ vips__jpeg_write_target( VipsImage *in, VipsTarget *target,
int Q, const char *profile, int Q, const char *profile,
gboolean optimize_coding, gboolean progressive, gboolean optimize_coding, gboolean progressive,
gboolean strip, gboolean trellis_quant, gboolean strip, gboolean trellis_quant,
gboolean overshoot_deringing, gboolean optimize_scans, gboolean overshoot_deringing, gboolean optimize_scans,
int quant_table, VipsForeignJpegSubsample subsample_mode) int quant_table, VipsForeignJpegSubsample subsample_mode)
{ {
Write *write; Write *write;

View File

@ -369,11 +369,14 @@ int vips_openslideload( const char *filename, VipsImage **out, ... )
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO: default preset * @VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO: default preset
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_ON: always perform subsampling * @VIPS_FOREIGN_JPEG_SUBSAMPLE_ON: always perform subsampling
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF: never perform subsampling * @VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF: never perform subsampling
*
* Set jpeg subsampling mode.
*/ */
typedef enum { typedef enum {
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO, VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO,
VIPS_FOREIGN_JPEG_SUBSAMPLE_ON, VIPS_FOREIGN_JPEG_SUBSAMPLE_ON,
VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF,
VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST
} VipsForeignJpegSubsample; } VipsForeignJpegSubsample;
int vips_jpegload( const char *filename, VipsImage **out, ... ) int vips_jpegload( const char *filename, VipsImage **out, ... )

View File

@ -508,6 +508,7 @@ vips_foreign_jpeg_subsample_get_type( void )
{VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO, "VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO", "auto"}, {VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO, "VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO", "auto"},
{VIPS_FOREIGN_JPEG_SUBSAMPLE_ON, "VIPS_FOREIGN_JPEG_SUBSAMPLE_ON", "on"}, {VIPS_FOREIGN_JPEG_SUBSAMPLE_ON, "VIPS_FOREIGN_JPEG_SUBSAMPLE_ON", "on"},
{VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF, "VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF", "off"}, {VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF, "VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF", "off"},
{VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST, "VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST", "last"},
{0, NULL, NULL} {0, NULL, NULL}
}; };