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:
Khaled Hosny 2014-01-08 02:28:55 +02:00 committed by Behdad Esfahbod
parent 81bedda58c
commit d055e1fc78
2 changed files with 47 additions and 26 deletions

View File

@ -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
**/ **/

View File

@ -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);