Avoid using vips7 symbols

This commit is contained in:
Kleis Auke Wolthuizen 2020-06-18 14:21:43 +02:00
parent 230d2acfea
commit 8abcae3abc
6 changed files with 166 additions and 75 deletions

View File

@ -1168,7 +1168,7 @@ vips__rad_save( VipsImage *in, VipsTarget *target )
#endif /*DEBUG*/ #endif /*DEBUG*/
if( vips_image_pio_input( in ) || if( vips_image_pio_input( in ) ||
vips_check_coding_rad( "vips2rad", in ) ) vips_check_coding( "vips2rad", in, VIPS_CODING_RAD ) )
return( -1 ); return( -1 );
if( !(write = write_new( in, target )) ) if( !(write = write_new( in, target )) )
return( -1 ); return( -1 );

View File

@ -98,7 +98,10 @@
#include <vips/thread.h> #include <vips/thread.h>
#include <vips/internal.h> #include <vips/internal.h>
#include <vips/vector.h> #include <vips/vector.h>
#if VIPS_ENABLE_DEPRECATED
#include <vips/vips7compat.h> #include <vips/vips7compat.h>
#endif
/* abort() on the first warning or error. /* abort() on the first warning or error.
*/ */
@ -312,6 +315,32 @@ set_stacksize( guint64 size )
#endif /*HAVE_PTHREAD_DEFAULT_NP*/ #endif /*HAVE_PTHREAD_DEFAULT_NP*/
} }
static void
vips_verbose( void )
{
/* Older glibs were showing G_LOG_LEVEL_{INFO,DEBUG} messages
* by default
*/
#if GLIB_CHECK_VERSION ( 2, 31, 0 )
const char *old;
old = g_getenv( "G_MESSAGES_DEBUG" );
if( !old ) {
g_setenv( "G_MESSAGES_DEBUG", G_LOG_DOMAIN, TRUE );
}
else if( !g_str_equal( old, "all" ) &&
!g_strrstr( old, G_LOG_DOMAIN ) ) {
char *new;
new = g_strconcat( old, " ", G_LOG_DOMAIN, NULL );
g_setenv( "G_MESSAGES_DEBUG", new, TRUE );
g_free( new );
}
#endif /*GLIB_CHECK_VERSION( 2, 31, 0 )*/
}
/** /**
* vips_init: * vips_init:
* @argv0: name of application * @argv0: name of application
@ -440,7 +469,7 @@ vips_init( const char *argv0 )
#else #else
if( g_getenv( "VIPS_INFO" ) ) if( g_getenv( "VIPS_INFO" ) )
#endif #endif
vips_info_set( TRUE ); vips_verbose();
if( g_getenv( "VIPS_PROFILE" ) ) if( g_getenv( "VIPS_PROFILE" ) )
vips_profile_set( TRUE ); vips_profile_set( TRUE );
if( g_getenv( "VIPS_LEAK" ) ) if( g_getenv( "VIPS_LEAK" ) )
@ -466,7 +495,10 @@ vips_init( const char *argv0 )
(void) vips_target_custom_get_type(); (void) vips_target_custom_get_type();
vips__meta_init_types(); vips__meta_init_types();
vips__interpolate_init(); vips__interpolate_init();
#if VIPS_ENABLE_DEPRECATED
im__format_init(); im__format_init();
#endif
/* Start up operator cache. /* Start up operator cache.
*/ */
@ -499,6 +531,7 @@ vips_init( const char *argv0 )
(void) vips_load_plugins( "%s/vips-plugins-%d.%d", (void) vips_load_plugins( "%s/vips-plugins-%d.%d",
libdir, VIPS_MAJOR_VERSION, VIPS_MINOR_VERSION ); libdir, VIPS_MAJOR_VERSION, VIPS_MINOR_VERSION );
#if VIPS_ENABLE_DEPRECATED
/* Load up any vips7 plugins in the vips libdir. We don't error on /* Load up any vips7 plugins in the vips libdir. We don't error on
* failure, it's too annoying to have VIPS refuse to start because of * failure, it's too annoying to have VIPS refuse to start because of
* a broken plugin. * a broken plugin.
@ -516,6 +549,7 @@ vips_init( const char *argv0 )
g_warning( "%s", vips_error_buffer() ); g_warning( "%s", vips_error_buffer() );
vips_error_clear(); vips_error_clear();
} }
#endif
/* Get the run-time compiler going. /* Get the run-time compiler going.
*/ */
@ -554,7 +588,7 @@ vips_init( const char *argv0 )
#else #else
if( g_getenv( "VIPS_WARNING" ) ) if( g_getenv( "VIPS_WARNING" ) )
#endif #endif
g_log_set_handler( "VIPS", G_LOG_LEVEL_WARNING, g_log_set_handler( G_LOG_DOMAIN, G_LOG_LEVEL_WARNING,
empty_log_handler, NULL ); empty_log_handler, NULL );
/* Set a minimum stacksize, if we can. /* Set a minimum stacksize, if we can.
@ -659,7 +693,9 @@ vips_shutdown( void )
vips_cache_drop_all(); vips_cache_drop_all();
#if VIPS_ENABLE_DEPRECATED
im_close_plugins(); im_close_plugins();
#endif
/* Mustn't run this more than once. Don't use the VIPS_GATE macro, /* Mustn't run this more than once. Don't use the VIPS_GATE macro,
* since we don't for gate start. * since we don't for gate start.
@ -717,7 +753,7 @@ static gboolean
vips_lib_info_cb( const gchar *option_name, const gchar *value, vips_lib_info_cb( const gchar *option_name, const gchar *value,
gpointer data, GError **error ) gpointer data, GError **error )
{ {
vips_info_set( TRUE ); vips_verbose();
return( TRUE ); return( TRUE );
} }

View File

@ -43,26 +43,29 @@
#include <vips/internal.h> #include <vips/internal.h>
#include <vips/transform.h> #include <vips/transform.h>
/* DBL_MIN is smallest *normalized* double precision float */
#define TOO_SMALL 2.0 * DBL_MIN
/* Calculate the inverse transformation. /* Calculate the inverse transformation.
*/ */
int int
vips__transform_calc_inverse( VipsTransformation *trn ) vips__transform_calc_inverse( VipsTransformation *trn )
{ {
DOUBLEMASK *msk, *msk2; double det = trn->a * trn->d - trn->b * trn->c;
if( !(msk = im_create_dmaskv( "boink", 2, 2, if( fabs( det ) < TOO_SMALL ) {
trn->a, trn->b, trn->c, trn->d )) ) /* divisor is near zero */
return( -1 ); vips_error( "vips__transform_calc_inverse",
if( !(msk2 = im_matinv( msk, "boink2" )) ) { "%s", _( "singular or near-singular matrix" ) );
(void) im_free_dmask( msk );
return( -1 ); return( -1 );
} }
trn->ia = msk2->coeff[0];
trn->ib = msk2->coeff[1]; double tmp = 1.0 / det;
trn->ic = msk2->coeff[2];
trn->id = msk2->coeff[3]; trn->ia = tmp * trn->d;
(void) im_free_dmask( msk ); trn->ib = -tmp * trn->b;
(void) im_free_dmask( msk2 ); trn->ic = -tmp * trn->c;
trn->id = tmp * trn->a;
return( 0 ); return( 0 );
} }

