From b12d5f8205c0a3981745dae11acd25d147b6f4a1 Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Fri, 21 Oct 2016 12:32:04 +0100 Subject: [PATCH 1/3] comment typo --- libvips/conversion/bandbool.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libvips/conversion/bandbool.c b/libvips/conversion/bandbool.c index 86385048..d26c5d7d 100644 --- a/libvips/conversion/bandbool.c +++ b/libvips/conversion/bandbool.c @@ -186,7 +186,7 @@ vips_bandbool_buffer( VipsBandary *bandary, #define D VIPS_FORMAT_DOUBLE #define DX VIPS_FORMAT_DPCOMPLEX -/* Type conversions for boolean. +/* Format conversions for boolean. */ static const VipsBandFormat vips_bandbool_format_table[10] = { /* UC C US S UI I F X D DX */ From a7edd235c4874438b2952df7602de14c2eb6a777 Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Fri, 28 Oct 2016 16:25:31 +0100 Subject: [PATCH 2/3] improve compat with ancient glibs and fix a tiny threading leak --- ChangeLog | 2 ++ libvips/include/vips/internal.h | 2 ++ libvips/iofuncs/buffer.c | 2 +- libvips/iofuncs/init.c | 3 +++ libvips/iofuncs/threadpool.c | 29 +++++++++++++++++++++++------ 5 files changed, 31 insertions(+), 7 deletions(-) diff --git a/ChangeLog b/ChangeLog index 941a8f26..90d493d4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,7 @@ 18/10/16 started 8.4.3 - fix error detection in gif_close, thanks aaron42net +- fix tiny threading memleak +- improve compatibility with very old glib, see #548 27/9/16 started 8.4.2 - small doc improvements diff --git a/libvips/include/vips/internal.h b/libvips/include/vips/internal.h index 6d32afa2..8ad38485 100644 --- a/libvips/include/vips/internal.h +++ b/libvips/include/vips/internal.h @@ -102,6 +102,8 @@ extern char *vips__cache_max_files; extern gboolean vips__cache_dump; extern gboolean vips__cache_trace; +void vips__threadpool_init( void ); + void vips__cache_init( void ); void vips__print_renders( void ); diff --git a/libvips/iofuncs/buffer.c b/libvips/iofuncs/buffer.c index 23e450ad..a5af8fe2 100644 --- a/libvips/iofuncs/buffer.c +++ b/libvips/iofuncs/buffer.c @@ -712,7 +712,7 @@ buffer_thread_destroy_notify( VipsBufferThread *buffer_thread ) buffer_thread_free( buffer_thread ); } -/* Init the buffer cache system. +/* Init the buffer cache system. This is called during vips_init. */ void vips__buffer_init( void ) diff --git a/libvips/iofuncs/init.c b/libvips/iofuncs/init.c index fb492808..2a576544 100644 --- a/libvips/iofuncs/init.c +++ b/libvips/iofuncs/init.c @@ -302,6 +302,9 @@ vips_init( const char *argv0 ) g_thread_init( NULL ); #endif + vips__threadpool_init(); + vips__buffer_init(); + /* This does an unsynchronised static hash table init on first call -- * we have to make sure we do this single-threaded. See: * https://github.com/openslide/openslide/issues/161 diff --git a/libvips/iofuncs/threadpool.c b/libvips/iofuncs/threadpool.c index 860690c6..c39b593f 100644 --- a/libvips/iofuncs/threadpool.c +++ b/libvips/iofuncs/threadpool.c @@ -101,7 +101,7 @@ int vips__concurrency = 0; /* Set this GPrivate to indicate that this is a vips worker. */ -static GPrivate vips_threadpool_is_worker_private; +static GPrivate *is_worker_key = NULL; /* Glib 2.32 revised the thread API. We need some compat functions. */ @@ -165,7 +165,7 @@ vips_g_cond_free( GCond *cond ) gboolean vips_thread_isworker( void ) { - return( g_private_get( &vips_threadpool_is_worker_private ) != NULL ); + return( g_private_get( is_worker_key ) != NULL ); } typedef struct { @@ -181,12 +181,12 @@ vips_thread_run( gpointer data ) void *result; - if( vips__thread_profile ) - vips__thread_profile_attach( info->domain ); - /* Set this to something (anything) to tag this thread as a vips worker. */ - g_private_set( &vips_threadpool_is_worker_private, data ); + g_private_set( is_worker_key, data ); + + if( vips__thread_profile ) + vips__thread_profile_attach( info->domain ); result = info->func( info->data ); @@ -940,6 +940,23 @@ vips_threadpool_run( VipsImage *im, return( result ); } +/* Start up threadpools. This is called during vips_init. + */ +void +vips__threadpool_init( void ) +{ + /* We need to work with the pre-2.32 threading API. + */ +#ifdef HAVE_PRIVATE_INIT + static GPrivate private = { 0 }; + + is_worker_key = &private; +#else + if( !is_worker_key ) + is_worker_key = g_private_new( NULL ); +#endif +} + /** * vips_get_tile_size: * @im: image to guess for From c0ab8b0ab198dadce71246727328c193b229fe37 Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Fri, 28 Oct 2016 16:49:02 +0100 Subject: [PATCH 3/3] fix a warning from the test suite we were trying to save greyscale PNGs with an RGB profile --- test/test_foreign.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/test/test_foreign.py b/test/test_foreign.py index 61de9ce0..bbbe2104 100755 --- a/test/test_foreign.py +++ b/test/test_foreign.py @@ -58,9 +58,13 @@ class TestForeign(unittest.TestCase): self.colour = Vips.Image.jpegload(self.jpeg_file) self.mono = self.colour.extract_band(1) + # we remove the ICC profile: the RGB one will no longer be appropriate + self.mono.remove("icc-profile-data") self.rad = self.colour.float2rad() + self.rad.remove("icc-profile-data") self.cmyk = self.colour.bandjoin(self.mono) self.cmyk = self.cmyk.copy(interpretation = Vips.Interpretation.CMYK) + self.cmyk.remove("icc-profile-data") im = Vips.Image.new_from_file(self.gif_file) self.onebit = im > 128