fix up VipsPool
vipspool working, test program in ~/try, passes valgrind
This commit is contained in:
parent
22326059ec
commit
e99f6cc49e
@ -9,6 +9,7 @@
|
|||||||
- VipsMin stops search early if it can
|
- VipsMin stops search early if it can
|
||||||
- C API supports optional output args
|
- C API supports optional output args
|
||||||
- switch back to int-valued operations
|
- switch back to int-valued operations
|
||||||
|
- fix up VipsPool
|
||||||
|
|
||||||
10/8/11 started 7.26.3
|
10/8/11 started 7.26.3
|
||||||
- don't use G_VALUE_COLLECT_INIT(), many platforms do not have a glib this
|
- don't use G_VALUE_COLLECT_INIT(), many platforms do not have a glib this
|
||||||
|
3
TODO
3
TODO
@ -1,6 +1,3 @@
|
|||||||
- revise vipspool, write a test prog
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
- could we generate the code for vips_add() automatically? it might be nice to
|
- could we generate the code for vips_add() automatically? it might be nice to
|
||||||
|
@ -60,6 +60,10 @@ typedef struct _VipsPool {
|
|||||||
/* A table of all the contexts we've seen.
|
/* A table of all the contexts we've seen.
|
||||||
*/
|
*/
|
||||||
GHashTable *contexts;
|
GHashTable *contexts;
|
||||||
|
|
||||||
|
/* Track a name for debugging.
|
||||||
|
*/
|
||||||
|
const char *name;
|
||||||
} VipsPool;
|
} VipsPool;
|
||||||
|
|
||||||
typedef struct _VipsPoolClass {
|
typedef struct _VipsPoolClass {
|
||||||
@ -72,12 +76,12 @@ VipsPool *vips_pool_new( const char *name );
|
|||||||
VipsPoolContext *vips_pool_context_new( VipsPool *pool );
|
VipsPoolContext *vips_pool_context_new( VipsPool *pool );
|
||||||
GObject **vips_pool_context_object( VipsPoolContext *context, int n );
|
GObject **vips_pool_context_object( VipsPoolContext *context, int n );
|
||||||
|
|
||||||
/* Save some typing.
|
/* Save some typing. This assumes you have a (VipsPoolContext *) called
|
||||||
|
* "context" in scope.
|
||||||
*/
|
*/
|
||||||
#define VIPS_VAR_IMAGE_REF( N ) \
|
#define VIPS_VI( N ) \
|
||||||
((VipsImage **) vips_pool_context_object( context, (N) ))
|
(*((VipsImage **) vips_pool_context_object( context, (N) )))
|
||||||
#define VIPS_VAR_IMAGE( N ) \
|
|
||||||
(*((VipsImage **) vips_pool_context_object( context, (N) )))
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -28,9 +28,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#define DEBUG
|
|
||||||
#define VIPS_DEBUG
|
#define VIPS_DEBUG
|
||||||
#define DEBUG_REF
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
@ -83,16 +81,16 @@
|
|||||||
{
|
{
|
||||||
VipsPoolContext *context = vips_pool_context_new( pool );
|
VipsPoolContext *context = vips_pool_context_new( pool );
|
||||||
|
|
||||||
if( vips_add( in1, in2, VIPS_VAR_IMAGE_REF( 1 ), NULL ) ||
|
if( vips_add( in1, in2, &VIPS_VI( 1 ), NULL ) ||
|
||||||
vips_add( in1, VIPS_VAR_IMAGE( 1 ), out, NULL ) )
|
vips_add( in1, VIPS_VI( 1 ), out, NULL ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
vips_pool_context_new() creates a new context to hold a set of temporary
|
vips_pool_context_new() creates a new context to hold a set of temporary
|
||||||
objects. You can get a reference to a temporary image object with the
|
objects. You can get a pointer to a temporary image object with the
|
||||||
macro VIPS_VAR_IMAGE_REF(), and get the object with VIPS_VAR_IMAGE().
|
macro VIPS_VI() (this assumes there is a variable called "context" in scope).
|
||||||
Temporary objects are numbered from zero.
|
Temporary objects are numbered from zero.
|
||||||
|
|
||||||
Our caller will (eventually) call g_object_unref() on the pool and this
|
Our caller will (eventually) call g_object_unref() on the pool and this
|
||||||
@ -118,10 +116,23 @@ vips_pool_dispose( GObject *gobject )
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
vips_pool_context_print( VipsPoolContext *context, VipsBuf *buf )
|
vips_pool_context_print( VipsPoolContext *context, VipsPoolContext *value,
|
||||||
|
VipsBuf *buf )
|
||||||
{
|
{
|
||||||
vips_buf_appendf( buf, "VipsPoolContext %p, %d objects\n",
|
int i, n;
|
||||||
context, context->len );
|
|
||||||
|
n = 0;
|
||||||
|
for( i = 0; i < context->len; i++ )
|
||||||
|
if( g_ptr_array_index( context, i ) )
|
||||||
|
n += 1;
|
||||||
|
|
||||||
|
vips_buf_appendf( buf, "VipsPoolContext %p, size %d, %d objects\n",
|
||||||
|
context, context->len, n );
|
||||||
|
|
||||||
|
for( i = 0; i < context->len; i++ )
|
||||||
|
if( g_ptr_array_index( context, i ) )
|
||||||
|
vips_buf_appendf( buf, "\t%p\n",
|
||||||
|
g_ptr_array_index( context, i ) ) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -166,7 +177,7 @@ vips_pool_new( const char *name )
|
|||||||
|
|
||||||
pool = VIPS_POOL( g_object_new( VIPS_TYPE_POOL, NULL ) );
|
pool = VIPS_POOL( g_object_new( VIPS_TYPE_POOL, NULL ) );
|
||||||
|
|
||||||
g_object_set( pool, "name", name, NULL );
|
pool->name = name;
|
||||||
|
|
||||||
if( vips_object_build( VIPS_OBJECT( pool ) ) ) {
|
if( vips_object_build( VIPS_OBJECT( pool ) ) ) {
|
||||||
VIPS_UNREF( pool );
|
VIPS_UNREF( pool );
|
||||||
@ -176,12 +187,22 @@ vips_pool_new( const char *name )
|
|||||||
return( pool );
|
return( pool );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
vips_pool_context_element_free( GObject *object )
|
||||||
|
{
|
||||||
|
if( object )
|
||||||
|
g_object_unref( object );
|
||||||
|
}
|
||||||
|
|
||||||
VipsPoolContext *
|
VipsPoolContext *
|
||||||
vips_pool_context_new( VipsPool *pool )
|
vips_pool_context_new( VipsPool *pool )
|
||||||
{
|
{
|
||||||
VipsPoolContext *context;
|
VipsPoolContext *context;
|
||||||
|
|
||||||
context = g_ptr_array_new_with_free_func( g_object_unref );
|
/* g_object_unref() hates unreffing NULL.
|
||||||
|
*/
|
||||||
|
context = g_ptr_array_new_with_free_func(
|
||||||
|
(GDestroyNotify) vips_pool_context_element_free );
|
||||||
g_hash_table_insert( pool->contexts, context, context );
|
g_hash_table_insert( pool->contexts, context, context );
|
||||||
|
|
||||||
return( context );
|
return( context );
|
||||||
|
Loading…
Reference in New Issue
Block a user