add nickname/description props to vipsobject

This commit is contained in:
John Cupitt 2009-01-22 15:46:02 +00:00
parent e6e948a743
commit 9727f9a6c1
5 changed files with 62 additions and 15 deletions

View File

@ -30,6 +30,7 @@
- IM_FREE() can do "const char*" variables - IM_FREE() can do "const char*" variables
- im_buf_t renamed as VipsBuf - im_buf_t renamed as VipsBuf
- added vips_object_to_string() - added vips_object_to_string()
- added "nickname" and "description" properties to VipsObject
11/9/08 started 7.16.3 11/9/08 started 7.16.3
- oop typo in manpage for im_project() - oop typo in manpage for im_project()

4
TODO
View File

@ -2,10 +2,6 @@
- try making vips_add(), an operator as a class - try making vips_add(), an operator as a class
- nickname, description etc need to be properties so nip2 can read them
arg, they are class properties, argh, can we support these?
- make a new package for "resample"? im_shrink & friends could go in there too - make a new package for "resample"? im_shrink & friends could go in there too
- make a "deprecated" package too - make a "deprecated" package too

View File

@ -179,6 +179,12 @@ struct _VipsObject {
/* Table of argument instances for this class and any derived classes. /* Table of argument instances for this class and any derived classes.
*/ */
VipsArgumentTable *argument_table; VipsArgumentTable *argument_table;
/* Class properties (see below), duplicated in the instance so we can
* get at them easily via the property system.
*/
char *nickname;
char *description;
}; };
struct _VipsObjectClass { struct _VipsObjectClass {

View File

@ -55,6 +55,14 @@ enum {
SIG_LAST SIG_LAST
}; };
/* Properties.
*/
enum {
PROP_NICKNAME, /* Class properties as object props */
PROP_DESCRIPTION,
PROP_LAST
};
static guint vips_object_signals[SIG_LAST] = { 0 }; static guint vips_object_signals[SIG_LAST] = { 0 };
G_DEFINE_ABSTRACT_TYPE( VipsObject, vips_object, G_TYPE_OBJECT ); G_DEFINE_ABSTRACT_TYPE( VipsObject, vips_object, G_TYPE_OBJECT );
@ -718,27 +726,29 @@ transform_string_double( const GValue *src_value, GValue *dest_value )
} }
static void static void
vips_object_class_init( VipsObjectClass *class ) vips_object_class_init( VipsObjectClass *object_class )
{ {
GObjectClass *gobject_class = G_OBJECT_CLASS( class ); GObjectClass *gobject_class = G_OBJECT_CLASS( object_class );
GParamSpec *pspec;
gobject_class->dispose = vips_object_dispose; gobject_class->dispose = vips_object_dispose;
gobject_class->finalize = vips_object_finalize; gobject_class->finalize = vips_object_finalize;
gobject_class->set_property = vips_object_set_property; gobject_class->set_property = vips_object_set_property;
gobject_class->get_property = vips_object_get_property; gobject_class->get_property = vips_object_get_property;
class->build = vips_object_real_build; object_class->build = vips_object_real_build;
class->changed = vips_object_real_changed; object_class->changed = vips_object_real_changed;
class->print_class = vips_object_real_print_class; object_class->print_class = vips_object_real_print_class;
class->print = vips_object_real_print; object_class->print = vips_object_real_print;
class->nickname = "object"; object_class->nickname = "object";
class->description = _( "VIPS base class" ); object_class->description = _( "VIPS base class" );
/* Table of VipsArgumentClass ... we can just g_free() them. /* Table of VipsArgumentClass ... we can just g_free() them.
*/ */
class->argument_table = g_hash_table_new_full( object_class->argument_table = g_hash_table_new_full(
g_direct_hash, g_direct_equal, NULL, (GDestroyNotify) g_free ); g_direct_hash, g_direct_equal, NULL, (GDestroyNotify) g_free );
class->argument_table_traverse = NULL; object_class->argument_table_traverse = NULL;
vips_object_signals[SIG_CHANGED] = g_signal_new( "changed", vips_object_signals[SIG_CHANGED] = g_signal_new( "changed",
G_OBJECT_CLASS_TYPE( gobject_class ), G_OBJECT_CLASS_TYPE( gobject_class ),
@ -752,15 +762,49 @@ vips_object_class_init( VipsObjectClass *class )
*/ */
g_value_register_transform_func( G_TYPE_STRING, G_TYPE_DOUBLE, g_value_register_transform_func( G_TYPE_STRING, G_TYPE_DOUBLE,
transform_string_double ); transform_string_double );
/* Create properties.
*/
pspec = g_param_spec_string( "nickname",
_( "Nickname" ),
_( "Class nickname" ),
"",
(GParamFlags) G_PARAM_READABLE );
g_object_class_install_property( gobject_class,
PROP_NICKNAME, pspec );
vips_object_class_install_argument( object_class, pspec,
VIPS_ARGUMENT_SET_ONCE,
G_STRUCT_OFFSET( VipsObject, nickname ) );
pspec = g_param_spec_string( "description",
_( "Description" ),
_( "Class description" ),
"",
(GParamFlags) G_PARAM_READABLE );
g_object_class_install_property( gobject_class,
PROP_DESCRIPTION, pspec );
vips_object_class_install_argument( object_class, pspec,
VIPS_ARGUMENT_SET_ONCE,
G_STRUCT_OFFSET( VipsObject, description ) );
} }
static void static void
vips_object_init( VipsObject *object ) vips_object_init( VipsObject *object )
{ {
VipsObjectClass *object_class = VIPS_OBJECT_GET_CLASS( object );
#ifdef DEBUG #ifdef DEBUG
printf( "vips_object_init: " ); printf( "vips_object_init: " );
vips_object_print( object ); vips_object_print( object );
#endif /*DEBUG*/ #endif /*DEBUG*/
/* It'd be nice if this just copied a pointer rather than did a
* strdup().
*/
g_object_set( object,
"nickname", object_class->nickname,
"description", object_class->description, NULL );
} }
void void

View File

@ -131,7 +131,7 @@
/* Properties. /* Properties.
*/ */
enum { enum {
PROP_SHARPENING = 1, PROP_SHARPENING,
PROP_LAST PROP_LAST
}; };