Merge branch '8.10'

This commit is contained in:
John Cupitt 2020-11-11 10:06:22 +00:00
commit 013e8beba7
5 changed files with 23 additions and 7 deletions

View File

@ -18,6 +18,7 @@
- fix tiffsave region shrink mode [imgifty] - fix tiffsave region shrink mode [imgifty]
- add missing flushes on write to target [harukizaemon] - add missing flushes on write to target [harukizaemon]
- hide info messages you could get with some older glibs [kleisauke] - hide info messages you could get with some older glibs [kleisauke]
- fix --no-strip on dzsave with icc-profiles [altert]
6/9/20 started 8.10.2 6/9/20 started 8.10.2
- update magicksave/load profile handling [kelilevi] - update magicksave/load profile handling [kelilevi]

View File

@ -613,8 +613,8 @@ write_image( VipsForeignSaveDz *dz,
if( vips_copy( image, &t, NULL ) ) if( vips_copy( image, &t, NULL ) )
return( -1 ); return( -1 );
/* We default to stripping all metadata. Only "no_strip" turns this /* We default to stripping all metadata. "no_strip" turns this
* off. Very few people really want metadata on every tile. * off. Most people don't want metadata on every tile.
*/ */
vips_image_set_int( t, "hide-progress", 1 ); vips_image_set_int( t, "hide-progress", 1 );
if( vips_image_write_to_buffer( t, format, &buf, &len, if( vips_image_write_to_buffer( t, format, &buf, &len,
@ -1312,6 +1312,13 @@ strip_init( Strip *strip, Layer *layer )
return; return;
} }
/* The strip needs to inherit the layer's metadata.
*/
if( vips__image_meta_copy( strip->image, layer->image ) ) {
strip_free( strip );
return;
}
/* Type needs to be set so we know how to convert for save correctly. /* Type needs to be set so we know how to convert for save correctly.
*/ */
strip->image->Type = layer->image->Type; strip->image->Type = layer->image->Type;

View File

@ -152,6 +152,7 @@ int vips__write_extension_block( VipsImage *im, void *buf, int size );
int vips__writehist( VipsImage *image ); int vips__writehist( VipsImage *image );
int vips__read_header_bytes( VipsImage *im, unsigned char *from ); int vips__read_header_bytes( VipsImage *im, unsigned char *from );
int vips__write_header_bytes( VipsImage *im, unsigned char *to ); int vips__write_header_bytes( VipsImage *im, unsigned char *to );
int vips__image_meta_copy( VipsImage *dst, const VipsImage *src );
extern GMutex *vips__global_lock; extern GMutex *vips__global_lock;

View File

@ -994,8 +994,8 @@ meta_cp_field( VipsMeta *meta, VipsImage *dst, void *b )
/* Copy meta on to dst. /* Copy meta on to dst.
*/ */
static int int
meta_cp( VipsImage *dst, const VipsImage *src ) vips__image_meta_copy( VipsImage *dst, const VipsImage *src )
{ {
if( src->meta ) { if( src->meta ) {
/* We lock with vips_image_set() to stop races in highly- /* We lock with vips_image_set() to stop races in highly-
@ -1051,7 +1051,7 @@ vips__image_copy_fields_array( VipsImage *out, VipsImage *in[] )
* subclass loaders will sometimes write to an image. * subclass loaders will sometimes write to an image.
*/ */
for( i = ni - 1; i >= 0; i-- ) for( i = ni - 1; i >= 0; i-- )
if( meta_cp( out, in[i] ) ) if( vips__image_meta_copy( out, in[i] ) )
return( -1 ); return( -1 );
/* Merge hists first to last. /* Merge hists first to last.
@ -1094,7 +1094,7 @@ vips_image_set( VipsImage *image, const char *name, GValue *value )
g_assert( value ); g_assert( value );
/* We lock between modifying metadata and copying metadata between /* We lock between modifying metadata and copying metadata between
* images, see meta_cp(). * images, see vips__image_meta_copy().
* *
* This prevents modification of metadata by one thread racing with * This prevents modification of metadata by one thread racing with
* metadata copy on another -- this can lead to crashes in * metadata copy on another -- this can lead to crashes in
@ -1302,7 +1302,7 @@ vips_image_remove( VipsImage *image, const char *name )
if( image->meta ) { if( image->meta ) {
/* We lock between modifying metadata and copying metadata /* We lock between modifying metadata and copying metadata
* between images, see meta_cp(). * between images, see vips__image_meta_copy().
* *
* This prevents modification of metadata by one thread * This prevents modification of metadata by one thread
* racing with metadata copy on another -- this can lead to * racing with metadata copy on another -- this can lead to

View File

@ -1026,6 +1026,13 @@ class TestForeign:
buf = self.colour.dzsave_buffer(region_shrink="mode") buf = self.colour.dzsave_buffer(region_shrink="mode")
buf = self.colour.dzsave_buffer(region_shrink="median") buf = self.colour.dzsave_buffer(region_shrink="median")
# test no-strip ... icc profiles should be passed down
filename = temp_filename(self.tempdir, '')
self.colour.dzsave(filename, no_strip=True)
y = pyvips.Image.new_from_file(filename + "_files/0/0_0.jpeg")
assert y.get_typeof("icc-profile-data") != 0
@skip_if_no("heifload") @skip_if_no("heifload")
def test_heifload(self): def test_heifload(self):
def heif_valid(im): def heif_valid(im):