more docs argh

This commit is contained in:
John Cupitt 2014-08-19 17:57:27 +01:00
parent af84b3097c
commit 573b94e3ec
17 changed files with 56 additions and 51 deletions

View File

@ -364,6 +364,10 @@ if( negative( in, &out, "image_max", 128, NULL ) )
#VipsRect in _generate(). #VipsRect in _generate().
</para> </para>
<para>
Make zero-copy operations, like vips_insert(), with vips_region_region().
</para>
</refsect1> </refsect1>
</refentry> </refentry>

View File

@ -24,14 +24,14 @@
</para> </para>
<para> <para>
When your program starts, use <function>vips_init()</function> to set up When your program starts, use <function>VIPS_INIT()</function> to set up
the VIPS library. You should pass it the name of your program, usually the VIPS library. You should pass it the name of your program, usually
<literal>argv[0]</literal>. Use <function>vips_shutdown()</function> <literal>argv[0]</literal>. Use <function>vips_shutdown()</function>
when you exit. when you exit.
</para> </para>
<para> <para>
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. with vips_get_option_group(), see below.
</para> </para>
@ -73,6 +73,13 @@
C-style memory array. See vips_image_write_to_file() and friends. C-style memory array. See vips_image_write_to_file() and friends.
</para> </para>
<para>
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 <link linkend="extending">extending</link>
for an introduxction to writing your own operations.
</para>
<para> <para>
VIPS keeps a log of error message, see <link VIPS keeps a log of error message, see <link
linkend="libvips-error">VIPS Error</link> to find out how to get and linkend="libvips-error">VIPS Error</link> to find out how to get and
@ -100,7 +107,7 @@ main( int argc, char **argv )
double mean; double mean;
VipsImage *out; VipsImage *out;
if( vips_init( argv[0] ) ) if( VIPS_INIT( argv[0] ) )
vips_error_exit( NULL ); vips_error_exit( NULL );
context = g_option_context_new( "hello infile outfile - VIPS demo" ); context = g_option_context_new( "hello infile outfile - VIPS demo" );

View File

@ -200,7 +200,7 @@ vips_add_init( VipsAdd *add )
* *
* The two input images are cast up to the smallest common format (see table * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), then the * <link linkend="libvips-arithmetic">arithmetic</link>), then the
* following table is used to determine the output type: * following table is used to determine the output type:
* *
* <table> * <table>

View File

@ -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 * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>). * <link linkend="libvips-arithmetic">arithmetic</link>).
* *
* See also: vips_boolean_const(). * See also: vips_boolean_const().
* *

View File

@ -254,7 +254,7 @@ vips_divide_init( VipsDivide *divide )
* *
* The two input images are cast up to the smallest common format (see table * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), then the * <link linkend="libvips-arithmetic">arithmetic</link>), then the
* following table is used to determine the output type: * following table is used to determine the output type:
* *
* <table> * <table>

View File

@ -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 * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), and that format is the * <link linkend="libvips-arithmetic">arithmetic</link>), and that format is the
* result type. * result type.
* *
* See also: vips_math2_const(). * See also: vips_math2_const().

View File

@ -200,7 +200,7 @@ vips_multiply_init( VipsMultiply *multiply )
* *
* The two input images are cast up to the smallest common format (see table * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), then the * <link linkend="libvips-arithmetic">arithmetic</link>), then the
* following table is used to determine the output type: * following table is used to determine the output type:
* *
* <table> * <table>

View File

@ -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 * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>). * <link linkend="libvips-arithmetic">arithmetic</link>).
* *
* To decide if pixels match exactly, that is have the same value in every * 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 * band, use vips_bandbool() after this operation to AND or OR image bands

View File

@ -207,7 +207,7 @@ vips_remainder_init( VipsRemainder *remainder )
* *
* The two input images are cast up to the smallest common format (see table * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), and that format is the * <link linkend="libvips-arithmetic">arithmetic</link>), and that format is the
* result type. * result type.
* *
* See also: vips_remainder_const(), vips_divide(), vips_round(). * See also: vips_remainder_const(), vips_divide(), vips_round().

View File

@ -190,7 +190,7 @@ vips_subtract_init( VipsSubtract *subtract )
* *
* The two input images are cast up to the smallest common format (see table * The two input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), then the * <link linkend="libvips-arithmetic">arithmetic</link>), then the
* following table is used to determine the output type: * following table is used to determine the output type:
* *
* <table> * <table>

View File

@ -179,7 +179,7 @@ vips_sumv( VipsImage **in, VipsImage **out, int n, va_list ap )
* @n: number of input images * @n: number of input images
* @...: %NULL-terminated list of optional named arguments * @...: %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 * If the images differ in size, the smaller images are enlarged to match the
* largest by adding zero pixels along the bottom and right. * 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 * The input images are cast up to the smallest common format (see table
* Smallest common format in * Smallest common format in
* <link linkend="VIPS-arithmetic">arithmetic</link>), then the * <link linkend="libvips-arithmetic">arithmetic</link>), then the
* following table is used to determine the output type: * following table is used to determine the output type:
* *
* <table> * <table>

View File

@ -104,6 +104,8 @@ extern gboolean vips__cache_trace;
void vips__cache_init( void ); void vips__cache_init( void );
void vips__print_renders( void );
void vips__type_leak( void ); void vips__type_leak( void );
typedef int (*im__fftproc_fn)( VipsImage *, VipsImage *, VipsImage * ); typedef int (*im__fftproc_fn)( VipsImage *, VipsImage *, VipsImage * );

