Add some docs

This commit is contained in:
Matthias Clasen 2022-12-16 06:43:43 -05:00 committed by Behdad Esfahbod
parent 44c68594f1
commit 5afca91ff2
2 changed files with 196 additions and 78 deletions

View File

@ -184,7 +184,11 @@ HB_PAINT_FUNCS_IMPLEMENT_CALLBACKS
/** /**
* hb_paint_funcs_create: * hb_paint_funcs_create:
* *
* Returns value: (transfer full): * Creates a new #hb_paint_funcs_t structure of paint functions.
* Returns value: (transfer full): the paint-functions structure
*
* Since: REPLACEME
*/ */
hb_paint_funcs_t * hb_paint_funcs_t *
hb_paint_funcs_create () hb_paint_funcs_create ()
@ -209,12 +213,33 @@ DEFINE_NULL_INSTANCE (hb_paint_funcs_t) =
} }
}; };
/**
* hb_paint_funcs_reference: (skip)
* @funcs: The paint-functions structure
*
* Increases the reference count on a paint-functions structure.
*
* Return value: The paint-functions structure
*
* Since: REPLACEME
*/
hb_paint_funcs_t * hb_paint_funcs_t *
hb_paint_funcs_reference (hb_paint_funcs_t *funcs) hb_paint_funcs_reference (hb_paint_funcs_t *funcs)
{ {
return hb_object_reference (funcs); return hb_object_reference (funcs);
} }
/**
* hb_paint_funcs_destroy: (skip)
* @funcs: The paint-functions structure
*
* Decreases the reference count on a paint-functions structure.
*
* When the reference count reaches zero, the structure
* is destroyed, freeing all memory.
*
* Since: REPLACEME
*/
void void
hb_paint_funcs_destroy (hb_paint_funcs_t *funcs) hb_paint_funcs_destroy (hb_paint_funcs_t *funcs)
{ {
@ -233,6 +258,17 @@ hb_paint_funcs_destroy (hb_paint_funcs_t *funcs)
hb_free (funcs); hb_free (funcs);
} }
/**
* hb_paint_funcs_make_immutable:
* @funcs: The paint-functions structure
*
* Makes a paint-functions structure immutable.
*
* After this call, all attempts to set one of the callbacks
* on @funcs will fail.
*
* Since: REPLACEME
*/
void void
hb_paint_funcs_make_immutable (hb_paint_funcs_t *funcs) hb_paint_funcs_make_immutable (hb_paint_funcs_t *funcs)
{ {
@ -242,6 +278,16 @@ hb_paint_funcs_make_immutable (hb_paint_funcs_t *funcs)
hb_object_make_immutable (funcs); hb_object_make_immutable (funcs);
} }
/**
* hb_paint_funcs_is_immutable:
* @funcs: The paint-functions structure
*
* Tests whether a paint-functions structure is immutable.
*
* Return value: `true` if @funcs is immutable, `false` otherwise
*
* Since: REPLACEME
*/
hb_bool_t hb_bool_t
hb_paint_funcs_is_immutable (hb_paint_funcs_t *funcs) hb_paint_funcs_is_immutable (hb_paint_funcs_t *funcs)
{ {

View File

@ -85,16 +85,16 @@ hb_paint_funcs_is_immutable (hb_paint_funcs_t *funcs);
* a transform to subsequent paint calls. * a transform to subsequent paint calls.
* *
* This transform is applied after the current transform, * This transform is applied after the current transform,
* and remains in effect until a matching call to the * and remains in effect until a matching call to
* #hb_paint_funcs_pop_transform_func_t vfunc. * the #hb_paint_funcs_pop_transform_func_t vfunc.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
typedef void (*hb_paint_push_transform_func_t) (hb_paint_funcs_t *funcs, typedef void (*hb_paint_push_transform_func_t) (hb_paint_funcs_t *funcs,
void *paint_data, void *paint_data,
float xx, float xy, float xx, float yx,
float yx, float yy, float xy, float yy,
float x0, float y0, float dx, float dy,
void *user_data); void *user_data);
/** /**
@ -109,9 +109,9 @@ typedef void (*hb_paint_push_transform_func_t) (hb_paint_funcs_t *funcs,
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
typedef void (*hb_paint_pop_transform_func_t) (hb_paint_funcs_t *funcs, typedef void (*hb_paint_pop_transform_func_t) (hb_paint_funcs_t *funcs,
void *paint_data, void *paint_data,
void *user_data); void *user_data);
/** /**
* hb_paint_push_clip_glyph_func_t: * hb_paint_push_clip_glyph_func_t:
@ -126,9 +126,14 @@ typedef void (*hb_paint_pop_transform_func_t) (hb_paint_funcs_t *funcs,
* The coordinates of the glyph outline are interpreted according * The coordinates of the glyph outline are interpreted according
* to the current transform. * to the current transform.
* *
* Note that hb_font_paint_glyph() applies the scale and slant of
* the font as a transform, so you need to pass an unscaled, unslanted
* copy of the font to hb_font_get_glyph_shape() when obtaining outlines,
* to avoid double scaling.
*
* This clip is applied in addition to the current clip, * This clip is applied in addition to the current clip,
* and remains in effect until a matching call to the * and remains in effect until a matching call to
* #hb_paint_funcs_pop_clip_func_t vfunc. * the #hb_paint_funcs_pop_clip_func_t vfunc.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
@ -154,8 +159,8 @@ typedef void (*hb_paint_push_clip_glyph_func_t) (hb_paint_funcs_t *funcs,
* to the current transform. * to the current transform.
* *
* This clip is applied in addition to the current clip, * This clip is applied in addition to the current clip,
* and remains in effect until a matching call to the * and remains in effect until a matching call to
* #hb_paint_funcs_pop_clip_func_t vfunc. * the #hb_paint_funcs_pop_clip_func_t vfunc.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
@ -177,9 +182,9 @@ typedef void (*hb_paint_push_clip_rect_func_t) (hb_paint_funcs_t *funcs,
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
typedef void (*hb_paint_pop_clip_func_t) (hb_paint_funcs_t *funcs, typedef void (*hb_paint_pop_clip_func_t) (hb_paint_funcs_t *funcs,
void *paint_data, void *paint_data,
void *user_data); void *user_data);
/** /**
* hb_paint_solid_func_t: * hb_paint_solid_func_t:
@ -193,7 +198,7 @@ typedef void (*hb_paint_pop_clip_func_t) (hb_paint_funcs_t *funcs,
* color everywhere within the current clip. * color everywhere within the current clip.
* *
* The @color_index can be either an index into one of the fonts * The @color_index can be either an index into one of the fonts
* color palettes, or the special value #FFFF, which indicates that * color palettes, or the special value 0xFFFF, which indicates that
* the foreground color should be used. * the foreground color should be used.
* *
* In either case, the @alpha value should be applied in addition * In either case, the @alpha value should be applied in addition
@ -201,15 +206,35 @@ typedef void (*hb_paint_pop_clip_func_t) (hb_paint_funcs_t *funcs,
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
typedef void (*hb_paint_solid_func_t) (hb_paint_funcs_t *funcs, typedef void (*hb_paint_solid_func_t) (hb_paint_funcs_t *funcs,
void *paint_data, void *paint_data,
unsigned int color_index, unsigned int color_index,
float alpha, float alpha,
void *user_data); void *user_data);
/**
* hb_color_line_t:
*
* An opaque struct containing color information for a gradient.
*
* Since: REPLACEME
*/
typedef struct hb_color_line_t hb_color_line_t; typedef struct hb_color_line_t hb_color_line_t;
/**
* hb_color_stop_t:
* @offset: the offset of the color stop
* @color_index: either a color palette index or the special value 0xFFFF
* @alpha: alpha to apply
*
* Information about a color stop on a color line.
*
* Color lines typically have offsets ranging between 0 and 1,
* but that is not required.
*
* Since: REPLACEME
*/
typedef struct { typedef struct {
float offset; float offset;
unsigned int color_index; unsigned int color_index;
@ -250,9 +275,9 @@ hb_color_line_get_extend (hb_color_line_t *color_line);
* The coordinates of the points are interpreted according * The coordinates of the points are interpreted according
* to the current transform. * to the current transform.
* *
* See the OpenType spec COLR section (FIXME link) for details on how the * See the OpenType spec COLR section (https://learn.microsoft.com/en-us/typography/opentype/spec/colr)
* points define the direction of the gradient, and how * for details on how the points define the direction of the
* to interpret the @color_line. * gradient, and how to interpret the @color_line.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
@ -283,9 +308,9 @@ typedef void (*hb_paint_linear_gradient_func_t) (hb_paint_funcs_t *funcs,
* The coordinates of the points are interpreted according * The coordinates of the points are interpreted according
* to the current transform. * to the current transform.
* *
* See the OpenType spec COLR section (FIXME link) for details on how the * See the OpenType spec COLR section (https://learn.microsoft.com/en-us/typography/opentype/spec/colr)
* points define the direction of the gradient, and how * for details on how the points define the direction of the
* to interpret the @color_line. * gradient, and how to interpret the @color_line.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
@ -313,9 +338,9 @@ typedef void (*hb_paint_radial_gradient_func_t) (hb_paint_funcs_t *funcs,
* The coordinates of the points are interpreted according * The coordinates of the points are interpreted according
* to the current transform. * to the current transform.
* *
* See the OpenType spec COLR section (FIXME link) for details on how the * See the OpenType spec COLR section (https://learn.microsoft.com/en-us/typography/opentype/spec/colr)
* points define the direction of the gradient, and how * for details on how the points define the direction of the
* to interpret the @color_line. * gradient, and how to interpret the @color_line.
* *
* Since: REPLACEME * Since: REPLACEME
*/ */
@ -401,10 +426,14 @@ typedef void (*hb_paint_pop_group_func_t) (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_push_transform_func: * hb_paint_funcs_set_push_transform_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The push-transform callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the push-transform callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_push_transform_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_push_transform_func (hb_paint_funcs_t *funcs,
@ -414,10 +443,14 @@ hb_paint_funcs_set_push_transform_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_pop_transform_func: * hb_paint_funcs_set_pop_transform_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The pop-transform callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the pop-transform callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_pop_transform_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_pop_transform_func (hb_paint_funcs_t *funcs,
@ -427,10 +460,14 @@ hb_paint_funcs_set_pop_transform_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_push_clip_glyph_func: * hb_paint_funcs_set_push_clip_glyph_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The push-clip-glyph callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the push-clip-glyph callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_push_clip_glyph_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_push_clip_glyph_func (hb_paint_funcs_t *funcs,
@ -440,10 +477,14 @@ hb_paint_funcs_set_push_clip_glyph_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_push_clip_rect_func: * hb_paint_funcs_set_push_clip_rect_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The push-clip-rect callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the push-clip-rect callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_push_clip_rect_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_push_clip_rect_func (hb_paint_funcs_t *funcs,
@ -453,10 +494,14 @@ hb_paint_funcs_set_push_clip_rect_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_pop_clip_func: * hb_paint_funcs_set_pop_clip_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The pop-clip callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the pop-clip callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_pop_clip_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_pop_clip_func (hb_paint_funcs_t *funcs,
@ -466,10 +511,14 @@ hb_paint_funcs_set_pop_clip_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_solid_func: * hb_paint_funcs_set_solid_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The paint-solid callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the paint-solid callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_solid_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_solid_func (hb_paint_funcs_t *funcs,
@ -479,10 +528,14 @@ hb_paint_funcs_set_solid_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_linear_gradient_func: * hb_paint_funcs_set_linear_gradient_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The linear-gradient callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the linear-gradient callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_linear_gradient_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_linear_gradient_func (hb_paint_funcs_t *funcs,
@ -492,10 +545,14 @@ hb_paint_funcs_set_linear_gradient_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_radial_gradient_func: * hb_paint_funcs_set_radial_gradient_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The radial-gradient callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the radial-gradient callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_radial_gradient_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_radial_gradient_func (hb_paint_funcs_t *funcs,
@ -505,10 +562,14 @@ hb_paint_funcs_set_radial_gradient_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_sweep_gradient_func: * hb_paint_funcs_set_sweep_gradient_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The sweep-gradient callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the sweep-gradient callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_sweep_gradient_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_sweep_gradient_func (hb_paint_funcs_t *funcs,
@ -518,10 +579,14 @@ hb_paint_funcs_set_sweep_gradient_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_push_group_func: * hb_paint_funcs_set_push_group_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The push-group callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the push-group callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_push_group_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_push_group_func (hb_paint_funcs_t *funcs,
@ -531,10 +596,14 @@ hb_paint_funcs_set_push_group_func (hb_paint_funcs_t *funcs,
/** /**
* hb_paint_funcs_set_pop_group_func: * hb_paint_funcs_set_pop_group_func:
* @funcs: * @funcs: A paint functions struct
* @func: (closure user_data) (destroy destroy) (scope notified): * @func: (closure user_data) (destroy destroy) (scope notified): The pop-group callback
* @user_data: * @user_data: Data to pass to @func
* @destroy: (nullable) * @destroy: (nullable): Function to call when @user_data is no longer needed
*
* Sets the pop-group callback on the paint functions struct.
*
* Since: REPLACEME
*/ */
HB_EXTERN void HB_EXTERN void
hb_paint_funcs_set_pop_group_func (hb_paint_funcs_t *funcs, hb_paint_funcs_set_pop_group_func (hb_paint_funcs_t *funcs,
@ -557,7 +626,8 @@ hb_paint_push_clip_glyph (hb_paint_funcs_t *funcs, void *paint_data,
HB_EXTERN void HB_EXTERN void
hb_paint_push_clip_rect (hb_paint_funcs_t *funcs, void *paint_data, hb_paint_push_clip_rect (hb_paint_funcs_t *funcs, void *paint_data,
float xmin, float ymin, float xmax, float ymax); float xmin, float ymin,
float xmax, float ymax);
HB_EXTERN void HB_EXTERN void
hb_paint_pop_clip (hb_paint_funcs_t *funcs, void *paint_data); hb_paint_pop_clip (hb_paint_funcs_t *funcs, void *paint_data);
@ -577,8 +647,10 @@ hb_paint_linear_gradient (hb_paint_funcs_t *funcs, void *paint_data,
HB_EXTERN void HB_EXTERN void
hb_paint_radial_gradient (hb_paint_funcs_t *funcs, void *paint_data, hb_paint_radial_gradient (hb_paint_funcs_t *funcs, void *paint_data,
hb_color_line_t *color_line, hb_color_line_t *color_line,
float x0, float y0, float r0, float x0, float y0,
float x1, float y1, float r1); float r0,
float x1, float y1,
float r1);
HB_EXTERN void HB_EXTERN void
hb_paint_sweep_gradient (hb_paint_funcs_t *funcs, void *paint_data, hb_paint_sweep_gradient (hb_paint_funcs_t *funcs, void *paint_data,