Some attempt into initial hb-shape documentation
Very anaemic, needs to descripe the format understood by hb_feature_from_string() etc., but it is just start.
This commit is contained in:
parent
81bedda58c
commit
d055e1fc78
|
@ -33,6 +33,17 @@
|
||||||
#include "hb-buffer-private.hh"
|
#include "hb-buffer-private.hh"
|
||||||
#include "hb-font-private.hh"
|
#include "hb-font-private.hh"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION:hb-shape
|
||||||
|
* @title: Shaping
|
||||||
|
* @short_description: Conversion of text strings into positioned glyphs
|
||||||
|
* @include: hb.h
|
||||||
|
*
|
||||||
|
* Shaping is the central operation of HarfBuzz. Shaping operates on buffers,
|
||||||
|
* which are sequences of Unicode characters that use the same font and have
|
||||||
|
* the same text direction, script and language. After shaping the buffer
|
||||||
|
* contains the output glyphs and their positions.
|
||||||
|
**/
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
parse_space (const char **pp, const char *end)
|
parse_space (const char **pp, const char *end)
|
||||||
|
@ -198,13 +209,14 @@ parse_one_feature (const char **pp, const char *end, hb_feature_t *feature)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_feature_from_string:
|
* hb_feature_from_string:
|
||||||
* @str: (array length=len) (element-type uint8_t):
|
* @str: (array length=len) (element-type uint8_t): a string to parse
|
||||||
* @len:
|
* @len: length of @str, or -1 if string is nul-terminated
|
||||||
* @feature: (out) (optional):
|
* @feature: (out): the #hb_feature_t to initialize with the parsed values
|
||||||
*
|
*
|
||||||
*
|
* Parses a string into a #hb_feature_t. If @len is -1 then @str is
|
||||||
|
* %NULL-terminated.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value: %true if @str is successfully parsed, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.0
|
* Since: 1.0
|
||||||
**/
|
**/
|
||||||
|
@ -231,11 +243,13 @@ hb_feature_from_string (const char *str, int len,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_feature_to_string:
|
* hb_feature_to_string:
|
||||||
* @feature:
|
* @feature: an #hb_feature_t to convert
|
||||||
* @buf: (array length=size):
|
* @buf: (array length=size) (out): output string
|
||||||
* @size:
|
* @size: the allocated size of @buf
|
||||||
*
|
*
|
||||||
*
|
* Converts a #hb_feature_t into a %NULL-terminated string in the format
|
||||||
|
* understood by hb_feature_from_string(). The client in responsible for
|
||||||
|
* allocating big enough size for @buf, 128 bytes is more than enough.
|
||||||
*
|
*
|
||||||
* Since: 1.0
|
* Since: 1.0
|
||||||
**/
|
**/
|
||||||
|
@ -290,9 +304,10 @@ void free_static_shaper_list (void)
|
||||||
/**
|
/**
|
||||||
* hb_shape_list_shapers:
|
* hb_shape_list_shapers:
|
||||||
*
|
*
|
||||||
*
|
* Retrieves the list of shapers supported by HarfBuzz.
|
||||||
*
|
*
|
||||||
* Return value: (transfer none):
|
* Return value: (transfer none) (array zero-terminated=1): an array of
|
||||||
|
* constant strings
|
||||||
*
|
*
|
||||||
* Since: 1.0
|
* Since: 1.0
|
||||||
**/
|
**/
|
||||||
|
@ -333,15 +348,19 @@ retry:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_shape_full:
|
* hb_shape_full:
|
||||||
* @font: a font.
|
* @font: an #hb_font_t to use for shaping
|
||||||
* @buffer: a buffer.
|
* @buffer: an #hb_buffer_t to shape
|
||||||
* @features: (array length=num_features):
|
* @features: (array length=num_features) (allow-none): an array of user
|
||||||
* @num_features:
|
* specified #hb_feature_t or %NULL
|
||||||
* @shaper_list: (array zero-terminated=1):
|
* @num_features: the length of @features array
|
||||||
|
* @shaper_list: (array zero-terminated=1) (allow-none): a %NULL-terminated
|
||||||
|
* array of shapers to use or %NULL
|
||||||
*
|
*
|
||||||
*
|
* See hb_shape() for details. If @shaper_list is not %NULL, the specified
|
||||||
|
* shapers will be used in the given order, otherwise the default shapers list
|
||||||
|
* will be used.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value: %false if all shapers failed, %true otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.0
|
* Since: 1.0
|
||||||
**/
|
**/
|
||||||
|
@ -368,12 +387,17 @@ hb_shape_full (hb_font_t *font,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_shape:
|
* hb_shape:
|
||||||
* @font: a font.
|
* @font: an #hb_font_t to use for shaping
|
||||||
* @buffer: a buffer.
|
* @buffer: an #hb_buffer_t to shape
|
||||||
* @features: (array length=num_features):
|
* @features: (array length=num_features) (allow-none): an array of user
|
||||||
* @num_features:
|
* specified #hb_feature_t or %NULL
|
||||||
|
* @num_features: the length of @features array
|
||||||
*
|
*
|
||||||
*
|
* Shapes @buffer using @font turning its Unicode characters content to
|
||||||
|
* positioned glyphs. If @features is not %NULL, it will be used to control the
|
||||||
|
* features applied during shaping.
|
||||||
|
*
|
||||||
|
* Return value: %false if all shapers failed, %true otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.0
|
* Since: 1.0
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -47,13 +47,10 @@ typedef struct hb_feature_t {
|
||||||
unsigned int end;
|
unsigned int end;
|
||||||
} hb_feature_t;
|
} hb_feature_t;
|
||||||
|
|
||||||
/* len=-1 means str is NUL-terminated */
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_feature_from_string (const char *str, int len,
|
hb_feature_from_string (const char *str, int len,
|
||||||
hb_feature_t *feature);
|
hb_feature_t *feature);
|
||||||
|
|
||||||
/* Something like 128 bytes is more than enough.
|
|
||||||
* nul-terminates. */
|
|
||||||
void
|
void
|
||||||
hb_feature_to_string (hb_feature_t *feature,
|
hb_feature_to_string (hb_feature_t *feature,
|
||||||
char *buf, unsigned int size);
|
char *buf, unsigned int size);
|
||||||
|
|
Loading…
Reference in New Issue