cpp can set enums from strings

eg.

	set("extend", "copy")->
This commit is contained in:
John Cupitt 2014-12-30 11:27:04 +00:00
parent 61cbba4605
commit 32625146db
6 changed files with 93 additions and 9 deletions

View File

@ -1,3 +1,6 @@
30/12/14 started 7.42.2
- allow c++ set enum from string
24/12/14 started 7.42.1 24/12/14 started 7.42.1
- add gobject-2.0 to Requires: in vips and vips-cpp .pc files - add gobject-2.0 to Requires: in vips and vips-cpp .pc files
- bump soname - bump soname

31
TODO
View File

@ -1,3 +1,34 @@
- display of optional params should show default value
also display possible enum values?
min and max for int/float params?
maybe:
$ vips embed
embed an image in a larger image
usage:
embed in out x y width height
where:
in - Input image, input VipsImage
out - Output image, output VipsImage
x - Left edge of input in output, input gint
(default: 0, min: -inf, max: inf)
y - Top edge of input in output, input gint
(default: 0, min: -inf, max: inf)
width - Image width in pixels, input gint
(default: 100, min: 0, max: inf)
height - Image height in pixels, input gint
(default: 100, min: 0, max: inf)
optional arguments:
extend - How to generate the extra pixels, input VipsExtend
(default: black, allowed: copy, extend, mirror)
background - Colour for background pixels, input VipsArrayDouble
(default: 0, min: 0, max: inf)
operation flags: sequential-unbuffered
- use vips_resize() in vipsthumbnail? - use vips_resize() in vipsthumbnail?
should the sharpening filter be selectable? should the sharpening filter be selectable?

View File

@ -2,7 +2,7 @@
# also update the version number in the m4 macros below # also update the version number in the m4 macros below
AC_INIT([vips], [7.42.1], [vipsip@jiscmail.ac.uk]) AC_INIT([vips], [7.42.2], [vipsip@jiscmail.ac.uk])
# required for gobject-introspection # required for gobject-introspection
AC_PREREQ(2.62) AC_PREREQ(2.62)
@ -18,7 +18,7 @@ AC_CONFIG_MACRO_DIR([m4])
# user-visible library versioning # user-visible library versioning
m4_define([vips_major_version], [7]) m4_define([vips_major_version], [7])
m4_define([vips_minor_version], [42]) m4_define([vips_minor_version], [42])
m4_define([vips_micro_version], [1]) m4_define([vips_micro_version], [2])
m4_define([vips_version], m4_define([vips_version],
[vips_major_version.vips_minor_version.vips_micro_version]) [vips_major_version.vips_minor_version.vips_micro_version])
@ -38,7 +38,7 @@ VIPS_VERSION_STRING=$VIPS_VERSION-`date`
# binary interface changes not backwards compatible?: reset age to 0 # binary interface changes not backwards compatible?: reset age to 0
LIBRARY_CURRENT=40 LIBRARY_CURRENT=40
LIBRARY_REVISION=0 LIBRARY_REVISION=1
LIBRARY_AGE=0 LIBRARY_AGE=0
# patched into include/vips/version.h # patched into include/vips/version.h

View File

