diff --git a/ChangeLog b/ChangeLog index b89486e6..3bd61884 100644 --- a/ChangeLog +++ b/ChangeLog @@ -15,6 +15,7 @@ 2/8/17 started 8.5.8 - fix transparency detection in merge, thanks Haida +- define env var VIPS_WARNING to hide warning messages 9/6/17 started 8.5.7 - better smartcrop diff --git a/libvips/convolution/conva.c b/libvips/convolution/conva.c index 2b3a48bd..49aed0aa 100644 --- a/libvips/convolution/conva.c +++ b/libvips/convolution/conva.c @@ -79,9 +79,9 @@ $ vips im_max abs.v */ /* - */ #define DEBUG #define VIPS_DEBUG + */ #ifdef HAVE_CONFIG_H #include diff --git a/libvips/iofuncs/init.c b/libvips/iofuncs/init.c index 13a25611..ce66d620 100644 --- a/libvips/iofuncs/init.c +++ b/libvips/iofuncs/init.c @@ -26,6 +26,8 @@ * constructed before we go parallel * 18/9/16 * - call _setmaxstdio() on win32 + * 4/8/17 + * - hide warnings is VIPS_WARNING is set */ /* @@ -241,6 +243,15 @@ vips_load_plugins( const char *fmt, ... ) return( result ); } +/* Install this log handler to hide warning messages. + */ +static void +empty_log_handler( const gchar *log_domain, GLogLevelFlags log_level, + const gchar *message, gpointer user_data ) +{ +} + + /** * vips_init: * @argv0: name of application @@ -441,6 +452,18 @@ vips_init( const char *argv0 ) done = TRUE; + /* If VIPS_WARNING is defined, suppress all warning messages from vips. + * + * Libraries should not call g_log_set_handler(), it is + * supposed to be for the application layer, but this can be awkward to + * set up if you are using libvips from something like Ruby. Allow this + * env var hack as a workaround. + */ + if( g_getenv( "VIPS_WARNING" ) || + g_getenv( "IM_WARNING" ) ) + g_log_set_handler( "VIPS", G_LOG_LEVEL_WARNING, + empty_log_handler, NULL ); + vips__thread_gate_stop( "init: startup" ); return( 0 );