get the CLI working again
get the cli working with the new vfunc thing
This commit is contained in:
parent
0b902bfbd4
commit
ff44680022
9
TODO
9
TODO
@ -1,6 +1,11 @@
|
|||||||
- test the vfunc system for CLI args
|
- perhaps we should have hard refs everywhere? it's very confusing having a
|
||||||
|
mxture :-( use vips_object_local() to make hard refs autounref
|
||||||
|
|
||||||
vips_object_new_from_string() is now very confusingly named
|
|
||||||
|
|
||||||
|
- try out:
|
||||||
|
|
||||||
|
http://incubator.quasimondo.com/processing/stackblur.pde
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1048,7 +1048,7 @@ vips_object_set_argument_from_string( VipsObject *object,
|
|||||||
g_assert( argument_class->flags & VIPS_ARGUMENT_INPUT );
|
g_assert( argument_class->flags & VIPS_ARGUMENT_INPUT );
|
||||||
|
|
||||||
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
||||||
(oclass = g_type_class_peek( otype )) &&
|
(oclass = g_type_class_ref( otype )) &&
|
||||||
oclass->new_from_string ) {
|
oclass->new_from_string ) {
|
||||||
VipsObject *object;
|
VipsObject *object;
|
||||||
|
|
||||||
@ -1118,7 +1118,7 @@ vips_object_get_argument_needs_string( VipsObject *object, const char *name )
|
|||||||
/* For now, only vipsobject subclasses can ask for args.
|
/* For now, only vipsobject subclasses can ask for args.
|
||||||
*/
|
*/
|
||||||
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
||||||
(oclass = g_type_class_peek( otype )) )
|
(oclass = g_type_class_ref( otype )) )
|
||||||
return( oclass->output_needs_arg );
|
return( oclass->output_needs_arg );
|
||||||
|
|
||||||
return( FALSE );
|
return( FALSE );
|
||||||
@ -1173,7 +1173,7 @@ vips_object_get_argument_to_string( VipsObject *object,
|
|||||||
g_assert( argument_class->flags & VIPS_ARGUMENT_OUTPUT );
|
g_assert( argument_class->flags & VIPS_ARGUMENT_OUTPUT );
|
||||||
|
|
||||||
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
if( g_type_is_a( otype, VIPS_TYPE_OBJECT ) &&
|
||||||
(oclass = g_type_class_peek( otype )) &&
|
(oclass = g_type_class_ref( otype )) &&
|
||||||
oclass->output_to_arg ) {
|
oclass->output_to_arg ) {
|
||||||
VipsObject *value;
|
VipsObject *value;
|
||||||
|
|
||||||
@ -1495,25 +1495,12 @@ vips_class_map_concrete_all( GType type, VipsClassMap fn, void *a )
|
|||||||
void *result;
|
void *result;
|
||||||
|
|
||||||
result = NULL;
|
result = NULL;
|
||||||
if( !G_TYPE_IS_ABSTRACT( type ) ) {
|
if( !G_TYPE_IS_ABSTRACT( type ) )
|
||||||
GTypeClass *class;
|
/* We never unref this ref, but we never unload classes
|
||||||
|
* anyway, so so what.
|
||||||
/* Does this class exist? Try to create if not.
|
|
||||||
*/
|
*/
|
||||||
if( !(class = g_type_class_peek( type )) )
|
result = fn( VIPS_OBJECT_CLASS( g_type_class_ref( type ) ), a );
|
||||||
/* We don't unref, so the class is never finalized.
|
|
||||||
* This will make the peek work next time around and
|
|
||||||
* save us from constantly building and destroying
|
|
||||||
* classes.
|
|
||||||
*/
|
|
||||||
if( !(class = g_type_class_ref( type )) ) {
|
|
||||||
vips_error( "VipsObject",
|
|
||||||
"%s", _( "unable to build class" ) );
|
|
||||||
return( NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
result = fn( VIPS_OBJECT_CLASS( class ), a );
|
|
||||||
}
|
|
||||||
if( !result )
|
if( !result )
|
||||||
result = vips_type_map( type,
|
result = vips_type_map( type,
|
||||||
(VipsTypeMap2) vips_class_map_concrete_all, fn, a );
|
(VipsTypeMap2) vips_class_map_concrete_all, fn, a );
|
||||||
|
@ -442,6 +442,10 @@ vips_region_new( VipsImage *image )
|
|||||||
return( NULL );
|
return( NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We return a hard reference, so unfloat it.
|
||||||
|
*/
|
||||||
|
g_object_ref_sink( region );
|
||||||
|
|
||||||
return( region );
|
return( region );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user