View File

@ -131,8 +131,6 @@ int vips_threadpool_run( VipsImage *im,
void vips_get_tile_size( VipsImage *im, void vips_get_tile_size( VipsImage *im,
int *tile_width, int *tile_height, int *nlines ); int *tile_width, int *tile_height, int *nlines );
void vips__print_renders( void );
void vips_concurrency_set( int concurrency ); void vips_concurrency_set( int concurrency );
int vips_concurrency_get( void ); int vips_concurrency_get( void );

View File

@ -91,7 +91,6 @@ typedef struct _VipsArea {
VipsArea *vips_area_copy( VipsArea *area ); VipsArea *vips_area_copy( VipsArea *area );
void vips_area_unref( 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( VipsCallbackFn free_fn, void *data );
VipsArea *vips_area_new_blob( VipsCallbackFn free_fn, 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. * vips_value_set_array_image(). They need to be declared after VipsImage.
*/ */
void vips__meta_init_types( void );
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /*__cplusplus*/ #endif /*__cplusplus*/

View File

@ -105,11 +105,11 @@
* The stages inside vips_object_build() are: * The stages inside vips_object_build() are:
* *
* 1. Chain up through the object's @build class methods. At each stage, * 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. * superclass.
* *
* 2. The innermost @build method in #VipsObject itself checks that all input * 2. The innermost @build method inside #VipsObject itself checks that all
* arguments have been set and then returns. * input arguments have been set and then returns.
* *
* 3. All object @build methods now finish executing, from innermost to * 3. All object @build methods now finish executing, from innermost to
* outermost. They know all input arguments have been checked and supplied, so * 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 * signal. #VipsObject::postbuild only runs if the object has constructed
* successfuly. * 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 * 1. #VipsObject::preclose. This is emitted at the start of
* the #VipsObject dispose. The object is still functioning. * the #VipsObject dispose. The object is still functioning.

View File

@ -158,12 +158,14 @@
* @X: x coordinate * @X: x coordinate
* @Y: y coordinate * @Y: y coordinate
* *
* This macro returns a pointer to a pixel in a region. The (x, y) coordinates * This macro returns a pointer to a pixel in a region. The (@X, @Y)
* need to be within the #VipsRect (@R->valid). * coordinates need to be within the #VipsRect (@R->valid).
* *
* If DEBUG is defined, you get a version that checks bounds for you. * 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 * This macro returns a pointer to the top-left pixel in the #VipsRegion, that
* is, the pixel at (@R->valid.left, @R->valid.top). * 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. * 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 * the calling thread, no new threads are involved, and computation
* blocks until the pixels are ready. * blocks until the pixels are ready.
* *
* Use vips_region_prepare_thread() to calculate an area of pixels with many * Use vips_sink_screen() to calculate an area of pixels in the
* threads. Use vips_sink_screen() to calculate an area of pixels in the
* background. * background.
* *
* See also: vips_region_prepare_thread(), vips_sink_screen(), * See also: vips_sink_screen(),
* vips_region_prepare_to(). * vips_region_prepare_to().
* *
* Returns: 0 on success, or -1 on error. * Returns: 0 on success, or -1 on error.

View File

@ -138,21 +138,6 @@ vips_thing_get_type( void )
return( type ); return( type );
} }
/**
* SECTION: VipsArea
* @short_description: an area of memory
* @stability: Stable
* @see_also: <link linkend="libvips-meta">header</link>,
* @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; static GSList *vips_area_all = NULL;
VipsArea * VipsArea *
@ -227,8 +212,14 @@ vips_area_unref( VipsArea *area )
* @free_fn: (scope async): @data will be freed with this function * @free_fn: (scope async): @data will be freed with this function
* @data: 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 * A VipsArea wraps a chunk of memory. It adds reference counting and a free
* struct). Inital count == 1, so _unref() after attaching somewhere. * 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(). * 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 * @sizeof_type: sizeof() an element in the array
* @n: number of elements 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. * the elements, get the pointer and write.
* *
* See also: vips_area_unref(). * See also: vips_area_unref().
@ -351,7 +342,7 @@ vips_area_free_array_object( GObject **array, VipsArea *area )
* vips_area_new_array_object: * vips_area_new_array_object:
* @n: number of elements in the array * @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. * the area is freed, each %GObject will be unreffed.
* *
* See also: vips_area_unref(). * See also: vips_area_unref().
@ -934,7 +925,7 @@ vips_value_set_save_stringf( GValue *value, const char *fmt, ... )
* @value: %GValue to get from * @value: %GValue to get from
* @length: (allow-none): return length here, optionally * @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. * 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: * vips_value_set_ref_string:
* @value: (out): GValue to set * @value: (out): %GValue to set
* @str: C string to copy into the GValue * @str: C string to copy into the GValue
* *
* Copies the C string @str into @value. * Copies the C string @str into @value.
* *
* vips_ref_string are immutable C strings that are copied between images by * vips_ref_string are immutable C strings that are copied between images by
* copying reference-counted pointers, making the much more efficient than * copying reference-counted pointers, making the much more efficient than
* regular GValue strings. * regular %GValue strings.
* *
* Returns: 0 on success, -1 otherwise. * 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 * @value: (out): %GValue to set
* @n: the number of elements * @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(). * See also: vips_array_object_get().
* *