View File

@ -8,6 +8,8 @@ from helpers import assert_equal_objects
class TestIofuncs: class TestIofuncs:
# test the vips7 filename splitter ... this is very fragile and annoying # test the vips7 filename splitter ... this is very fragile and annoying
# code with lots of cases # code with lots of cases
@pytest.mark.xfail(raises=AttributeError, reason="uses deprecated symbols")
def test_split7(self): def test_split7(self):
def split(path): def split(path):
filename7 = pyvips.path_filename7(path) filename7 = pyvips.path_filename7(path)

View File

@ -42,6 +42,9 @@
* - parse options in two passes (thanks Haida) * - parse options in two passes (thanks Haida)
* 26/11/17 * 26/11/17
* - remove throw() decls, they are now deprecated everywhere * - remove throw() decls, they are now deprecated everywhere
* 18/6/20 kleisauke
* - avoid using vips7 symbols
* - remove deprecated vips7 C++ generator
*/ */
/* /*
@ -92,9 +95,12 @@
#include <locale.h> #include <locale.h>
#include <vips/vips.h> #include <vips/vips.h>
#include <vips/vips7compat.h>
#include <vips/internal.h> #include <vips/internal.h>
#if VIPS_ENABLE_DEPRECATED
#include <vips/vips7compat.h>
#endif
#ifdef OS_WIN32 #ifdef OS_WIN32
#define strcasecmp(a,b) _stricmp(a,b) #define strcasecmp(a,b) _stricmp(a,b)
#endif #endif
@ -180,6 +186,7 @@ static GOptionEntry main_option[] = {
{ NULL } { NULL }
}; };
#if VIPS_ENABLE_DEPRECATED
typedef void *(*map_name_fn)( im_function * ); typedef void *(*map_name_fn)( im_function * );
/* Loop over a package. /* Loop over a package.
@ -241,13 +248,18 @@ list_function( im_function *func )
return( NULL ); return( NULL );
} }
#endif
static int static int
print_list( int argc, char **argv ) print_list( int argc, char **argv )
{ {
#if VIPS_ENABLE_DEPRECATED
if( !argv[0] || strcmp( argv[0], "packages" ) == 0 ) if( !argv[0] || strcmp( argv[0], "packages" ) == 0 )
im_map_packages( (VSListMap2Fn) list_package, NULL ); im_map_packages( (VSListMap2Fn) list_package, NULL );
else if( strcmp( argv[0], "classes" ) == 0 ) else if( strcmp( argv[0], "classes" ) == 0 )
#else
if( !argv[0] || strcmp( argv[0], "classes" ) == 0 )
#endif
vips_type_map_all( g_type_from_name( "VipsObject" ), vips_type_map_all( g_type_from_name( "VipsObject" ),
(VipsTypeMapFn) list_class, NULL ); (VipsTypeMapFn) list_class, NULL );
else if( g_type_from_name( argv[0] ) && else if( g_type_from_name( argv[0] ) &&
@ -256,13 +268,18 @@ print_list( int argc, char **argv )
(VipsTypeMapFn) list_class, NULL ); (VipsTypeMapFn) list_class, NULL );
} }
else { else {
#if VIPS_ENABLE_DEPRECATED
if( map_name( argv[0], list_function ) ) if( map_name( argv[0], list_function ) )
vips_error_exit( "unknown package \"%s\"", argv[0] ); vips_error_exit( "unknown package \"%s\"", argv[0] );
#else
vips_error_exit( "unknown operation \"%s\"", argv[0] );
#endif
} }
return( 0 ); return( 0 );
} }
#if VIPS_ENABLE_DEPRECATED
/* Print "ln -s" lines for this package. /* Print "ln -s" lines for this package.
*/ */
static void * static void *
@ -301,6 +318,7 @@ has_print( im_function *fn )
return( 0 ); return( 0 );
} }
#endif
static int static int
isvips( const char *name ) isvips( const char *name )
@ -313,6 +331,7 @@ isvips( const char *name )
return( vips_isprefix( "vips", name ) ); return( vips_isprefix( "vips", name ) );
} }
#if VIPS_ENABLE_DEPRECATED
/* Print a usage string from an im_function descriptor. /* Print a usage string from an im_function descriptor.
*/ */
static void static void
@ -382,6 +401,7 @@ usage( im_function *fn )
fprintf( stderr, "\n" ); fprintf( stderr, "\n" );
} }
#endif
static int static int
print_help( int argc, char **argv ) print_help( int argc, char **argv )
@ -406,10 +426,16 @@ static GOptionEntry empty_options[] = {
}; };
static ActionEntry actions[] = { static ActionEntry actions[] = {
#if VIPS_ENABLE_DEPRECATED
{ "list", N_( "list classes|packages|all|package-name|operation-name" ), { "list", N_( "list classes|packages|all|package-name|operation-name" ),
#else
{ "list", N_( "list classes|all|operation-name" ),
#endif
&empty_options[0], print_list }, &empty_options[0], print_list },
#if VIPS_ENABLE_DEPRECATED
{ "links", N_( "generate links for vips/bin" ), { "links", N_( "generate links for vips/bin" ),
&empty_options[0], print_links }, &empty_options[0], print_links },
#endif
{ "help", N_( "list possible actions" ), { "help", N_( "list possible actions" ),
&empty_options[0], print_help }, &empty_options[0], print_help },
}; };
@ -489,14 +515,16 @@ main( int argc, char **argv )
GOptionGroup *main_group; GOptionGroup *main_group;
GOptionGroup *group; GOptionGroup *group;
VipsOperation *operation; VipsOperation *operation;
#if VIPS_ENABLE_DEPRECATED
im_function *fn; im_function *fn;
#endif
int i, j; int i, j;
gboolean handled; gboolean handled;
GError *error = NULL; GError *error = NULL;
if( VIPS_INIT( argv[0] ) ) if( VIPS_INIT( argv[0] ) )
vips_error_exit( NULL ); vips_error_exit( NULL );
textdomain( GETTEXT_PACKAGE ); textdomain( GETTEXT_PACKAGE );
setlocale( LC_ALL, "" ); setlocale( LC_ALL, "" );
@ -575,8 +603,18 @@ main( int argc, char **argv )
; ;
if( main_option_plugin ) { if( main_option_plugin ) {
#if VIPS_ENABLE_DEPRECATED
if( !im_load_plugin( main_option_plugin ) ) if( !im_load_plugin( main_option_plugin ) )
vips_error_exit( NULL ); vips_error_exit( NULL );
#else /*!VIPS_ENABLE_DEPRECATED*/
GModule *module;
module = g_module_open( main_option_plugin, G_MODULE_BIND_LAZY );
if( !module ) {
vips_error_exit( _( "unable to load \"%s\" -- %s" ),
main_option_plugin, g_module_error() );
}
#endif
} }
if( main_option_version ) if( main_option_version )
@ -634,6 +672,7 @@ main( int argc, char **argv )
break; break;
} }
#if VIPS_ENABLE_DEPRECATED
/* Could be a vips7 im_function. We need to test for vips7 first, /* Could be a vips7 im_function. We need to test for vips7 first,
* since we don't want to use the vips7 compat wrappers in vips8 * since we don't want to use the vips7 compat wrappers in vips8
* unless we have to. They don't support all args types. * unless we have to. They don't support all args types.
@ -656,6 +695,7 @@ main( int argc, char **argv )
if( action && if( action &&
!handled ) !handled )
vips_error_clear(); vips_error_clear();
#endif
/* Could be a vips8 VipsOperation. /* Could be a vips8 VipsOperation.
*/ */

