diff --git a/doc/reference/extending.xml b/doc/reference/extending.xml index 24b4940d..39ebf79a 100644 --- a/doc/reference/extending.xml +++ b/doc/reference/extending.xml @@ -364,6 +364,10 @@ if( negative( in, &out, "image_max", 128, NULL ) ) #VipsRect in _generate(). + + Make zero-copy operations, like vips_insert(), with vips_region_region(). + + diff --git a/doc/reference/using-C.xml b/doc/reference/using-C.xml index bd5d2548..5beb21ac 100644 --- a/doc/reference/using-C.xml +++ b/doc/reference/using-C.xml @@ -24,14 +24,14 @@ - When your program starts, use vips_init() to set up + When your program starts, use VIPS_INIT() to set up the VIPS library. You should pass it the name of your program, usually argv[0]. Use vips_shutdown() when you exit. - You can add the VIPS flags to your GObject command-line processing + You can add the VIPS flags to your %GObject command-line processing with vips_get_option_group(), see below. @@ -73,6 +73,13 @@ C-style memory array. See vips_image_write_to_file() and friends. + + Use #VipsRegion to read pixels out of images. You can use + VIPS_IMAGE_ADDR() as well, but this can need a large amount of + memory to work. See extending + for an introduxction to writing your own operations. + + VIPS keeps a log of error message, see VIPS Error to find out how to get and @@ -100,7 +107,7 @@ main( int argc, char **argv ) double mean; VipsImage *out; - if( vips_init( argv[0] ) ) + if( VIPS_INIT( argv[0] ) ) vips_error_exit( NULL ); context = g_option_context_new( "hello infile outfile - VIPS demo" ); diff --git a/libvips/arithmetic/add.c b/libvips/arithmetic/add.c index cc84a8f0..16a1a45a 100644 --- a/libvips/arithmetic/add.c +++ b/libvips/arithmetic/add.c @@ -200,7 +200,7 @@ vips_add_init( VipsAdd *add ) * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), then the + * arithmetic), then the * following table is used to determine the output type: * * diff --git a/libvips/arithmetic/boolean.c b/libvips/arithmetic/boolean.c index 4fab4f12..9c749c83 100644 --- a/libvips/arithmetic/boolean.c +++ b/libvips/arithmetic/boolean.c @@ -260,7 +260,7 @@ vips_booleanv( VipsImage *left, VipsImage *right, VipsImage **out, * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic). + * arithmetic). * * See also: vips_boolean_const(). * diff --git a/libvips/arithmetic/divide.c b/libvips/arithmetic/divide.c index b9ba7532..6242f53f 100644 --- a/libvips/arithmetic/divide.c +++ b/libvips/arithmetic/divide.c @@ -254,7 +254,7 @@ vips_divide_init( VipsDivide *divide ) * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), then the + * arithmetic), then the * following table is used to determine the output type: * *
diff --git a/libvips/arithmetic/math2.c b/libvips/arithmetic/math2.c index 740ea82f..6bc36093 100644 --- a/libvips/arithmetic/math2.c +++ b/libvips/arithmetic/math2.c @@ -247,7 +247,7 @@ vips_math2v( VipsImage *left, VipsImage *right, VipsImage **out, * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), and that format is the + * arithmetic), and that format is the * result type. * * See also: vips_math2_const(). diff --git a/libvips/arithmetic/multiply.c b/libvips/arithmetic/multiply.c index e3cbd730..e0b78ffd 100644 --- a/libvips/arithmetic/multiply.c +++ b/libvips/arithmetic/multiply.c @@ -200,7 +200,7 @@ vips_multiply_init( VipsMultiply *multiply ) * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), then the + * arithmetic), then the * following table is used to determine the output type: * *
diff --git a/libvips/arithmetic/relational.c b/libvips/arithmetic/relational.c index c12672d7..d9c78a04 100644 --- a/libvips/arithmetic/relational.c +++ b/libvips/arithmetic/relational.c @@ -270,7 +270,7 @@ vips_relationalv( VipsImage *left, VipsImage *right, VipsImage **out, * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic). + * arithmetic). * * To decide if pixels match exactly, that is have the same value in every * band, use vips_bandbool() after this operation to AND or OR image bands diff --git a/libvips/arithmetic/remainder.c b/libvips/arithmetic/remainder.c index 3abae74c..b208d621 100644 --- a/libvips/arithmetic/remainder.c +++ b/libvips/arithmetic/remainder.c @@ -207,7 +207,7 @@ vips_remainder_init( VipsRemainder *remainder ) * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), and that format is the + * arithmetic), and that format is the * result type. * * See also: vips_remainder_const(), vips_divide(), vips_round(). diff --git a/libvips/arithmetic/subtract.c b/libvips/arithmetic/subtract.c index 16ece78a..bf881baf 100644 --- a/libvips/arithmetic/subtract.c +++ b/libvips/arithmetic/subtract.c @@ -190,7 +190,7 @@ vips_subtract_init( VipsSubtract *subtract ) * * The two input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), then the + * arithmetic), then the * following table is used to determine the output type: * *
diff --git a/libvips/arithmetic/sum.c b/libvips/arithmetic/sum.c index 47e59097..0572ff44 100644 --- a/libvips/arithmetic/sum.c +++ b/libvips/arithmetic/sum.c @@ -179,7 +179,7 @@ vips_sumv( VipsImage **in, VipsImage **out, int n, va_list ap ) * @n: number of input images * @...: %NULL-terminated list of optional named arguments * - * This operation sums @in1 + @in2 and writes the result to @out. + * This operation sums all images in @in and writes the result to @out. * * If the images differ in size, the smaller images are enlarged to match the * largest by adding zero pixels along the bottom and right. @@ -191,7 +191,7 @@ vips_sumv( VipsImage **in, VipsImage **out, int n, va_list ap ) * * The input images are cast up to the smallest common format (see table * Smallest common format in - * arithmetic), then the + * arithmetic), then the * following table is used to determine the output type: * *
diff --git a/libvips/include/vips/internal.h b/libvips/include/vips/internal.h index ae39e7b7..71d9c485 100644 --- a/libvips/include/vips/internal.h +++ b/libvips/include/vips/internal.h @@ -104,6 +104,8 @@ extern gboolean vips__cache_trace; void vips__cache_init( void ); +void vips__print_renders( void ); + void vips__type_leak( void ); typedef int (*im__fftproc_fn)( VipsImage *, VipsImage *, VipsImage * ); diff --git a/libvips/include/vips/threadpool.h b/libvips/include/vips/threadpool.h index 46dd1e4e..236e5495 100644 --- a/libvips/include/vips/threadpool.h +++ b/libvips/include/vips/threadpool.h @@ -131,8 +131,6 @@ int vips_threadpool_run( VipsImage *im, void vips_get_tile_size( VipsImage *im, int *tile_width, int *tile_height, int *nlines ); -void vips__print_renders( void ); - void vips_concurrency_set( int concurrency ); int vips_concurrency_get( void ); diff --git a/libvips/include/vips/type.h b/libvips/include/vips/type.h index 83a5095e..5ec3278f 100644 --- a/libvips/include/vips/type.h +++ b/libvips/include/vips/type.h @@ -91,7 +91,6 @@ typedef struct _VipsArea { VipsArea *vips_area_copy( VipsArea *area ); void vips_area_unref( VipsArea *area ); -void vips__type_leak( void ); VipsArea *vips_area_new( VipsCallbackFn free_fn, void *data ); VipsArea *vips_area_new_blob( VipsCallbackFn free_fn, @@ -198,8 +197,6 @@ int vips_value_set_array_object( GValue *value, int n ); * vips_value_set_array_image(). They need to be declared after VipsImage. */ -void vips__meta_init_types( void ); - #ifdef __cplusplus } #endif /*__cplusplus*/ diff --git a/libvips/iofuncs/object.c b/libvips/iofuncs/object.c index 59ccb348..80f6f5da 100644 --- a/libvips/iofuncs/object.c +++ b/libvips/iofuncs/object.c @@ -105,11 +105,11 @@ * The stages inside vips_object_build() are: * * 1. Chain up through the object's @build class methods. At each stage, - * each object does any initial setup and checking, then chains up to its + * each class does any initial setup and checking, then chains up to its * superclass. * - * 2. The innermost @build method in #VipsObject itself checks that all input - * arguments have been set and then returns. + * 2. The innermost @build method inside #VipsObject itself checks that all + * input arguments have been set and then returns. * * 3. All object @build methods now finish executing, from innermost to * outermost. They know all input arguments have been checked and supplied, so @@ -120,7 +120,10 @@ * signal. #VipsObject::postbuild only runs if the object has constructed * successfuly. * - * And the stages inside close are: + * #VipsOperation has a cache of recent operation objects, see that class for + * an explanation of vips_cache_operation_build(). + * + * Finally the stages inside close are: * * 1. #VipsObject::preclose. This is emitted at the start of * the #VipsObject dispose. The object is still functioning. diff --git a/libvips/iofuncs/region.c b/libvips/iofuncs/region.c index 42152971..fdcd7656 100644 --- a/libvips/iofuncs/region.c +++ b/libvips/iofuncs/region.c @@ -158,12 +158,14 @@ * @X: x coordinate * @Y: y coordinate * - * This macro returns a pointer to a pixel in a region. The (x, y) coordinates - * need to be within the #VipsRect (@R->valid). + * This macro returns a pointer to a pixel in a region. The (@X, @Y) + * coordinates need to be within the #VipsRect (@R->valid). * * If DEBUG is defined, you get a version that checks bounds for you. * - * Returns: The address of pixel (x,y) in the region. + * See also: vips_region_prepare(). + * + * Returns: The address of pixel (@X,@Y) in @R. */ /** @@ -172,6 +174,8 @@ * * This macro returns a pointer to the top-left pixel in the #VipsRegion, that * is, the pixel at (@R->valid.left, @R->valid.top). + * + * See also: vips_region_prepare(). * * Returns: The address of the top-left pixel in the region. */ @@ -1090,11 +1094,10 @@ vips_region_generate( VipsRegion *reg ) * the calling thread, no new threads are involved, and computation * blocks until the pixels are ready. * - * Use vips_region_prepare_thread() to calculate an area of pixels with many - * threads. Use vips_sink_screen() to calculate an area of pixels in the + * Use vips_sink_screen() to calculate an area of pixels in the * background. * - * See also: vips_region_prepare_thread(), vips_sink_screen(), + * See also: vips_sink_screen(), * vips_region_prepare_to(). * * Returns: 0 on success, or -1 on error. diff --git a/libvips/iofuncs/type.c b/libvips/iofuncs/type.c index af7ff785..8206dd71 100644 --- a/libvips/iofuncs/type.c +++ b/libvips/iofuncs/type.c @@ -138,21 +138,6 @@ vips_thing_get_type( void ) return( type ); } -/** - * SECTION: VipsArea - * @short_description: an area of memory - * @stability: Stable - * @see_also: header, - * @include: vips/vips.h - * - * A VipsArea wraps a chunk of memory. It adds reference counting and a free - * function. It also keeps a count and a GType, so the area can be an array. - * - * This type is used for things like passing an array of double or an array of - * VipsObject pointers to operations, and for reference-counted immutable - * strings. - */ - static GSList *vips_area_all = NULL; VipsArea * @@ -227,8 +212,14 @@ vips_area_unref( VipsArea *area ) * @free_fn: (scope async): @data will be freed with this function * @data: data will be freed with this function * - * An area of memory with a free function. (eg. \0-terminated string, or a - * struct). Inital count == 1, so _unref() after attaching somewhere. + * A VipsArea wraps a chunk of memory. It adds reference counting and a free + * function. It also keeps a count and a %GType, so the area can be an array. + * + * This type is used for things like passing an array of double or an array of + * #VipsObject pointers to operations, and for reference-counted immutable + * strings. + * + * Inital count == 1, so _unref() after attaching somewhere. * * See also: vips_area_unref(). * @@ -313,7 +304,7 @@ vips_area_new_blob( VipsCallbackFn free_fn, void *data, size_t length ) * @sizeof_type: sizeof() an element in the array * @n: number of elements in the array * - * An area which holds an array of elements of some GType. To set values for + * An area which holds an array of elements of some %GType. To set values for * the elements, get the pointer and write. * * See also: vips_area_unref(). @@ -351,7 +342,7 @@ vips_area_free_array_object( GObject **array, VipsArea *area ) * vips_area_new_array_object: * @n: number of elements in the array * - * An area which holds an array of GObjects. See vips_area_new_array(). When + * An area which holds an array of %GObjects. See vips_area_new_array(). When * the area is freed, each %GObject will be unreffed. * * See also: vips_area_unref(). @@ -934,7 +925,7 @@ vips_value_set_save_stringf( GValue *value, const char *fmt, ... ) * @value: %GValue to get from * @length: (allow-none): return length here, optionally * - * Get the C string held internally by the GValue. + * Get the C string held internally by the %GValue. * * Returns: (transfer none): The C string held by @value. */ @@ -946,14 +937,14 @@ vips_value_get_ref_string( const GValue *value, size_t *length ) /** * vips_value_set_ref_string: - * @value: (out): GValue to set + * @value: (out): %GValue to set * @str: C string to copy into the GValue * * Copies the C string @str into @value. * * vips_ref_string are immutable C strings that are copied between images by * copying reference-counted pointers, making the much more efficient than - * regular GValue strings. + * regular %GValue strings. * * Returns: 0 on success, -1 otherwise. */ @@ -1353,7 +1344,7 @@ vips_value_get_array_object( const GValue *value, int *n ) * @value: (out): %GValue to set * @n: the number of elements * - * Set @value to hold an array of GObject. Pass in the array length in @n. + * Set @value to hold an array of %GObject. Pass in the array length in @n. * * See also: vips_array_object_get(). *