Merge branch 'master' into add-tiff-webp-zstd

This commit is contained in:
John Cupitt 2019-07-11 13:50:47 +01:00
commit 044f8b74f6
3 changed files with 46 additions and 4 deletions

View File

@ -7,6 +7,9 @@
- add "compression" option to heifsave [lovell] - add "compression" option to heifsave [lovell]
- support webp and zstd compression in tiff - support webp and zstd compression in tiff
9/7/19 started 8.8.2
- better early shutdown in readers
24/5/19 started 8.8.1 24/5/19 started 8.8.1
- improve realpath() use on older libc - improve realpath() use on older libc
- better magickload error messages - better magickload error messages

View File

@ -171,7 +171,8 @@ vips_sequential_generate( VipsRegion *or,
return( -1 ); return( -1 );
} }
sequential->y_pos = VIPS_MAX( sequential->y_pos, VIPS_RECT_BOTTOM( r ) ); sequential->y_pos =
VIPS_MAX( sequential->y_pos, VIPS_RECT_BOTTOM( r ) );
g_mutex_unlock( sequential->lock ); g_mutex_unlock( sequential->lock );

View File

@ -45,6 +45,8 @@
* - rename yshrink -> vshrink for greater consistency * - rename yshrink -> vshrink for greater consistency
* 7/3/17 * 7/3/17
* - add a seq line cache * - add a seq line cache
* 9/7/19
* - read the tail of the input to force early shutdown in seq readers
*/ */
/* /*
@ -99,6 +101,7 @@ typedef struct _VipsShrinkv {
int vshrink; int vshrink;
size_t sizeof_line_buffer; size_t sizeof_line_buffer;
gboolean sequential;
} VipsShrinkv; } VipsShrinkv;
@ -265,6 +268,7 @@ vips_shrinkv_gen( VipsRegion *or, void *vseq,
{ {
VipsShrinkvSequence *seq = (VipsShrinkvSequence *) vseq; VipsShrinkvSequence *seq = (VipsShrinkvSequence *) vseq;
VipsShrinkv *shrink = (VipsShrinkv *) b; VipsShrinkv *shrink = (VipsShrinkv *) b;
VipsResample *resample = VIPS_RESAMPLE( shrink );
VipsRegion *ir = seq->ir; VipsRegion *ir = seq->ir;
VipsRect *r = &or->valid; VipsRect *r = &or->valid;
@ -315,6 +319,38 @@ vips_shrinkv_gen( VipsRegion *or, void *vseq,
VIPS_COUNT_PIXELS( or, "vips_shrinkv_gen" ); VIPS_COUNT_PIXELS( or, "vips_shrinkv_gen" );
/* If we are in seq mode and we've just generated the last line of
* the output, make sure we read all of the input.
*
* This will trigger the early shutdown logic in things like the
* tiff loader.
*/
if( shrink->sequential &&
r->top + r->height >= or->im->Ysize ) {
/* First unused scanline. resample->in->Ysize because we want
* the height before the embed.
*/
int first = or->im->Ysize * shrink->vshrink;
int unused = resample->in->Ysize - first;
g_assert( unused >= 0 );
for( y = 0; y < unused; y++ ) {
VipsRect s;
s.left = r->left;
s.top = first + y;
s.width = r->width;
s.height = 1;
#ifdef DEBUG
printf( "shrink_gen: requesting tail %d\n", s.top );
#endif /*DEBUG*/
if( vips_region_prepare( ir, &s ) )
return( -1 );
}
}
return( 0 ); return( 0 );
} }
@ -349,12 +385,12 @@ vips_shrinkv_build( VipsObject *object )
return( -1 ); return( -1 );
in = t[0]; in = t[0];
/* We need new pixels along the bottom so that we don't have small chunks /* Make the height a multiple of the shrink factor so we don't need to
* to average along the bottom edge. * average half pixels.
*/ */
if( vips_embed( in, &t[1], if( vips_embed( in, &t[1],
0, 0, 0, 0,
in->Xsize, in->Ysize + shrink->vshrink, in->Xsize, VIPS_ROUND_UP( in->Ysize, shrink->vshrink ),
"extend", VIPS_EXTEND_COPY, "extend", VIPS_EXTEND_COPY,
NULL ) ) NULL ) )
return( -1 ); return( -1 );
@ -415,6 +451,8 @@ vips_shrinkv_build( VipsObject *object )
if( vips_image_get_typeof( in, VIPS_META_SEQUENTIAL ) ) { if( vips_image_get_typeof( in, VIPS_META_SEQUENTIAL ) ) {
g_info( "shrinkv sequential line cache" ); g_info( "shrinkv sequential line cache" );
shrink->sequential = TRUE;
if( vips_sequential( in, &t[3], if( vips_sequential( in, &t[3],
"tile_height", 10, "tile_height", 10,
NULL ) ) NULL ) )