@ -1,4 +1,8 @@
// Object part of VImage class /* Object part of VImage class
*
* 30/12/14
* - allow set enum value from string
*/
/* /*
@ -327,6 +331,47 @@ VOption::set( const char *name, VipsBlob **value )
return( this ); return( this );
} }
// just g_object_set_property(), except we allow set enum from string
static void
set_property( VipsObject *object, const char *name, const GValue *value )
{
VipsObjectClass *object_class = VIPS_OBJECT_GET_CLASS( object );
GType type = G_VALUE_TYPE( value );
GParamSpec *pspec;
VipsArgumentClass *argument_class;
VipsArgumentInstance *argument_instance;
if( vips_object_get_argument( object, name,
&pspec, &argument_class, &argument_instance ) ) {
vips_warn( NULL, "%s", vips_error_buffer() );
vips_error_clear();
return;
}
if( G_IS_PARAM_SPEC_ENUM( pspec ) &&
type == G_TYPE_STRING ) {
GType pspec_type = G_PARAM_SPEC_VALUE_TYPE( pspec );
int enum_value;
GValue value2 = { 0 };
if( (enum_value = vips_enum_from_nick( object_class->nickname,
pspec_type, g_value_get_string( value ) )) < 0 ) {
vips_warn( NULL, "%s", vips_error_buffer() );
vips_error_clear();
return;
}
g_value_init( &value2, pspec_type );
g_value_set_enum( &value2, enum_value );
g_object_set_property( G_OBJECT( object ), name, &value2 );
g_value_unset( &value2 );
}
else
g_object_set_property( G_OBJECT( object ), name, value );
}
// walk the options and set props on the operation // walk the options and set props on the operation
void void
VOption::set_operation( VipsOperation *operation ) VOption::set_operation( VipsOperation *operation )
@ -343,7 +388,7 @@ VOption::set_operation( VipsOperation *operation )
g_free( str_value ); g_free( str_value );
#endif /*VIPS_DEBUG_VERBOSE*/ #endif /*VIPS_DEBUG_VERBOSE*/
g_object_set_property( G_OBJECT( operation ), set_property( VIPS_OBJECT( operation ),
(*i)->name, &(*i)->value ); (*i)->name, &(*i)->value );
} }
} }

View File

@ -73,7 +73,7 @@ main( int argc, char **argv )
VImage out = in.embed( 10, 10, 1000, 1000, VImage out = in.embed( 10, 10, 1000, 1000,
VImage::option()-> VImage::option()->
set( "extend", VIPS_EXTEND_BACKGROUND )-> set( "extend", "background" )->
set( "background", 128 ) ); set( "background", 128 ) );
out.write_to_file( argv[2] ); out.write_to_file( argv[2] );
@ -113,7 +113,9 @@ main( int argc, char **argv )
<para> <para>
In this case we request unbuffered IO for the image, meaning, we In this case we request unbuffered IO for the image, meaning, we
expect to do a single top-to-bottom scan of the image and do not expect to do a single top-to-bottom scan of the image and do not
need it to be decompressed entirely. need it to be decompressed entirely. You can use the C enum name,
as is done in this case, or use a string and have the string
looked up. See below.
</para> </para>
<para> <para>
@ -197,7 +199,9 @@ VImage VImage::add( VImage right, VOption *options = 0 );
<para> <para>
The next line runs vips_embed() with two optional parameters. The first The next line runs vips_embed() with two optional parameters. The first
sets the value to an enum (you just use the ones from the C API), the sets the value to an enum (here we use a string to set the value, it'll
be looked up in the list of possible enum values, or you can use the
symbols from the C API), the
second sets the value to an <code>int</code>. The second sets the value to an <code>int</code>. The
<code>"background"</code> <code>"background"</code>
parameter is actually a #VipsArrayDouble: if you pass an parameter is actually a #VipsArrayDouble: if you pass an

View File

@ -206,6 +206,7 @@ vips_verror( const char *domain, const char *fmt, va_list ap )
g_mutex_lock( vips__global_lock ); g_mutex_lock( vips__global_lock );
g_assert( vips_error_freeze_count >= 0 ); g_assert( vips_error_freeze_count >= 0 );
if( !vips_error_freeze_count ) { if( !vips_error_freeze_count ) {
if( domain )
vips_buf_appendf( &vips_error_buf, "%s: ", domain ); vips_buf_appendf( &vips_error_buf, "%s: ", domain );
vips_buf_vappendf( &vips_error_buf, fmt, ap ); vips_buf_vappendf( &vips_error_buf, fmt, ap );
vips_buf_appends( &vips_error_buf, "\n" ); vips_buf_appends( &vips_error_buf, "\n" );