View File

@ -1,21 +1,23 @@
/* modify vips file header! - useful for setting resolution, coding... /* modify vips file header! - useful for setting resolution, coding...
very dangerous! * very dangerous!
no way of setting non-used codes in variables like newxres *
so need flags to show new parameter has been set.. boring * no way of setting non-used codes in variables like newxres
Copyright K.Martinez 30/6/93 * so need flags to show new parameter has been set.. boring
29/7/93 JC * Copyright K.Martinez 30/6/93
-format added *
- ==0 added to strcmp! * 29/7/93 JC
17/11/94 JC * - format added
- new header fields added * - ==0 added to strcmp!
21/10/04 * 17/11/94 JC
- more header updates * - new header fields added
* 21/10/04
22/8/05 * - more header updates
- less-stupid-ified * 22/8/05
20/9/05 * - less-stupid-ified
- rewritten with glib option parser, ready for xml options to go in * 20/9/05
* - rewritten with glib option parser, ready for xml options to go in
* 18/6/20 kleisauke
* - avoid using vips7 symbols
*/ */
/* /*
@ -59,7 +61,6 @@ Copyright K.Martinez 30/6/93
#include <locale.h> #include <locale.h>
#include <vips/vips.h> #include <vips/vips.h>
#include <vips/vips7compat.h>
#include <vips/internal.h> #include <vips/internal.h>
#include <vips/debug.h> #include <vips/debug.h>
@ -119,8 +120,8 @@ parse_pint( char *arg, int *out )
/* Might as well set an upper limit. /* Might as well set an upper limit.
*/ */
*out = atoi( arg ); *out = atoi( arg );
if( *out <= 0 || *out > 1000000 ) if( *out <= 0 || *out > 1000000 )
error_exit( _( "'%s' is not a positive integer" ), arg ); vips_error_exit( _( "'%s' is not a positive integer" ), arg );
} }
int int
@ -129,8 +130,8 @@ main( int argc, char **argv )
GOptionContext *context; GOptionContext *context;
GOptionGroup *main_group; GOptionGroup *main_group;
GError *error = NULL; GError *error = NULL;
IMAGE *im; VipsImage *im;
unsigned char header[IM_SIZEOF_HEADER]; unsigned char header[VIPS_SIZEOF_HEADER];
if( VIPS_INIT( argv[0] ) ) if( VIPS_INIT( argv[0] ) )
vips_error_exit( "%s", _( "unable to start VIPS" ) ); vips_error_exit( "%s", _( "unable to start VIPS" ) );
@ -158,10 +159,7 @@ main( int argc, char **argv )
if( !g_option_context_parse( context, &argc, &argv, &error ) ) if( !g_option_context_parse( context, &argc, &argv, &error ) )
#endif /*HAVE_G_WIN32_GET_COMMAND_LINE*/ #endif /*HAVE_G_WIN32_GET_COMMAND_LINE*/
{ {
if( error ) { vips_g_error( &error );
fprintf( stderr, "%s\n", error->message );
g_error_free( error );
}
exit( -1 ); exit( -1 );
} }
@ -178,12 +176,14 @@ main( int argc, char **argv )
exit( -1 ); exit( -1 );
} }
if( !(im = im_init( argv[1] )) || if( !(im = vips_image_new_from_file( argv[1], NULL )) )
(im->fd = im__open_image_file( im->filename )) == -1 ) vips_error_exit( _( "could not open image %s" ), argv[1] );
error_exit( _( "could not open image %s" ), argv[1] );
if( read( im->fd, header, IM_SIZEOF_HEADER ) != IM_SIZEOF_HEADER || vips__seek( im->fd, 0, SEEK_SET );
im__read_header_bytes( im, header ) ) if( read( im->fd, header, VIPS_SIZEOF_HEADER ) !=
error_exit( _( "could not read VIPS header for %s" ), VIPS_SIZEOF_HEADER ||
vips__read_header_bytes( im, header ) )
vips_error_exit( _( "could not read VIPS header for %s" ),
im->filename ); im->filename );
if( endian ) { if( endian ) {
@ -191,8 +191,8 @@ main( int argc, char **argv )
im->magic = VIPS_MAGIC_INTEL; im->magic = VIPS_MAGIC_INTEL;
else if( strcmp( endian, "big" ) == 0 ) else if( strcmp( endian, "big" ) == 0 )
im->magic = VIPS_MAGIC_SPARC; im->magic = VIPS_MAGIC_SPARC;
else else
error_exit( _( "bad endian-ness %s, " vips_error_exit( _( "bad endian-ness %s, "
"should be 'big' or 'little'" ), endian ); "should be 'big' or 'little'" ), endian );
} }
if( xsize ) if( xsize )
@ -202,26 +202,36 @@ main( int argc, char **argv )
if( bands ) if( bands )
parse_pint( bands, &im->Bands ); parse_pint( bands, &im->Bands );
if( format ) { if( format ) {
VipsBandFormat f; int f;
if( (f = vips_enum_from_nick( argv[0],
VIPS_TYPE_BAND_FORMAT, format )) < 0 )
vips_error_exit( _( "bad format %s" ), format );
if( (f = im_char2BandFmt( format )) < 0 )
error_exit( _( "bad format %s" ), format );
im->BandFmt = f; im->BandFmt = f;
im->Bbits = im_bits_of_fmt( f );
/* We don't use this, but make sure it's set in case any
* old binaries are expecting it.
*/
im->Bbits = vips_format_sizeof( f ) << 3;
} }
if( interpretation ) { if( interpretation ) {
VipsInterpretation i; int i;
if( (i = im_char2Type( interpretation )) < 0 ) if( (i = vips_enum_from_nick( argv[0],
error_exit( _( "bad interpretation %s" ), VIPS_TYPE_INTERPRETATION, interpretation )) < 0 )
vips_error_exit( _( "bad interpretation %s" ),
interpretation ); interpretation );
im->Type = i; im->Type = i;
} }
if( coding ) { if( coding ) {
VipsCoding c; int c;
if( (c = vips_enum_from_nick( argv[0],
VIPS_TYPE_CODING, coding )) < 0 )
vips_error_exit( _( "bad coding %s" ), coding );
if( (c = im_char2Coding( coding )) < 0 )
error_exit( _( "bad coding %s" ), coding );
im->Coding = c; im->Coding = c;
} }
if( xres ) if( xres )
@ -233,31 +243,31 @@ main( int argc, char **argv )
if( yoffset ) if( yoffset )
im->Yoffset = atoi( yoffset ); im->Yoffset = atoi( yoffset );
if( lseek( im->fd, 0, SEEK_SET ) == (off_t) -1 ) if( vips__seek( im->fd, 0, SEEK_SET ) == (off_t) -1 )
error_exit( _( "could not seek on %s" ), im->filename ); vips_error_exit( _( "could not seek on %s" ), im->filename );
if( im__write_header_bytes( im, header ) || if( vips__write_header_bytes( im, header ) ||
im__write( im->fd, header, IM_SIZEOF_HEADER ) ) vips__write( im->fd, header, VIPS_SIZEOF_HEADER ) )
error_exit( _( "could not write to %s" ), im->filename ); vips_error_exit( _( "could not write to %s" ), im->filename );
if( setext ) { if( setext ) {
char *xml; char *xml;
size_t size; size_t size;
if( !(xml = im__file_read( stdin, "stdin", &size )) ) if( !(xml = vips__file_read( stdin, "stdin", &size )) )
error_exit( "%s", _( "could not get ext data" ) ); vips_error_exit( "%s", _( "could not get ext data" ) );
/* Strip trailing whitespace ... we can get stray \n at the /* Strip trailing whitespace ... we can get stray \n at the
* end, eg. "echo | editvips --setext fred.v". * end, eg. "echo | vipsedit --setext fred.v".
*/ */
while( size > 0 && isspace( xml[size - 1] ) ) while( size > 0 && isspace( xml[size - 1] ) )
size -= 1; size -= 1;
if( im__write_extension_block( im, xml, size ) ) if( vips__write_extension_block( im, xml, size ) )
error_exit( "%s", _( "could not set extension" ) ); vips_error_exit( "%s", _( "could not set extension" ) );
im_free( xml ); g_free( xml );
} }
im_close( im ); g_object_unref( im );
/* We don't free this on error exit, sadly. /* We don't free this on error exit, sadly.
*/ */