Merge pull request #1676 from n8willis/docs-gtkdoc-core
[Docs] Add gtkdoc comments for low-level core APIs
This commit is contained in:
commit
462b71eaf3
|
@ -359,6 +359,8 @@ hb_font_get_font_h_extents_func_t
|
||||||
hb_font_get_font_v_extents_func_t
|
hb_font_get_font_v_extents_func_t
|
||||||
hb_font_get_h_extents
|
hb_font_get_h_extents
|
||||||
hb_font_get_v_extents
|
hb_font_get_v_extents
|
||||||
|
hb_font_extents_t
|
||||||
|
hb_glyph_extents_t
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
|
|
|
@ -58,7 +58,7 @@
|
||||||
* @length: Length of @data in bytes.
|
* @length: Length of @data in bytes.
|
||||||
* @mode: Memory mode for @data.
|
* @mode: Memory mode for @data.
|
||||||
* @user_data: Data parameter to pass to @destroy.
|
* @user_data: Data parameter to pass to @destroy.
|
||||||
* @destroy: Callback to call when @data is not needed anymore.
|
* @destroy: (optional): Callback to call when @data is not needed anymore.
|
||||||
*
|
*
|
||||||
* Creates a new "blob" object wrapping @data. The @mode parameter is used
|
* Creates a new "blob" object wrapping @data. The @mode parameter is used
|
||||||
* to negotiate ownership and lifecycle of @data.
|
* to negotiate ownership and lifecycle of @data.
|
||||||
|
@ -156,7 +156,7 @@ hb_blob_create_sub_blob (hb_blob_t *parent,
|
||||||
*
|
*
|
||||||
* Makes a writable copy of @blob.
|
* Makes a writable copy of @blob.
|
||||||
*
|
*
|
||||||
* Return value: New blob, or nullptr if allocation failed.
|
* Return value: The new blob, or nullptr if allocation failed
|
||||||
*
|
*
|
||||||
* Since: 1.8.0
|
* Since: 1.8.0
|
||||||
**/
|
**/
|
||||||
|
@ -182,7 +182,7 @@ hb_blob_copy_writable_or_fail (hb_blob_t *blob)
|
||||||
*
|
*
|
||||||
* See TODO:link object types for more information.
|
* See TODO:link object types for more information.
|
||||||
*
|
*
|
||||||
* Return value: (transfer full): the empty blob.
|
* Return value: (transfer full): The empty blob.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -234,13 +234,15 @@ hb_blob_destroy (hb_blob_t *blob)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_blob_set_user_data: (skip)
|
* hb_blob_set_user_data: (skip)
|
||||||
* @blob: a blob.
|
* @blob: An #hb_blob_t
|
||||||
* @key: key for data to set.
|
* @key: The user-data key to set
|
||||||
* @data: data to set.
|
* @data: A pointer to the user data to set
|
||||||
* @destroy: callback to call when @data is not needed anymore.
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace: whether to replace an existing data with the same key.
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
* Return value:
|
* Attaches a user-data key/data pair to the specified blob.
|
||||||
|
*
|
||||||
|
* Return value: %true if success, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -256,12 +258,13 @@ hb_blob_set_user_data (hb_blob_t *blob,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_blob_get_user_data: (skip)
|
* hb_blob_get_user_data: (skip)
|
||||||
* @blob: a blob.
|
* @blob: a blob
|
||||||
* @key: key for data to get.
|
* @key: The user-data key to query
|
||||||
*
|
*
|
||||||
|
* Fetches the user data associated with the specified key,
|
||||||
|
* attached to the specified font-functions structure.
|
||||||
*
|
*
|
||||||
*
|
* Return value: (transfer none): A pointer to the user data
|
||||||
* Return value: (transfer none):
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -275,9 +278,9 @@ hb_blob_get_user_data (hb_blob_t *blob,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_blob_make_immutable:
|
* hb_blob_make_immutable:
|
||||||
* @blob: a blob.
|
* @blob: a blob
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Makes a blob immutable.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -294,9 +297,9 @@ hb_blob_make_immutable (hb_blob_t *blob)
|
||||||
* hb_blob_is_immutable:
|
* hb_blob_is_immutable:
|
||||||
* @blob: a blob.
|
* @blob: a blob.
|
||||||
*
|
*
|
||||||
|
* Tests whether a blob is immutable.
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if @blob is immutable, false otherwise
|
||||||
* Return value: TODO
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -311,9 +314,9 @@ hb_blob_is_immutable (hb_blob_t *blob)
|
||||||
* hb_blob_get_length:
|
* hb_blob_get_length:
|
||||||
* @blob: a blob.
|
* @blob: a blob.
|
||||||
*
|
*
|
||||||
|
* Fetches the length of a blob's data.
|
||||||
*
|
*
|
||||||
*
|
* Return value: the length of @blob data in bytes.
|
||||||
* Return value: the length of blob data in bytes.
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -326,11 +329,11 @@ hb_blob_get_length (hb_blob_t *blob)
|
||||||
/**
|
/**
|
||||||
* hb_blob_get_data:
|
* hb_blob_get_data:
|
||||||
* @blob: a blob.
|
* @blob: a blob.
|
||||||
* @length: (out):
|
* @length: (out): The length in bytes of the data retrieved
|
||||||
*
|
*
|
||||||
|
* Fetches the data from a blob.
|
||||||
*
|
*
|
||||||
*
|
* Returns: (transfer none) (array length=length): the byte data of @blob.
|
||||||
* Returns: (transfer none) (array length=length):
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -558,9 +561,12 @@ _open_resource_fork (const char *file_name, hb_mapped_file_t *file)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_blob_create_from_file:
|
* hb_blob_create_from_file:
|
||||||
* @file_name: font filename.
|
* @file_name: A font filename
|
||||||
*
|
*
|
||||||
* Returns: A hb_blob_t pointer with the content of the file
|
* Creates a new blob containing the data from the
|
||||||
|
* specified binary font file.
|
||||||
|
*
|
||||||
|
* Returns: An #hb_blob_t pointer with the content of the file
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -36,25 +36,34 @@
|
||||||
HB_BEGIN_DECLS
|
HB_BEGIN_DECLS
|
||||||
|
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Note re various memory-modes:
|
* hb_memory_mode_t:
|
||||||
|
* @HB_MEMORY_MODE_DUPLICATE
|
||||||
|
* @HB_MEMORY_MODE_READONLY
|
||||||
|
* @HB_MEMORY_MODE_WRITABLE
|
||||||
|
* @HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE
|
||||||
|
*
|
||||||
|
* Data type holding the memory modes available to
|
||||||
|
* client programs.
|
||||||
|
*
|
||||||
|
* Regarding these various memory-modes:
|
||||||
*
|
*
|
||||||
* - In no case shall the HarfBuzz client modify memory
|
* - In no case shall the HarfBuzz client modify memory
|
||||||
* that is passed to HarfBuzz in a blob. If there is
|
* that is passed to HarfBuzz in a blob. If there is
|
||||||
* any such possibility, MODE_DUPLICATE should be used
|
* any such possibility, @HB_MEMORY_MODE_DUPLICATE should be used
|
||||||
* such that HarfBuzz makes a copy immediately,
|
* such that HarfBuzz makes a copy immediately,
|
||||||
*
|
*
|
||||||
* - Use MODE_READONLY otherwise, unless you really really
|
* - Use @HB_MEMORY_MODE_READONLY otherwise, unless you really really
|
||||||
* really know what you are doing,
|
* really know what you are doing,
|
||||||
*
|
*
|
||||||
* - MODE_WRITABLE is appropriate if you really made a
|
* - @HB_MEMORY_MODE_WRITABLE is appropriate if you really made a
|
||||||
* copy of data solely for the purpose of passing to
|
* copy of data solely for the purpose of passing to
|
||||||
* HarfBuzz and doing that just once (no reuse!),
|
* HarfBuzz and doing that just once (no reuse!),
|
||||||
*
|
*
|
||||||
* - If the font is mmap()ed, it's ok to use
|
* - If the font is mmap()ed, it's okay to use
|
||||||
* READONLY_MAY_MAKE_WRITABLE, however, using that mode
|
* @HB_MEMORY_READONLY_MAY_MAKE_WRITABLE, however, using that mode
|
||||||
* correctly is very tricky. Use MODE_READONLY instead.
|
* correctly is very tricky. Use @HB_MEMORY_MODE_READONLY instead.
|
||||||
*/
|
**/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
HB_MEMORY_MODE_DUPLICATE,
|
HB_MEMORY_MODE_DUPLICATE,
|
||||||
HB_MEMORY_MODE_READONLY,
|
HB_MEMORY_MODE_READONLY,
|
||||||
|
@ -62,6 +71,14 @@ typedef enum {
|
||||||
HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE
|
HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE
|
||||||
} hb_memory_mode_t;
|
} hb_memory_mode_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_blob_t:
|
||||||
|
*
|
||||||
|
* Data type for blobs. A blob wraps a chunk of binary
|
||||||
|
* data and facilitates its lifecycle management between
|
||||||
|
* a client program and HarfBuzz.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef struct hb_blob_t hb_blob_t;
|
typedef struct hb_blob_t hb_blob_t;
|
||||||
|
|
||||||
HB_EXTERN hb_blob_t *
|
HB_EXTERN hb_blob_t *
|
||||||
|
|
235
src/hb-buffer.cc
235
src/hb-buffer.cc
|
@ -37,8 +37,9 @@
|
||||||
* @short_description: Input and output buffers
|
* @short_description: Input and output buffers
|
||||||
* @include: hb.h
|
* @include: hb.h
|
||||||
*
|
*
|
||||||
* Buffers serve dual role in HarfBuzz; they hold the input characters that are
|
* Buffers serve a dual role in HarfBuzz; before shaping, they hold
|
||||||
* passed to hb_shape(), and after shaping they hold the output glyphs.
|
* the input characters that are passed to hb_shape(), and after
|
||||||
|
* shaping they hold the output glyphs.
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
|
||||||
|
@ -705,9 +706,9 @@ hb_buffer_create ()
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_empty:
|
* hb_buffer_get_empty:
|
||||||
*
|
*
|
||||||
|
* Fetches an empty #hb_buffer_t.
|
||||||
*
|
*
|
||||||
*
|
* Return value: (transfer full): The empty buffer
|
||||||
* Return value: (transfer full):
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -719,7 +720,7 @@ hb_buffer_get_empty ()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_reference: (skip)
|
* hb_buffer_reference: (skip)
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Increases the reference count on @buffer by one. This prevents @buffer from
|
* Increases the reference count on @buffer by one. This prevents @buffer from
|
||||||
* being destroyed until a matching call to hb_buffer_destroy() is made.
|
* being destroyed until a matching call to hb_buffer_destroy() is made.
|
||||||
|
@ -737,7 +738,7 @@ hb_buffer_reference (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_destroy: (skip)
|
* hb_buffer_destroy: (skip)
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Deallocate the @buffer.
|
* Deallocate the @buffer.
|
||||||
* Decreases the reference count on @buffer by one. If the result is zero, then
|
* Decreases the reference count on @buffer by one. If the result is zero, then
|
||||||
|
@ -764,15 +765,15 @@ hb_buffer_destroy (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_user_data: (skip)
|
* hb_buffer_set_user_data: (skip)
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @key:
|
* @key: The user-data key
|
||||||
* @data:
|
* @data: A pointer to the user data
|
||||||
* @destroy:
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace:
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
|
* Attaches a user-data key/data pair to the specified buffer.
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if success, %false otherwise
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -788,12 +789,13 @@ hb_buffer_set_user_data (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_user_data: (skip)
|
* hb_buffer_get_user_data: (skip)
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @key:
|
* @key: The user-data key to query
|
||||||
*
|
*
|
||||||
|
* Fetches the user data associated with the specified key,
|
||||||
|
* attached to the specified buffer.
|
||||||
*
|
*
|
||||||
*
|
* Return value: (transfer-none): A pointer to the user data
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -807,11 +809,11 @@ hb_buffer_get_user_data (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_content_type:
|
* hb_buffer_set_content_type:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @content_type: the type of buffer contents to set
|
* @content_type: The type of buffer contents to set
|
||||||
*
|
*
|
||||||
* Sets the type of @buffer contents, buffers are either empty, contain
|
* Sets the type of @buffer contents. Buffers are either empty, contain
|
||||||
* characters (before shaping) or glyphs (the result of shaping).
|
* characters (before shaping), or contain glyphs (the result of shaping).
|
||||||
*
|
*
|
||||||
* Since: 0.9.5
|
* Since: 0.9.5
|
||||||
**/
|
**/
|
||||||
|
@ -824,12 +826,13 @@ hb_buffer_set_content_type (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_content_type:
|
* hb_buffer_get_content_type:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* see hb_buffer_set_content_type().
|
* Fetches the type of @buffer contents. Buffers are either empty, contain
|
||||||
|
* characters (before shaping), or contain glyphs (the result of shaping).
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The type of @buffer contents.
|
* The type of @buffer contents
|
||||||
*
|
*
|
||||||
* Since: 0.9.5
|
* Since: 0.9.5
|
||||||
**/
|
**/
|
||||||
|
@ -842,10 +845,11 @@ hb_buffer_get_content_type (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_unicode_funcs:
|
* hb_buffer_set_unicode_funcs:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @unicode_funcs:
|
* @unicode_funcs: The Unicode-functions structure
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the Unicode-functions structure of a buffer to
|
||||||
|
* @unicode_funcs.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -866,11 +870,11 @@ hb_buffer_set_unicode_funcs (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_unicode_funcs:
|
* hb_buffer_get_unicode_funcs:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
|
* Fetches the Unicode-functions structure of a buffer.
|
||||||
*
|
*
|
||||||
*
|
* Return value: The Unicode-functions structure
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -882,7 +886,7 @@ hb_buffer_get_unicode_funcs (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_direction:
|
* hb_buffer_set_direction:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @direction: the #hb_direction_t of the @buffer
|
* @direction: the #hb_direction_t of the @buffer
|
||||||
*
|
*
|
||||||
* Set the text flow direction of the buffer. No shaping can happen without
|
* Set the text flow direction of the buffer. No shaping can happen without
|
||||||
|
@ -908,7 +912,7 @@ hb_buffer_set_direction (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_direction:
|
* hb_buffer_get_direction:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_direction()
|
* See hb_buffer_set_direction()
|
||||||
*
|
*
|
||||||
|
@ -925,8 +929,8 @@ hb_buffer_get_direction (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_script:
|
* hb_buffer_set_script:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @script: an #hb_script_t to set.
|
* @script: An #hb_script_t to set.
|
||||||
*
|
*
|
||||||
* Sets the script of @buffer to @script.
|
* Sets the script of @buffer to @script.
|
||||||
*
|
*
|
||||||
|
@ -952,12 +956,12 @@ hb_buffer_set_script (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_script:
|
* hb_buffer_get_script:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_script().
|
* Fetches the script of @buffer.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The #hb_script_t of the @buffer.
|
* The #hb_script_t of the @buffer
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -969,8 +973,8 @@ hb_buffer_get_script (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_language:
|
* hb_buffer_set_language:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @language: an hb_language_t to set.
|
* @language: An hb_language_t to set
|
||||||
*
|
*
|
||||||
* Sets the language of @buffer to @language.
|
* Sets the language of @buffer to @language.
|
||||||
*
|
*
|
||||||
|
@ -996,7 +1000,7 @@ hb_buffer_set_language (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_language:
|
* hb_buffer_get_language:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_language().
|
* See hb_buffer_set_language().
|
||||||
*
|
*
|
||||||
|
@ -1013,8 +1017,8 @@ hb_buffer_get_language (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_segment_properties:
|
* hb_buffer_set_segment_properties:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @props: an #hb_segment_properties_t to use.
|
* @props: An #hb_segment_properties_t to use
|
||||||
*
|
*
|
||||||
* Sets the segment properties of the buffer, a shortcut for calling
|
* Sets the segment properties of the buffer, a shortcut for calling
|
||||||
* hb_buffer_set_direction(), hb_buffer_set_script() and
|
* hb_buffer_set_direction(), hb_buffer_set_script() and
|
||||||
|
@ -1034,8 +1038,8 @@ hb_buffer_set_segment_properties (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_segment_properties:
|
* hb_buffer_get_segment_properties:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @props: (out): the output #hb_segment_properties_t.
|
* @props: (out): The output #hb_segment_properties_t
|
||||||
*
|
*
|
||||||
* Sets @props to the #hb_segment_properties_t of @buffer.
|
* Sets @props to the #hb_segment_properties_t of @buffer.
|
||||||
*
|
*
|
||||||
|
@ -1051,8 +1055,8 @@ hb_buffer_get_segment_properties (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_flags:
|
* hb_buffer_set_flags:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @flags: the buffer flags to set.
|
* @flags: The buffer flags to set
|
||||||
*
|
*
|
||||||
* Sets @buffer flags to @flags. See #hb_buffer_flags_t.
|
* Sets @buffer flags to @flags. See #hb_buffer_flags_t.
|
||||||
*
|
*
|
||||||
|
@ -1070,12 +1074,12 @@ hb_buffer_set_flags (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_flags:
|
* hb_buffer_get_flags:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_flags().
|
* Fetches the #hb_buffer_flags_t of @buffer.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The @buffer flags.
|
* The @buffer flags
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -1087,10 +1091,12 @@ hb_buffer_get_flags (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_cluster_level:
|
* hb_buffer_set_cluster_level:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @cluster_level:
|
* @cluster_level: The cluster level to set on the buffer
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the cluster level of a buffer. The #hb_buffer_cluster_level_t
|
||||||
|
* dictates one aspect of how HarfBuzz will treat non-base characters
|
||||||
|
* during shaping.
|
||||||
*
|
*
|
||||||
* Since: 0.9.42
|
* Since: 0.9.42
|
||||||
**/
|
**/
|
||||||
|
@ -1106,11 +1112,13 @@ hb_buffer_set_cluster_level (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_cluster_level:
|
* hb_buffer_get_cluster_level:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
|
* Fetches the cluster level of a buffer. The #hb_buffer_cluster_level_t
|
||||||
|
* dictates one aspect of how HarfBuzz will treat non-base characters
|
||||||
|
* during shaping.
|
||||||
*
|
*
|
||||||
*
|
* Return value: The cluster level of @buffer
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.42
|
* Since: 0.9.42
|
||||||
**/
|
**/
|
||||||
|
@ -1123,7 +1131,7 @@ hb_buffer_get_cluster_level (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_replacement_codepoint:
|
* hb_buffer_set_replacement_codepoint:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @replacement: the replacement #hb_codepoint_t
|
* @replacement: the replacement #hb_codepoint_t
|
||||||
*
|
*
|
||||||
* Sets the #hb_codepoint_t that replaces invalid entries for a given encoding
|
* Sets the #hb_codepoint_t that replaces invalid entries for a given encoding
|
||||||
|
@ -1145,12 +1153,13 @@ hb_buffer_set_replacement_codepoint (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_replacement_codepoint:
|
* hb_buffer_get_replacement_codepoint:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_replacement_codepoint().
|
* Fetches the #hb_codepoint_t that replaces invalid entries for a given encoding
|
||||||
|
* when adding text to @buffer.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The @buffer replacement #hb_codepoint_t.
|
* The @buffer replacement #hb_codepoint_t
|
||||||
*
|
*
|
||||||
* Since: 0.9.31
|
* Since: 0.9.31
|
||||||
**/
|
**/
|
||||||
|
@ -1163,7 +1172,7 @@ hb_buffer_get_replacement_codepoint (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_invisible_glyph:
|
* hb_buffer_set_invisible_glyph:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @invisible: the invisible #hb_codepoint_t
|
* @invisible: the invisible #hb_codepoint_t
|
||||||
*
|
*
|
||||||
* Sets the #hb_codepoint_t that replaces invisible characters in
|
* Sets the #hb_codepoint_t that replaces invisible characters in
|
||||||
|
@ -1185,12 +1194,12 @@ hb_buffer_set_invisible_glyph (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_invisible_glyph:
|
* hb_buffer_get_invisible_glyph:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* See hb_buffer_set_invisible_glyph().
|
* See hb_buffer_set_invisible_glyph().
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The @buffer invisible #hb_codepoint_t.
|
* The @buffer invisible #hb_codepoint_t
|
||||||
*
|
*
|
||||||
* Since: 2.0.0
|
* Since: 2.0.0
|
||||||
**/
|
**/
|
||||||
|
@ -1203,7 +1212,7 @@ hb_buffer_get_invisible_glyph (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_reset:
|
* hb_buffer_reset:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Resets the buffer to its initial status, as if it was just newly created
|
* Resets the buffer to its initial status, as if it was just newly created
|
||||||
* with hb_buffer_create().
|
* with hb_buffer_create().
|
||||||
|
@ -1218,7 +1227,7 @@ hb_buffer_reset (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_clear_contents:
|
* hb_buffer_clear_contents:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Similar to hb_buffer_reset(), but does not clear the Unicode functions and
|
* Similar to hb_buffer_reset(), but does not clear the Unicode functions and
|
||||||
* the replacement code point.
|
* the replacement code point.
|
||||||
|
@ -1233,13 +1242,13 @@ hb_buffer_clear_contents (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_pre_allocate:
|
* hb_buffer_pre_allocate:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @size: number of items to pre allocate.
|
* @size: Number of items to pre allocate.
|
||||||
*
|
*
|
||||||
* Pre allocates memory for @buffer to fit at least @size number of items.
|
* Pre allocates memory for @buffer to fit at least @size number of items.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* %true if @buffer memory allocation succeeded, %false otherwise.
|
* %true if @buffer memory allocation succeeded, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -1251,7 +1260,7 @@ hb_buffer_pre_allocate (hb_buffer_t *buffer, unsigned int size)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_allocation_successful:
|
* hb_buffer_allocation_successful:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Check if allocating memory for the buffer succeeded.
|
* Check if allocating memory for the buffer succeeded.
|
||||||
*
|
*
|
||||||
|
@ -1268,9 +1277,9 @@ hb_buffer_allocation_successful (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_add:
|
* hb_buffer_add:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @codepoint: a Unicode code point.
|
* @codepoint: A Unicode code point.
|
||||||
* @cluster: the cluster value of @codepoint.
|
* @cluster: The cluster value of @codepoint.
|
||||||
*
|
*
|
||||||
* Appends a character with the Unicode value of @codepoint to @buffer, and
|
* Appends a character with the Unicode value of @codepoint to @buffer, and
|
||||||
* gives it the initial cluster value of @cluster. Clusters can be any thing
|
* gives it the initial cluster value of @cluster. Clusters can be any thing
|
||||||
|
@ -1294,8 +1303,8 @@ hb_buffer_add (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_length:
|
* hb_buffer_set_length:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @length: the new length of @buffer.
|
* @length: The new length of @buffer
|
||||||
*
|
*
|
||||||
* Similar to hb_buffer_pre_allocate(), but clears any new items added at the
|
* Similar to hb_buffer_pre_allocate(), but clears any new items added at the
|
||||||
* end.
|
* end.
|
||||||
|
@ -1336,7 +1345,7 @@ hb_buffer_set_length (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_length:
|
* hb_buffer_get_length:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Returns the number of items in the buffer.
|
* Returns the number of items in the buffer.
|
||||||
*
|
*
|
||||||
|
@ -1354,8 +1363,8 @@ hb_buffer_get_length (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_glyph_infos:
|
* hb_buffer_get_glyph_infos:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @length: (out): output array length.
|
* @length: (out): The output-array length.
|
||||||
*
|
*
|
||||||
* Returns @buffer glyph information array. Returned pointer
|
* Returns @buffer glyph information array. Returned pointer
|
||||||
* is valid as long as @buffer contents are not modified.
|
* is valid as long as @buffer contents are not modified.
|
||||||
|
@ -1378,8 +1387,8 @@ hb_buffer_get_glyph_infos (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_get_glyph_positions:
|
* hb_buffer_get_glyph_positions:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @length: (out): output length.
|
* @length: (out): The output length
|
||||||
*
|
*
|
||||||
* Returns @buffer glyph position array. Returned pointer
|
* Returns @buffer glyph position array. Returned pointer
|
||||||
* is valid as long as @buffer contents are not modified.
|
* is valid as long as @buffer contents are not modified.
|
||||||
|
@ -1424,12 +1433,12 @@ hb_buffer_has_positions (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_glyph_info_get_glyph_flags:
|
* hb_glyph_info_get_glyph_flags:
|
||||||
* @info: a #hb_glyph_info_t.
|
* @info: a #hb_glyph_info_t
|
||||||
*
|
*
|
||||||
* Returns glyph flags encoded within a #hb_glyph_info_t.
|
* Returns glyph flags encoded within a #hb_glyph_info_t.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* The #hb_glyph_flags_t encoded within @info.
|
* The #hb_glyph_flags_t encoded within @info
|
||||||
*
|
*
|
||||||
* Since: 1.5.0
|
* Since: 1.5.0
|
||||||
**/
|
**/
|
||||||
|
@ -1441,7 +1450,7 @@ hb_glyph_flags_t
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_reverse:
|
* hb_buffer_reverse:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Reverses buffer contents.
|
* Reverses buffer contents.
|
||||||
*
|
*
|
||||||
|
@ -1455,11 +1464,11 @@ hb_buffer_reverse (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_reverse_range:
|
* hb_buffer_reverse_range:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @start: start index.
|
* @start: start index
|
||||||
* @end: end index.
|
* @end: end index
|
||||||
*
|
*
|
||||||
* Reverses buffer contents between start to end.
|
* Reverses buffer contents between @start and @end.
|
||||||
*
|
*
|
||||||
* Since: 0.9.41
|
* Since: 0.9.41
|
||||||
**/
|
**/
|
||||||
|
@ -1472,7 +1481,7 @@ hb_buffer_reverse_range (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_reverse_clusters:
|
* hb_buffer_reverse_clusters:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Reverses buffer clusters. That is, the buffer contents are
|
* Reverses buffer clusters. That is, the buffer contents are
|
||||||
* reversed, then each cluster (consecutive items having the
|
* reversed, then each cluster (consecutive items having the
|
||||||
|
@ -1488,7 +1497,7 @@ hb_buffer_reverse_clusters (hb_buffer_t *buffer)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_guess_segment_properties:
|
* hb_buffer_guess_segment_properties:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Sets unset buffer segment properties based on buffer Unicode
|
* Sets unset buffer segment properties based on buffer Unicode
|
||||||
* contents. If buffer is not empty, it must have content type
|
* contents. If buffer is not empty, it must have content type
|
||||||
|
@ -1590,12 +1599,12 @@ hb_buffer_add_utf (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_add_utf8:
|
* hb_buffer_add_utf8:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @text: (array length=text_length) (element-type uint8_t): an array of UTF-8
|
* @text: (array length=text_length) (element-type uint8_t): An array of UTF-8
|
||||||
* characters to append.
|
* characters to append.
|
||||||
* @text_length: the length of the @text, or -1 if it is %NULL terminated.
|
* @text_length: The length of the @text, or -1 if it is %NULL terminated.
|
||||||
* @item_offset: the offset of the first character to add to the @buffer.
|
* @item_offset: The offset of the first character to add to the @buffer.
|
||||||
* @item_length: the number of characters to add to the @buffer, or -1 for the
|
* @item_length: The number of characters to add to the @buffer, or -1 for the
|
||||||
* end of @text (assuming it is %NULL terminated).
|
* end of @text (assuming it is %NULL terminated).
|
||||||
*
|
*
|
||||||
* See hb_buffer_add_codepoints().
|
* See hb_buffer_add_codepoints().
|
||||||
|
@ -1617,12 +1626,12 @@ hb_buffer_add_utf8 (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_add_utf16:
|
* hb_buffer_add_utf16:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @text: (array length=text_length): an array of UTF-16 characters to append.
|
* @text: (array length=text_length): An array of UTF-16 characters to append
|
||||||
* @text_length: the length of the @text, or -1 if it is %NULL terminated.
|
* @text_length: The length of the @text, or -1 if it is %NULL terminated
|
||||||
* @item_offset: the offset of the first character to add to the @buffer.
|
* @item_offset: The offset of the first character to add to the @buffer
|
||||||
* @item_length: the number of characters to add to the @buffer, or -1 for the
|
* @item_length: The number of characters to add to the @buffer, or -1 for the
|
||||||
* end of @text (assuming it is %NULL terminated).
|
* end of @text (assuming it is %NULL terminated)
|
||||||
*
|
*
|
||||||
* See hb_buffer_add_codepoints().
|
* See hb_buffer_add_codepoints().
|
||||||
*
|
*
|
||||||
|
@ -1643,12 +1652,12 @@ hb_buffer_add_utf16 (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_add_utf32:
|
* hb_buffer_add_utf32:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @text: (array length=text_length): an array of UTF-32 characters to append.
|
* @text: (array length=text_length): An array of UTF-32 characters to append
|
||||||
* @text_length: the length of the @text, or -1 if it is %NULL terminated.
|
* @text_length: The length of the @text, or -1 if it is %NULL terminated
|
||||||
* @item_offset: the offset of the first character to add to the @buffer.
|
* @item_offset: The offset of the first character to add to the @buffer
|
||||||
* @item_length: the number of characters to add to the @buffer, or -1 for the
|
* @item_length: The number of characters to add to the @buffer, or -1 for the
|
||||||
* end of @text (assuming it is %NULL terminated).
|
* end of @text (assuming it is %NULL terminated)
|
||||||
*
|
*
|
||||||
* See hb_buffer_add_codepoints().
|
* See hb_buffer_add_codepoints().
|
||||||
*
|
*
|
||||||
|
@ -1669,13 +1678,13 @@ hb_buffer_add_utf32 (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_add_latin1:
|
* hb_buffer_add_latin1:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @text: (array length=text_length) (element-type uint8_t): an array of UTF-8
|
* @text: (array length=text_length) (element-type uint8_t): an array of UTF-8
|
||||||
* characters to append.
|
* characters to append
|
||||||
* @text_length: the length of the @text, or -1 if it is %NULL terminated.
|
* @text_length: the length of the @text, or -1 if it is %NULL terminated
|
||||||
* @item_offset: the offset of the first character to add to the @buffer.
|
* @item_offset: the offset of the first character to add to the @buffer
|
||||||
* @item_length: the number of characters to add to the @buffer, or -1 for the
|
* @item_length: the number of characters to add to the @buffer, or -1 for the
|
||||||
* end of @text (assuming it is %NULL terminated).
|
* end of @text (assuming it is %NULL terminated)
|
||||||
*
|
*
|
||||||
* Similar to hb_buffer_add_codepoints(), but allows only access to first 256
|
* Similar to hb_buffer_add_codepoints(), but allows only access to first 256
|
||||||
* Unicode code points that can fit in 8-bit strings.
|
* Unicode code points that can fit in 8-bit strings.
|
||||||
|
@ -1731,8 +1740,8 @@ hb_buffer_add_codepoints (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_append:
|
* hb_buffer_append:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @source: source #hb_buffer_t.
|
* @source: source #hb_buffer_t
|
||||||
* @start: start index into source buffer to copy. Use 0 to copy from start of buffer.
|
* @start: start index into source buffer to copy. Use 0 to copy from start of buffer.
|
||||||
* @end: end index into source buffer to copy. Use @HB_FEATURE_GLOBAL_END to copy to end of buffer.
|
* @end: end index into source buffer to copy. Use @HB_FEATURE_GLOBAL_END to copy to end of buffer.
|
||||||
*
|
*
|
||||||
|
@ -1838,7 +1847,7 @@ normalize_glyphs_cluster (hb_buffer_t *buffer,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_buffer_normalize_glyphs:
|
* hb_buffer_normalize_glyphs:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
*
|
*
|
||||||
* Reorders a glyph buffer to have canonical in-cluster glyph order / position.
|
* Reorders a glyph buffer to have canonical in-cluster glyph order / position.
|
||||||
* The resulting clusters should behave identical to pre-reordering clusters.
|
* The resulting clusters should behave identical to pre-reordering clusters.
|
||||||
|
@ -1984,7 +1993,7 @@ hb_buffer_diff (hb_buffer_t *buffer,
|
||||||
#ifndef HB_NO_BUFFER_MESSAGE
|
#ifndef HB_NO_BUFFER_MESSAGE
|
||||||
/**
|
/**
|
||||||
* hb_buffer_set_message_func:
|
* hb_buffer_set_message_func:
|
||||||
* @buffer: an #hb_buffer_t.
|
* @buffer: An #hb_buffer_t
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified):
|
||||||
* @user_data:
|
* @user_data:
|
||||||
* @destroy:
|
* @destroy:
|
||||||
|
|
|
@ -315,6 +315,23 @@ hb_buffer_get_flags (hb_buffer_t *buffer);
|
||||||
* @HB_BUFFER_CLUSTER_LEVEL_DEFAULT: Default cluster level,
|
* @HB_BUFFER_CLUSTER_LEVEL_DEFAULT: Default cluster level,
|
||||||
* equal to @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES.
|
* equal to @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES.
|
||||||
*
|
*
|
||||||
|
* Data type for holding HarfBuzz's clustering behavior options. The cluster level
|
||||||
|
* dictates one aspect of how HarfBuzz will treat non-base characters
|
||||||
|
* during shaping.
|
||||||
|
*
|
||||||
|
* In @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES, non-base
|
||||||
|
* characters are merged into the cluster of the base character that precedes them.
|
||||||
|
*
|
||||||
|
* In @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_CHARACTERS, non-base characters are initially
|
||||||
|
* assigned their own cluster values, which are not merged into preceding base
|
||||||
|
* clusters. This allows HarfBuzz to perform additional operations like reorder
|
||||||
|
* sequences of adjacent marks.
|
||||||
|
*
|
||||||
|
* @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES is the default, because it maintains
|
||||||
|
* backward compatibility with older versions of HarfBuzz. New client programs that
|
||||||
|
* do not need to maintain such backward compatibility are recommended to use
|
||||||
|
* @HB_BUFFER_CLUSTER_LEVEL_MONOTONE_CHARACTERS instead of the default.
|
||||||
|
*
|
||||||
* Since: 0.9.42
|
* Since: 0.9.42
|
||||||
*/
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
|
|
@ -86,12 +86,15 @@ _hb_options_init ()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_tag_from_string:
|
* hb_tag_from_string:
|
||||||
* @str: (array length=len) (element-type uint8_t):
|
* @str: (array length=len) (element-type uint8_t): String to convert
|
||||||
* @len:
|
* @len: Length of @str, or -1 if it is %NULL-terminated
|
||||||
*
|
*
|
||||||
|
* Converts a string into an #hb_tag_t. Valid tags
|
||||||
|
* are four characters. Shorter input strings will be
|
||||||
|
* padded with spaces. Longer input strings will be
|
||||||
|
* truncated.
|
||||||
*
|
*
|
||||||
*
|
* Return value: The #hb_tag_t corresponding to @str
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -116,10 +119,11 @@ hb_tag_from_string (const char *str, int len)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_tag_to_string:
|
* hb_tag_to_string:
|
||||||
* @tag:
|
* @tag: #hb_tag_t to convert
|
||||||
* @buf: (out caller-allocates) (array fixed-size=4) (element-type uint8_t):
|
* @buf: (out caller-allocates) (array fixed-size=4) (element-type uint8_t): Converted string
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Converts an #hb_tag_t to a string and returns it in @buf.
|
||||||
|
* Strings will be four characters long.
|
||||||
*
|
*
|
||||||
* Since: 0.9.5
|
* Since: 0.9.5
|
||||||
**/
|
**/
|
||||||
|
@ -144,12 +148,17 @@ const char direction_strings[][4] = {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_direction_from_string:
|
* hb_direction_from_string:
|
||||||
* @str: (array length=len) (element-type uint8_t):
|
* @str: (array length=len) (element-type uint8_t): String to convert
|
||||||
* @len:
|
* @len: Length of @str, or -1 if it is %NULL-terminated
|
||||||
*
|
*
|
||||||
|
* Converts a string to an #hb_direction_t.
|
||||||
*
|
*
|
||||||
|
* Matching is loose and applies only to the first letter. For
|
||||||
|
* examples, "LTR" and "left-to-right" will both return #HB_DIRECTION_LTR.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Unmatched strings will return #HB_DIRECTION_INVALID.
|
||||||
|
*
|
||||||
|
* Return value: The #hb_direction_t matching @str
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -172,11 +181,11 @@ hb_direction_from_string (const char *str, int len)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_direction_to_string:
|
* hb_direction_to_string:
|
||||||
* @direction:
|
* @direction: The #hb_direction_t to convert
|
||||||
*
|
*
|
||||||
|
* Converts an #hb_direction_t to a string.
|
||||||
*
|
*
|
||||||
*
|
* Return value: (transfer none): The string corresponding to @direction
|
||||||
* Return value: (transfer none):
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -367,9 +376,9 @@ hb_language_from_string (const char *str, int len)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_language_to_string:
|
* hb_language_to_string:
|
||||||
* @language: an #hb_language_t to convert.
|
* @language: The #hb_language_t to convert
|
||||||
*
|
*
|
||||||
* See hb_language_from_string().
|
* Converts an #hb_language_t to a string.
|
||||||
*
|
*
|
||||||
* Return value: (transfer none):
|
* Return value: (transfer none):
|
||||||
* A %NULL-terminated string representing the @language. Must not be freed by
|
* A %NULL-terminated string representing the @language. Must not be freed by
|
||||||
|
@ -388,16 +397,17 @@ hb_language_to_string (hb_language_t language)
|
||||||
/**
|
/**
|
||||||
* hb_language_get_default:
|
* hb_language_get_default:
|
||||||
*
|
*
|
||||||
* Get default language from current locale.
|
* Fetch the default language from current locale.
|
||||||
*
|
*
|
||||||
* Note that the first time this function is called, it calls
|
* <note>Note that the first time this function is called, it calls
|
||||||
* "setlocale (LC_CTYPE, nullptr)" to fetch current locale. The underlying
|
* "setlocale (LC_CTYPE, nullptr)" to fetch current locale. The underlying
|
||||||
* setlocale function is, in many implementations, NOT threadsafe. To avoid
|
* setlocale function is, in many implementations, NOT threadsafe. To avoid
|
||||||
* problems, call this function once before multiple threads can call it.
|
* problems, call this function once before multiple threads can call it.
|
||||||
* This function is only used from hb_buffer_guess_segment_properties() by
|
* This function is only used from hb_buffer_guess_segment_properties() by
|
||||||
* HarfBuzz itself.
|
* HarfBuzz itself.</note>
|
||||||
*
|
*
|
||||||
* Return value: (transfer none):
|
* Return value: (transfer none): The default language of the locale as
|
||||||
|
* an #hb_language_t
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -494,7 +504,7 @@ hb_script_from_string (const char *str, int len)
|
||||||
* hb_script_to_iso15924_tag:
|
* hb_script_to_iso15924_tag:
|
||||||
* @script: an #hb_script_t to convert.
|
* @script: an #hb_script_t to convert.
|
||||||
*
|
*
|
||||||
* See hb_script_from_iso15924_tag().
|
* Converts an #hb_script_t to a corresponding ISO 15924 script tag.
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* An #hb_tag_t representing an ISO 15924 script tag.
|
* An #hb_tag_t representing an ISO 15924 script tag.
|
||||||
|
@ -509,11 +519,16 @@ hb_script_to_iso15924_tag (hb_script_t script)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_script_get_horizontal_direction:
|
* hb_script_get_horizontal_direction:
|
||||||
* @script:
|
* @script: The #hb_script_t to query
|
||||||
*
|
*
|
||||||
|
* Fetches the #hb_direction_t of a script when it is
|
||||||
|
* set horizontally. All right-to-left scripts will return
|
||||||
|
* #HB_DIRECTION_RTL. All left-to-right scripts will return
|
||||||
|
* #HB_DIRECTION_LTR. Scripts that can be written either
|
||||||
|
* horizontally or vertically will return #HB_DIRECTION_INVALID.
|
||||||
|
* Unknown scripts will return #HB_DIRECTION_LTR.
|
||||||
*
|
*
|
||||||
*
|
* Return value: The horizontal #hb_direction_t of @script
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -618,9 +633,9 @@ hb_script_get_horizontal_direction (hb_script_t script)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_version:
|
* hb_version:
|
||||||
* @major: (out): Library major version component.
|
* @major: (out): Library major version component
|
||||||
* @minor: (out): Library minor version component.
|
* @minor: (out): Library minor version component
|
||||||
* @micro: (out): Library micro version component.
|
* @micro: (out): Library micro version component
|
||||||
*
|
*
|
||||||
* Returns library version as three integer components.
|
* Returns library version as three integer components.
|
||||||
*
|
*
|
||||||
|
@ -641,7 +656,7 @@ hb_version (unsigned int *major,
|
||||||
*
|
*
|
||||||
* Returns library version as a string with three components.
|
* Returns library version as a string with three components.
|
||||||
*
|
*
|
||||||
* Return value: library version string.
|
* Return value: Library version string
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -653,13 +668,15 @@ hb_version_string ()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_version_atleast:
|
* hb_version_atleast:
|
||||||
* @major:
|
* @major: Library major version component
|
||||||
* @minor:
|
* @minor: Library minor version component
|
||||||
* @micro:
|
* @micro: Library micro version component
|
||||||
*
|
*
|
||||||
|
* Tests the library version against a minimum value,
|
||||||
|
* as three integer components.
|
||||||
*
|
*
|
||||||
*
|
* Return value: True if the library is equal to or greater than
|
||||||
* Return value:
|
* the test value, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.30
|
* Since: 0.9.30
|
||||||
**/
|
**/
|
||||||
|
@ -888,7 +905,7 @@ parse_one_feature (const char **pp, const char *end, hb_feature_t *feature)
|
||||||
* </informaltable>
|
* </informaltable>
|
||||||
*
|
*
|
||||||
* Return value:
|
* Return value:
|
||||||
* %true if @str is successfully parsed, %false otherwise.
|
* %true if @str is successfully parsed, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.5
|
* Since: 0.9.5
|
||||||
**/
|
**/
|
||||||
|
|
293
src/hb-common.h
293
src/hb-common.h
|
@ -88,11 +88,37 @@ typedef unsigned __int64 uint64_t;
|
||||||
|
|
||||||
HB_BEGIN_DECLS
|
HB_BEGIN_DECLS
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_bool_t:
|
||||||
|
*
|
||||||
|
* Data type for booleans.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef int hb_bool_t;
|
typedef int hb_bool_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_codepoint_t:
|
||||||
|
*
|
||||||
|
* Data type for holding Unicode codepoints. Also
|
||||||
|
* used to hold glyph IDs.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef uint32_t hb_codepoint_t;
|
typedef uint32_t hb_codepoint_t;
|
||||||
|
/**
|
||||||
|
* hb_position_t:
|
||||||
|
*
|
||||||
|
* Data type for holding a single coordinate value.
|
||||||
|
* Contour points and other multi-dimensional data are
|
||||||
|
* stored as tuples of #hb_position_t's.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef int32_t hb_position_t;
|
typedef int32_t hb_position_t;
|
||||||
|
/**
|
||||||
|
* hb_mask_t:
|
||||||
|
*
|
||||||
|
* Data type for bitmasks.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef uint32_t hb_mask_t;
|
typedef uint32_t hb_mask_t;
|
||||||
|
|
||||||
typedef union _hb_var_int_t {
|
typedef union _hb_var_int_t {
|
||||||
|
@ -107,9 +133,33 @@ typedef union _hb_var_int_t {
|
||||||
|
|
||||||
/* hb_tag_t */
|
/* hb_tag_t */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_tag_t:
|
||||||
|
*
|
||||||
|
* Data type for tag identifiers. Tags are four
|
||||||
|
* byte integers, each byte representing a character.
|
||||||
|
*
|
||||||
|
* Tags are used to identify tables, design-variation axes,
|
||||||
|
* scripts, languages, font features, and baselines with
|
||||||
|
* human-readable names.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef uint32_t hb_tag_t;
|
typedef uint32_t hb_tag_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HB_TAG:
|
||||||
|
*
|
||||||
|
* Constructs an #hb_tag_t from four characters.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_TAG(c1,c2,c3,c4) ((hb_tag_t)((((uint32_t)(c1)&0xFF)<<24)|(((uint32_t)(c2)&0xFF)<<16)|(((uint32_t)(c3)&0xFF)<<8)|((uint32_t)(c4)&0xFF)))
|
#define HB_TAG(c1,c2,c3,c4) ((hb_tag_t)((((uint32_t)(c1)&0xFF)<<24)|(((uint32_t)(c2)&0xFF)<<16)|(((uint32_t)(c3)&0xFF)<<8)|((uint32_t)(c4)&0xFF)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HB_UNTAG:
|
||||||
|
*
|
||||||
|
* Extracts the characters from an #hb_tag_t.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_UNTAG(tag) (uint8_t)(((tag)>>24)&0xFF), (uint8_t)(((tag)>>16)&0xFF), (uint8_t)(((tag)>>8)&0xFF), (uint8_t)((tag)&0xFF)
|
#define HB_UNTAG(tag) (uint8_t)(((tag)>>24)&0xFF), (uint8_t)(((tag)>>16)&0xFF), (uint8_t)(((tag)>>8)&0xFF), (uint8_t)((tag)&0xFF)
|
||||||
|
|
||||||
#define HB_TAG_NONE HB_TAG(0,0,0,0)
|
#define HB_TAG_NONE HB_TAG(0,0,0,0)
|
||||||
|
@ -132,6 +182,13 @@ hb_tag_to_string (hb_tag_t tag, char *buf);
|
||||||
* @HB_DIRECTION_RTL: Text is set horizontally from right to left.
|
* @HB_DIRECTION_RTL: Text is set horizontally from right to left.
|
||||||
* @HB_DIRECTION_TTB: Text is set vertically from top to bottom.
|
* @HB_DIRECTION_TTB: Text is set vertically from top to bottom.
|
||||||
* @HB_DIRECTION_BTT: Text is set vertically from bottom to top.
|
* @HB_DIRECTION_BTT: Text is set vertically from bottom to top.
|
||||||
|
*
|
||||||
|
* The direction of a text segment or buffer.
|
||||||
|
*
|
||||||
|
* A segment can also be tested for horizontal or vertical
|
||||||
|
* orientation (irrespective of specific direction) with
|
||||||
|
* HB_DIRECTION_IS_HORIZONTAL() or HB_DIRECTION_IS_VERTICAL().
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
HB_DIRECTION_INVALID = 0,
|
HB_DIRECTION_INVALID = 0,
|
||||||
|
@ -148,12 +205,59 @@ hb_direction_from_string (const char *str, int len);
|
||||||
HB_EXTERN const char *
|
HB_EXTERN const char *
|
||||||
hb_direction_to_string (hb_direction_t direction);
|
hb_direction_to_string (hb_direction_t direction);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_IS_VALID:
|
||||||
|
* @dir: #hb_direction_t to test
|
||||||
|
*
|
||||||
|
* Tests whether a text direction is valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_IS_VALID(dir) ((((unsigned int) (dir)) & ~3U) == 4)
|
#define HB_DIRECTION_IS_VALID(dir) ((((unsigned int) (dir)) & ~3U) == 4)
|
||||||
/* Direction must be valid for the following */
|
/* Direction must be valid for the following */
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_IS_HORIZONTAL:
|
||||||
|
* @dir: #hb_direction_t to test
|
||||||
|
*
|
||||||
|
* Tests whether a text direction is horizontal. Requires
|
||||||
|
* that the direction be valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_IS_HORIZONTAL(dir) ((((unsigned int) (dir)) & ~1U) == 4)
|
#define HB_DIRECTION_IS_HORIZONTAL(dir) ((((unsigned int) (dir)) & ~1U) == 4)
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_IS_VERTICAL:
|
||||||
|
* @dir: #hb_direction_t to test
|
||||||
|
*
|
||||||
|
* Tests whether a text direction is vertical. Requires
|
||||||
|
* that the direction be valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_IS_VERTICAL(dir) ((((unsigned int) (dir)) & ~1U) == 6)
|
#define HB_DIRECTION_IS_VERTICAL(dir) ((((unsigned int) (dir)) & ~1U) == 6)
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_IS_FORWARD:
|
||||||
|
* @dir: #hb_direction_t to test
|
||||||
|
*
|
||||||
|
* Tests whether a text direction moves forward (from left to right, or from
|
||||||
|
* top to bottom). Requires that the direction be valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_IS_FORWARD(dir) ((((unsigned int) (dir)) & ~2U) == 4)
|
#define HB_DIRECTION_IS_FORWARD(dir) ((((unsigned int) (dir)) & ~2U) == 4)
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_IS_BACKWARD:
|
||||||
|
* @dir: #hb_direction_t to test
|
||||||
|
*
|
||||||
|
* Tests whether a text direction moves backward (from right to left, or from
|
||||||
|
* bottom to top). Requires that the direction be valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_IS_BACKWARD(dir) ((((unsigned int) (dir)) & ~2U) == 5)
|
#define HB_DIRECTION_IS_BACKWARD(dir) ((((unsigned int) (dir)) & ~2U) == 5)
|
||||||
|
/**
|
||||||
|
* HB_DIRECTION_REVERSE:
|
||||||
|
* @dir: #hb_direction_t to reverse
|
||||||
|
*
|
||||||
|
* Reverses a text direction. Requires that the direction
|
||||||
|
* be valid.
|
||||||
|
*
|
||||||
|
**/
|
||||||
#define HB_DIRECTION_REVERSE(dir) ((hb_direction_t) (((unsigned int) (dir)) ^ 1))
|
#define HB_DIRECTION_REVERSE(dir) ((hb_direction_t) (((unsigned int) (dir)) ^ 1))
|
||||||
|
|
||||||
|
|
||||||
|
@ -173,7 +277,169 @@ HB_EXTERN hb_language_t
|
||||||
hb_language_get_default (void);
|
hb_language_get_default (void);
|
||||||
|
|
||||||
|
|
||||||
/* hb_script_t */
|
/**
|
||||||
|
* hb_script_t:
|
||||||
|
* @HB_SCRIPT_COMMON: HB_TAG ('Z','y','y','y')
|
||||||
|
* @HB_SCRIPT_INHERITED: HB_TAG ('Z','i','n','h')
|
||||||
|
* @HB_SCRIPT_UNKNOWN: HB_TAG ('Z','z','z','z')
|
||||||
|
* @HB_SCRIPT_ARABIC
|
||||||
|
* @HB_SCRIPT_ARMENIAN
|
||||||
|
* @HB_SCRIPT_BENGALI
|
||||||
|
* @HB_SCRIPT_CYRILLIC
|
||||||
|
* @HB_SCRIPT_DEVANAGARI
|
||||||
|
* @HB_SCRIPT_GEORGIAN
|
||||||
|
* @HB_SCRIPT_GREEK
|
||||||
|
* @HB_SCRIPT_GUJARATI
|
||||||
|
* @HB_SCRIPT_GURMUKHI
|
||||||
|
* @HB_SCRIPT_HANGUL
|
||||||
|
* @HB_SCRIPT_HAN
|
||||||
|
* @HB_SCRIPT_HEBREW
|
||||||
|
* @HB_SCRIPT_HIRAGANA
|
||||||
|
* @HB_SCRIPT_KANNADA
|
||||||
|
* @HB_SCRIPT_KATAKANA
|
||||||
|
* @HB_SCRIPT_LAO
|
||||||
|
* @HB_SCRIPT_LATIN
|
||||||
|
* @HB_SCRIPT_MALAYALAM
|
||||||
|
* @HB_SCRIPT_ORIYA
|
||||||
|
* @HB_SCRIPT_TAMIL
|
||||||
|
* @HB_SCRIPT_TELUGU
|
||||||
|
* @HB_SCRIPT_THAI
|
||||||
|
* @HB_SCRIPT_TIBETAN
|
||||||
|
* @HB_SCRIPT_BOPOMOFO
|
||||||
|
* @HB_SCRIPT_BRAILLE
|
||||||
|
* @HB_SCRIPT_CANADIAN_SYLLABICS
|
||||||
|
* @HB_SCRIPT_CHEROKEE
|
||||||
|
* @HB_SCRIPT_ETHIOPIC
|
||||||
|
* @HB_SCRIPT_KHMER
|
||||||
|
* @HB_SCRIPT_MONGOLIAN
|
||||||
|
* @HB_SCRIPT_MYANMAR
|
||||||
|
* @HB_SCRIPT_OGHAM
|
||||||
|
* @HB_SCRIPT_RUNIC
|
||||||
|
* @HB_SCRIPT_SINHALA
|
||||||
|
* @HB_SCRIPT_SYRIAC
|
||||||
|
* @HB_SCRIPT_THAANA
|
||||||
|
* @HB_SCRIPT_YI
|
||||||
|
* @HB_SCRIPT_DESERET
|
||||||
|
* @HB_SCRIPT_GOTHIC
|
||||||
|
* @HB_SCRIPT_OLD_ITALIC
|
||||||
|
* @HB_SCRIPT_BUHID
|
||||||
|
* @HB_SCRIPT_HANUNOO
|
||||||
|
* @HB_SCRIPT_TAGALOG
|
||||||
|
* @HB_SCRIPT_TAGBANWA
|
||||||
|
* @HB_SCRIPT_CYPRIOT
|
||||||
|
* @HB_SCRIPT_LIMBU
|
||||||
|
* @HB_SCRIPT_LINEAR_B
|
||||||
|
* @HB_SCRIPT_OSMANYA
|
||||||
|
* @HB_SCRIPT_SHAVIAN
|
||||||
|
* @HB_SCRIPT_TAI_LE
|
||||||
|
* @HB_SCRIPT_UGARITIC
|
||||||
|
* @HB_SCRIPT_BUGINESE
|
||||||
|
* @HB_SCRIPT_COPTIC
|
||||||
|
* @HB_SCRIPT_GLAGOLITIC
|
||||||
|
* @HB_SCRIPT_KHAROSHTHI
|
||||||
|
* @HB_SCRIPT_NEW_TAI_LUE
|
||||||
|
* @HB_SCRIPT_OLD_PERSIAN
|
||||||
|
* @HB_SCRIPT_SYLOTI_NAGRI
|
||||||
|
* @HB_SCRIPT_TIFINAGH
|
||||||
|
* @HB_SCRIPT_BALINESE
|
||||||
|
* @HB_SCRIPT_CUNEIFORM
|
||||||
|
* @HB_SCRIPT_NKO
|
||||||
|
* @HB_SCRIPT_PHAGS_PA
|
||||||
|
* @HB_SCRIPT_PHOENICIAN
|
||||||
|
* @HB_SCRIPT_CARIAN
|
||||||
|
* @HB_SCRIPT_CHAM
|
||||||
|
* @HB_SCRIPT_KAYAH_LI
|
||||||
|
* @HB_SCRIPT_LEPCHA
|
||||||
|
* @HB_SCRIPT_LYCIAN
|
||||||
|
* @HB_SCRIPT_LYDIAN
|
||||||
|
* @HB_SCRIPT_OL_CHIKI
|
||||||
|
* @HB_SCRIPT_REJANG
|
||||||
|
* @HB_SCRIPT_SAURASHTRA
|
||||||
|
* @HB_SCRIPT_SUNDANESE
|
||||||
|
* @HB_SCRIPT_VAI
|
||||||
|
* @HB_SCRIPT_AVESTAN
|
||||||
|
* @HB_SCRIPT_BAMUM
|
||||||
|
* @HB_SCRIPT_EGYPTIAN_HIEROGLYPHS
|
||||||
|
* @HB_SCRIPT_IMPERIAL_ARAMAIC
|
||||||
|
* @HB_SCRIPT_INSCRIPTIONAL_PAHLAVI
|
||||||
|
* @HB_SCRIPT_INSCRIPTIONAL_PARTHIAN
|
||||||
|
* @HB_SCRIPT_JAVANESE
|
||||||
|
* @HB_SCRIPT_KAITHI
|
||||||
|
* @HB_SCRIPT_LISU
|
||||||
|
* @HB_SCRIPT_MEETEI_MAYEK
|
||||||
|
* @HB_SCRIPT_OLD_SOUTH_ARABIAN
|
||||||
|
* @HB_SCRIPT_OLD_TURKIC
|
||||||
|
* @HB_SCRIPT_SAMARITAN
|
||||||
|
* @HB_SCRIPT_TAI_THAM
|
||||||
|
* @HB_SCRIPT_TAI_VIET
|
||||||
|
* @HB_SCRIPT_BATAK
|
||||||
|
* @HB_SCRIPT_BRAHMI
|
||||||
|
* @HB_SCRIPT_MANDAIC
|
||||||
|
* @HB_SCRIPT_CHAKMA
|
||||||
|
* @HB_SCRIPT_MEROITIC_CURSIVE
|
||||||
|
* @HB_SCRIPT_MEROITIC_HIEROGLYPHS
|
||||||
|
* @HB_SCRIPT_MIAO
|
||||||
|
* @HB_SCRIPT_SHARADA
|
||||||
|
* @HB_SCRIPT_SORA_SOMPENG
|
||||||
|
* @HB_SCRIPT_TAKRI
|
||||||
|
* @HB_SCRIPT_BASSA_VAH
|
||||||
|
* @HB_SCRIPT_CAUCASIAN_ALBANIAN
|
||||||
|
* @HB_SCRIPT_DUPLOYAN
|
||||||
|
* @HB_SCRIPT_ELBASAN
|
||||||
|
* @HB_SCRIPT_GRANTHA
|
||||||
|
* @HB_SCRIPT_KHOJKI
|
||||||
|
* @HB_SCRIPT_KHUDAWADI
|
||||||
|
* @HB_SCRIPT_LINEAR_A
|
||||||
|
* @HB_SCRIPT_MAHAJANI
|
||||||
|
* @HB_SCRIPT_MANICHAEAN
|
||||||
|
* @HB_SCRIPT_MENDE_KIKAKUI
|
||||||
|
* @HB_SCRIPT_MODI
|
||||||
|
* @HB_SCRIPT_MRO
|
||||||
|
* @HB_SCRIPT_NABATAEAN
|
||||||
|
* @HB_SCRIPT_OLD_NORTH_ARABIAN
|
||||||
|
* @HB_SCRIPT_OLD_PERMIC
|
||||||
|
* @HB_SCRIPT_PAHAWH_HMONG
|
||||||
|
* @HB_SCRIPT_PALMYRENE
|
||||||
|
* @HB_SCRIPT_PAU_CIN_HAU
|
||||||
|
* @HB_SCRIPT_PSALTER_PAHLAVI
|
||||||
|
* @HB_SCRIPT_SIDDHAM
|
||||||
|
* @HB_SCRIPT_TIRHUTA
|
||||||
|
* @HB_SCRIPT_WARANG_CITI
|
||||||
|
* @HB_SCRIPT_AHOM
|
||||||
|
* @HB_SCRIPT_ANATOLIAN_HIEROGLYPHS
|
||||||
|
* @HB_SCRIPT_HATRAN
|
||||||
|
* @HB_SCRIPT_MULTANI
|
||||||
|
* @HB_SCRIPT_OLD_HUNGARIAN
|
||||||
|
* @HB_SCRIPT_SIGNWRITING
|
||||||
|
* @HB_SCRIPT_ADLAM
|
||||||
|
* @HB_SCRIPT_BHAIKSUKI
|
||||||
|
* @HB_SCRIPT_MARCHEN
|
||||||
|
* @HB_SCRIPT_OSAGE
|
||||||
|
* @HB_SCRIPT_TANGUT
|
||||||
|
* @HB_SCRIPT_NEWA
|
||||||
|
* @HB_SCRIPT_MASARAM_GONDI
|
||||||
|
* @HB_SCRIPT_NUSHU
|
||||||
|
* @HB_SCRIPT_SOYOMBO
|
||||||
|
* @HB_SCRIPT_ZANABAZAR_SQUARE
|
||||||
|
* @HB_SCRIPT_DOGRA
|
||||||
|
* @HB_SCRIPT_GUNJALA_GONDI
|
||||||
|
* @HB_SCRIPT_HANIFI_ROHINGYA
|
||||||
|
* @HB_SCRIPT_MAKASAR
|
||||||
|
* @HB_SCRIPT_MEDEFAIDRIN
|
||||||
|
* @HB_SCRIPT_OLD_SOGDIAN
|
||||||
|
* @HB_SCRIPT_SOGDIAN
|
||||||
|
* @HB_SCRIPT_ELYMAIC
|
||||||
|
* @HB_SCRIPT_NANDINAGARI
|
||||||
|
* @HB_SCRIPT_NYIAKENG_PUACHUE_HMONG
|
||||||
|
* @HB_SCRIPT_WANCHO
|
||||||
|
* @HB_SCRIPT_INVALID: #HB_TAG_NONE
|
||||||
|
*
|
||||||
|
* Data type for scripts. Each #hb_script_t's value is an #hb_tag_t corresponding
|
||||||
|
* to the four-letter values defined by [ISO 15924](https://unicode.org/iso15924/).
|
||||||
|
*
|
||||||
|
* See also the Script (sc) property of the Unicode Character Database.
|
||||||
|
*
|
||||||
|
**/
|
||||||
|
|
||||||
/* https://unicode.org/iso15924/ */
|
/* https://unicode.org/iso15924/ */
|
||||||
/* https://docs.google.com/spreadsheets/d/1Y90M0Ie3MUJ6UVCRDOypOtijlMDLNNyyLk36T6iMu0o */
|
/* https://docs.google.com/spreadsheets/d/1Y90M0Ie3MUJ6UVCRDOypOtijlMDLNNyyLk36T6iMu0o */
|
||||||
|
@ -410,6 +676,12 @@ hb_script_get_horizontal_direction (hb_script_t script);
|
||||||
|
|
||||||
/* User data */
|
/* User data */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_user_data_key_t:
|
||||||
|
*
|
||||||
|
* Data structure for holding user-data keys.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef struct hb_user_data_key_t {
|
typedef struct hb_user_data_key_t {
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
char unused;
|
char unused;
|
||||||
|
@ -435,10 +707,10 @@ typedef void (*hb_destroy_func_t) (void *user_data);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_feature_t:
|
* hb_feature_t:
|
||||||
* @tag: a feature tag
|
* @tag: The #hb_tag_t tag of the feature
|
||||||
* @value: 0 disables the feature, non-zero (usually 1) enables the feature.
|
* @value: The value of the feature. 0 disables the feature, non-zero (usually
|
||||||
* For features implemented as lookup type 3 (like 'salt') the @value is a one
|
* 1) enables the feature. For features implemented as lookup type 3 (like
|
||||||
* based index into the alternates.
|
* 'salt') the @value is a one based index into the alternates.
|
||||||
* @start: the cluster to start applying this feature setting (inclusive).
|
* @start: the cluster to start applying this feature setting (inclusive).
|
||||||
* @end: the cluster to end applying this feature setting (exclusive).
|
* @end: the cluster to end applying this feature setting (exclusive).
|
||||||
*
|
*
|
||||||
|
@ -465,6 +737,12 @@ hb_feature_to_string (hb_feature_t *feature,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_variation_t:
|
* hb_variation_t:
|
||||||
|
* @tag: The #hb_tag_t tag of the variation-axis name
|
||||||
|
* @value: The value of the variation axis
|
||||||
|
*
|
||||||
|
* Data type for holding variation data. Registered OpenType
|
||||||
|
* variation-axis tags are listed at
|
||||||
|
* https://docs.microsoft.com/en-us/typography/opentype/spec/dvaraxisreg
|
||||||
*
|
*
|
||||||
* Since: 1.4.2
|
* Since: 1.4.2
|
||||||
*/
|
*/
|
||||||
|
@ -484,7 +762,8 @@ hb_variation_to_string (hb_variation_t *variation,
|
||||||
/**
|
/**
|
||||||
* hb_color_t:
|
* hb_color_t:
|
||||||
*
|
*
|
||||||
* Data type for holding color values.
|
* Data type for holding color values. Colors are eight bits per
|
||||||
|
* channel RGB plus alpha transparency.
|
||||||
*
|
*
|
||||||
* Since: 2.1.0
|
* Since: 2.1.0
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -304,7 +304,7 @@ hb_face_destroy (hb_face_t *face)
|
||||||
*
|
*
|
||||||
* Attaches a user-data key/data pair to the given face object.
|
* Attaches a user-data key/data pair to the given face object.
|
||||||
*
|
*
|
||||||
* Return value: %true if success, false otherwise
|
* Return value: %true if success, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
|
704
src/hb-font.cc
704
src/hb-font.cc
File diff suppressed because it is too large
Load Diff
385
src/hb-font.h
385
src/hb-font.h
|
@ -45,6 +45,19 @@ typedef struct hb_font_t hb_font_t;
|
||||||
* hb_font_funcs_t
|
* hb_font_funcs_t
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_funcs_t:
|
||||||
|
*
|
||||||
|
* Data type containing a set of virtual methods used for
|
||||||
|
* working on #hb_font_t font objects.
|
||||||
|
*
|
||||||
|
* HarfBuzz provides a lightweight default function for each of
|
||||||
|
* the methods in #hb_font_funcs_t. Client programs can implement
|
||||||
|
* their own replacements for the individual font functions, as
|
||||||
|
* needed, and replace the default by calling the setter for a
|
||||||
|
* method.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef struct hb_font_funcs_t hb_font_funcs_t;
|
typedef struct hb_font_funcs_t hb_font_funcs_t;
|
||||||
|
|
||||||
HB_EXTERN hb_font_funcs_t *
|
HB_EXTERN hb_font_funcs_t *
|
||||||
|
@ -81,11 +94,21 @@ hb_font_funcs_is_immutable (hb_font_funcs_t *ffuncs);
|
||||||
|
|
||||||
/* font and glyph extents */
|
/* font and glyph extents */
|
||||||
|
|
||||||
/* Note that typically ascender is positive and descender negative in coordinate systems that grow up. */
|
/**
|
||||||
|
* hb_font_extents_t:
|
||||||
|
* @ascender: The height of typographic ascenders.
|
||||||
|
* @descender: The depth of typographic descenders.
|
||||||
|
* @line_gap: The suggested line-spacing gap.
|
||||||
|
*
|
||||||
|
* Font-wide extent values, measured in font units.
|
||||||
|
*
|
||||||
|
* Note that typically @ascender is positive and @descender
|
||||||
|
* negative, in coordinate systems that grow up.
|
||||||
|
**/
|
||||||
typedef struct hb_font_extents_t {
|
typedef struct hb_font_extents_t {
|
||||||
hb_position_t ascender; /* typographic ascender. */
|
hb_position_t ascender;
|
||||||
hb_position_t descender; /* typographic descender. */
|
hb_position_t descender;
|
||||||
hb_position_t line_gap; /* suggested line spacing gap. */
|
hb_position_t line_gap;
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
hb_position_t reserved9;
|
hb_position_t reserved9;
|
||||||
hb_position_t reserved8;
|
hb_position_t reserved8;
|
||||||
|
@ -98,12 +121,22 @@ typedef struct hb_font_extents_t {
|
||||||
hb_position_t reserved1;
|
hb_position_t reserved1;
|
||||||
} hb_font_extents_t;
|
} hb_font_extents_t;
|
||||||
|
|
||||||
/* Note that height is negative in coordinate systems that grow up. */
|
/**
|
||||||
|
* hb_glyph_extents_t:
|
||||||
|
* @x_bearing: Distance from the x-origin to the left extremum of the glyph.
|
||||||
|
* @y_bearing: Distance from the top extremum of the glyph to the y-origin.
|
||||||
|
* @width: Distance from the left extremum of the glyph to the right extremum.
|
||||||
|
* @height: Distance from the top extremum of the glyph to the bottom extremum.
|
||||||
|
*
|
||||||
|
* Glyph extent values, measured in font units.
|
||||||
|
*
|
||||||
|
* Note that @height is negative, in coordinate systems that grow up.
|
||||||
|
**/
|
||||||
typedef struct hb_glyph_extents_t {
|
typedef struct hb_glyph_extents_t {
|
||||||
hb_position_t x_bearing; /* left side of glyph from origin. */
|
hb_position_t x_bearing;
|
||||||
hb_position_t y_bearing; /* top side of glyph from origin. */
|
hb_position_t y_bearing;
|
||||||
hb_position_t width; /* distance from left to right side. */
|
hb_position_t width;
|
||||||
hb_position_t height; /* distance from top to bottom side. */
|
hb_position_t height;
|
||||||
} hb_glyph_extents_t;
|
} hb_glyph_extents_t;
|
||||||
|
|
||||||
/* func types */
|
/* func types */
|
||||||
|
@ -111,19 +144,72 @@ typedef struct hb_glyph_extents_t {
|
||||||
typedef hb_bool_t (*hb_font_get_font_extents_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_font_extents_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_font_extents_t *extents,
|
hb_font_extents_t *extents,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_font_h_extents_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the extents for a font, in horizontal-direction
|
||||||
|
* text segments. Extents must be returned in an #hb_glyph_extents output
|
||||||
|
* parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_font_extents_func_t hb_font_get_font_h_extents_func_t;
|
typedef hb_font_get_font_extents_func_t hb_font_get_font_h_extents_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_font_v_extents_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the extents for a font, in vertical-direction
|
||||||
|
* text segments. Extents must be returned in an #hb_glyph_extents output
|
||||||
|
* parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_font_extents_func_t hb_font_get_font_v_extents_func_t;
|
typedef hb_font_get_font_extents_func_t hb_font_get_font_v_extents_func_t;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_nominal_glyph_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the nominal glyph ID for a specified Unicode code
|
||||||
|
* point. Glyph IDs must be returned in a #hb_codepoint_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_nominal_glyph_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_nominal_glyph_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t unicode,
|
hb_codepoint_t unicode,
|
||||||
hb_codepoint_t *glyph,
|
hb_codepoint_t *glyph,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_variation_glyph_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the glyph ID for a specified Unicode code point
|
||||||
|
* followed by a specified Variation Selector code point. Glyph IDs must be
|
||||||
|
* returned in a #hb_codepoint_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_variation_glyph_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_variation_glyph_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t unicode, hb_codepoint_t variation_selector,
|
hb_codepoint_t unicode, hb_codepoint_t variation_selector,
|
||||||
hb_codepoint_t *glyph,
|
hb_codepoint_t *glyph,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_nominal_glyphs_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the nominal glyph IDs for a sequence of
|
||||||
|
* Unicode code points. Glyph IDs must be returned in a #hb_codepoint_t
|
||||||
|
* output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef unsigned int (*hb_font_get_nominal_glyphs_func_t) (hb_font_t *font, void *font_data,
|
typedef unsigned int (*hb_font_get_nominal_glyphs_func_t) (hb_font_t *font, void *font_data,
|
||||||
unsigned int count,
|
unsigned int count,
|
||||||
const hb_codepoint_t *first_unicode,
|
const hb_codepoint_t *first_unicode,
|
||||||
|
@ -132,13 +218,51 @@ typedef unsigned int (*hb_font_get_nominal_glyphs_func_t) (hb_font_t *font, void
|
||||||
unsigned int glyph_stride,
|
unsigned int glyph_stride,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_advance_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advance for a specified glyph. The
|
||||||
|
* method must return an #hb_position_t.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_position_t (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_position_t (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_h_advance_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advance for a specified glyph, in
|
||||||
|
* horizontal-direction text segments. Advances must be returned in
|
||||||
|
* an #hb_position_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_h_advance_func_t;
|
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_h_advance_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_v_advance_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advance for a specified glyph, in
|
||||||
|
* vertical-direction text segments. Advances must be returned in
|
||||||
|
* an #hb_position_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_v_advance_func_t;
|
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_v_advance_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_advances_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advances for a sequence of glyphs.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef void (*hb_font_get_glyph_advances_func_t) (hb_font_t* font, void* font_data,
|
typedef void (*hb_font_get_glyph_advances_func_t) (hb_font_t* font, void* font_data,
|
||||||
unsigned int count,
|
unsigned int count,
|
||||||
const hb_codepoint_t *first_glyph,
|
const hb_codepoint_t *first_glyph,
|
||||||
|
@ -146,14 +270,66 @@ typedef void (*hb_font_get_glyph_advances_func_t) (hb_font_t* font, void* font_d
|
||||||
hb_position_t *first_advance,
|
hb_position_t *first_advance,
|
||||||
unsigned advance_stride,
|
unsigned advance_stride,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_h_advances_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advances for a sequence of glyphs, in
|
||||||
|
* horizontal-direction text segments.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_h_advances_func_t;
|
typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_h_advances_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_v_advances_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the advances for a sequence of glyphs, in
|
||||||
|
* vertical-direction text segments.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_v_advances_func_t;
|
typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_v_advances_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_origin_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the (X,Y) coordinates (in font units) of the
|
||||||
|
* origin for a glyph. Each coordinate must be returned in an #hb_position_t
|
||||||
|
* output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_origin_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_origin_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x, hb_position_t *y,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_h_origin_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the (X,Y) coordinates (in font units) of the
|
||||||
|
* origin for a glyph, in horizontal-direction text segments. Each
|
||||||
|
* coordinate must be returned in an #hb_position_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_h_origin_func_t;
|
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_h_origin_func_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_v_origin_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the (X,Y) coordinates (in font units) of the
|
||||||
|
* origin for a glyph, in vertical-direction text segments. Each coordinate
|
||||||
|
* must be returned in an #hb_position_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_v_origin_func_t;
|
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_v_origin_func_t;
|
||||||
|
|
||||||
typedef hb_position_t (*hb_font_get_glyph_kerning_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_position_t (*hb_font_get_glyph_kerning_func_t) (hb_font_t *font, void *font_data,
|
||||||
|
@ -162,20 +338,59 @@ typedef hb_position_t (*hb_font_get_glyph_kerning_func_t) (hb_font_t *font, void
|
||||||
typedef hb_font_get_glyph_kerning_func_t hb_font_get_glyph_h_kerning_func_t;
|
typedef hb_font_get_glyph_kerning_func_t hb_font_get_glyph_h_kerning_func_t;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_extents_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the extents for a specified glyph. Extents must be
|
||||||
|
* returned in an #hb_glyph_extents output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_glyph_extents_t *extents,
|
hb_glyph_extents_t *extents,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_contour_point_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the (X,Y) coordinates (in font units) for a
|
||||||
|
* specified contour point in a glyph. Each coordinate must be returned as
|
||||||
|
* an #hb_position_t output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_contour_point_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_contour_point_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_position_t *x, hb_position_t *y,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_name_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the glyph name that corresponds to a
|
||||||
|
* glyph ID. The name should be returned in a string output parameter.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_name_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_name_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
char *name, unsigned int size,
|
char *name, unsigned int size,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_font_get_glyph_from_name_func_t:
|
||||||
|
*
|
||||||
|
* A virtual method for the #hb_font_funcs_t of an #hb_font_t object.
|
||||||
|
*
|
||||||
|
* This method should retrieve the glyph ID that corresponds to a glyph-name
|
||||||
|
* string.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_from_name_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_from_name_func_t) (hb_font_t *font, void *font_data,
|
||||||
const char *name, int len, /* -1 means nul-terminated */
|
const char *name, int len, /* -1 means nul-terminated */
|
||||||
hb_codepoint_t *glyph,
|
hb_codepoint_t *glyph,
|
||||||
|
@ -186,12 +401,12 @@ typedef hb_bool_t (*hb_font_get_glyph_from_name_func_t) (hb_font_t *font, void *
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_font_h_extents_func:
|
* hb_font_funcs_set_font_h_extents_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_font_h_extents_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.1.2
|
* Since: 1.1.2
|
||||||
**/
|
**/
|
||||||
|
@ -202,12 +417,12 @@ hb_font_funcs_set_font_h_extents_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_font_v_extents_func:
|
* hb_font_funcs_set_font_v_extents_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_font_v_extents_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.1.2
|
* Since: 1.1.2
|
||||||
**/
|
**/
|
||||||
|
@ -218,12 +433,12 @@ hb_font_funcs_set_font_v_extents_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_nominal_glyph_func:
|
* hb_font_funcs_set_nominal_glyph_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_nominal_glyph_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.2.3
|
* Since: 1.2.3
|
||||||
**/
|
**/
|
||||||
|
@ -234,12 +449,12 @@ hb_font_funcs_set_nominal_glyph_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_nominal_glyphs_func:
|
* hb_font_funcs_set_nominal_glyphs_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_nominal_glyphs_func_t.
|
||||||
*
|
*
|
||||||
* Since: 2.0.0
|
* Since: 2.0.0
|
||||||
**/
|
**/
|
||||||
|
@ -250,12 +465,12 @@ hb_font_funcs_set_nominal_glyphs_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_variation_glyph_func:
|
* hb_font_funcs_set_variation_glyph_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_variation_glyph_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.2.3
|
* Since: 1.2.3
|
||||||
**/
|
**/
|
||||||
|
@ -266,12 +481,12 @@ hb_font_funcs_set_variation_glyph_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_h_advance_func:
|
* hb_font_funcs_set_glyph_h_advance_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_h_advance_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -282,12 +497,12 @@ hb_font_funcs_set_glyph_h_advance_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_v_advance_func:
|
* hb_font_funcs_set_glyph_v_advance_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_v_advance_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -298,12 +513,12 @@ hb_font_funcs_set_glyph_v_advance_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_h_advances_func:
|
* hb_font_funcs_set_glyph_h_advances_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_h_advances_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.8.6
|
* Since: 1.8.6
|
||||||
**/
|
**/
|
||||||
|
@ -314,12 +529,12 @@ hb_font_funcs_set_glyph_h_advances_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_v_advances_func:
|
* hb_font_funcs_set_glyph_v_advances_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_v_advances_func_t.
|
||||||
*
|
*
|
||||||
* Since: 1.8.6
|
* Since: 1.8.6
|
||||||
**/
|
**/
|
||||||
|
@ -330,12 +545,12 @@ hb_font_funcs_set_glyph_v_advances_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_h_origin_func:
|
* hb_font_funcs_set_glyph_h_origin_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_h_origin_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -346,12 +561,12 @@ hb_font_funcs_set_glyph_h_origin_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_v_origin_func:
|
* hb_font_funcs_set_glyph_v_origin_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_v_origin_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -378,12 +593,12 @@ hb_font_funcs_set_glyph_h_kerning_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_extents_func:
|
* hb_font_funcs_set_glyph_extents_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_extents_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -394,12 +609,12 @@ hb_font_funcs_set_glyph_extents_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_contour_point_func:
|
* hb_font_funcs_set_glyph_contour_point_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_contour_point_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -410,12 +625,12 @@ hb_font_funcs_set_glyph_contour_point_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_name_func:
|
* hb_font_funcs_set_glyph_name_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_name_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -426,12 +641,12 @@ hb_font_funcs_set_glyph_name_func (hb_font_funcs_t *ffuncs,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_font_funcs_set_glyph_from_name_func:
|
* hb_font_funcs_set_glyph_from_name_func:
|
||||||
* @ffuncs: font functions.
|
* @ffuncs: A font-function structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified):
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data:
|
* @user_data: Data to pass to @func
|
||||||
* @destroy:
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Sets the implementation function for #hb_font_get_glyph_from_name_func_t.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -661,7 +661,7 @@ _hb_ft_reference_table (hb_face_t *face HB_UNUSED, hb_tag_t tag, void *user_data
|
||||||
/**
|
/**
|
||||||
* hb_ft_face_create:
|
* hb_ft_face_create:
|
||||||
* @ft_face: (destroy destroy) (scope notified): FT_Face to work upon
|
* @ft_face: (destroy destroy) (scope notified): FT_Face to work upon
|
||||||
* @destroy: A callback to call when the face object is not needed anymore
|
* @destroy: (optional): A callback to call when the face object is not needed anymore
|
||||||
*
|
*
|
||||||
* Creates an #hb_face_t face object from the specified FT_Face.
|
* Creates an #hb_face_t face object from the specified FT_Face.
|
||||||
*
|
*
|
||||||
|
|
|
@ -42,7 +42,9 @@
|
||||||
/**
|
/**
|
||||||
* hb_map_create: (Xconstructor)
|
* hb_map_create: (Xconstructor)
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Creates a new, initially empty map.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The new #hb_map_t
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -62,7 +64,9 @@ hb_map_create ()
|
||||||
/**
|
/**
|
||||||
* hb_map_get_empty:
|
* hb_map_get_empty:
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Fetches the singleton empty #hb_map_t.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The empty #hb_map_t
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -74,9 +78,11 @@ hb_map_get_empty ()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_reference: (skip)
|
* hb_map_reference: (skip)
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Increases the reference count on a map.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The map
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -88,7 +94,11 @@ hb_map_reference (hb_map_t *map)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_destroy: (skip)
|
* hb_map_destroy: (skip)
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
|
*
|
||||||
|
* Decreases the reference count on a map. When
|
||||||
|
* the reference count reaches zero, the map is
|
||||||
|
* destroyed, freeing all memory.
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -104,13 +114,15 @@ hb_map_destroy (hb_map_t *map)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_set_user_data: (skip)
|
* hb_map_set_user_data: (skip)
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The user-data key to set
|
||||||
* @data:
|
* @data: A pointer to the user data to set
|
||||||
* @destroy:
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace:
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
* Return value:
|
* Attaches a user-data key/data pair to the specified map.
|
||||||
|
*
|
||||||
|
* Return value: %true if success, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -126,10 +138,13 @@ hb_map_set_user_data (hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_get_user_data: (skip)
|
* hb_map_get_user_data: (skip)
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The user-data key to query
|
||||||
*
|
*
|
||||||
* Return value: (transfer none):
|
* Fetches the user data associated with the specified key,
|
||||||
|
* attached to the specified map.
|
||||||
|
*
|
||||||
|
* Return value: (transfer none): A pointer to the user data
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -143,11 +158,11 @@ hb_map_get_user_data (hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_allocation_successful:
|
* hb_map_allocation_successful:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
*
|
*
|
||||||
|
* Tests whether memory allocation for a set was successful.
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if allocation succeeded, false otherwise
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -160,11 +175,11 @@ hb_map_allocation_successful (const hb_map_t *map)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_set:
|
* hb_map_set:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The key to store in the map
|
||||||
* @value:
|
* @value: The value to store for @key
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Stores @key:@value in the map.
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -178,10 +193,10 @@ hb_map_set (hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_get:
|
* hb_map_get:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The key to query
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Fetches the value stored for @key in @map.
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -194,10 +209,10 @@ hb_map_get (const hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_del:
|
* hb_map_del:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The key to delete
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Removes @key and its stored value from @map.
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -210,10 +225,12 @@ hb_map_del (hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_has:
|
* hb_map_has:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
* @key:
|
* @key: The key to query
|
||||||
*
|
*
|
||||||
|
* Tests whether @key is an element of @map.
|
||||||
*
|
*
|
||||||
|
* Return value: %true if @key is found in @map, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -227,9 +244,9 @@ hb_map_has (const hb_map_t *map,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_clear:
|
* hb_map_clear:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Clears out the contents of @map.
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -241,9 +258,11 @@ hb_map_clear (hb_map_t *map)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_is_empty:
|
* hb_map_is_empty:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
*
|
*
|
||||||
|
* Tests whether @map is empty (contains no elements).
|
||||||
*
|
*
|
||||||
|
* Return value: %true if @map is empty
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
@ -255,9 +274,11 @@ hb_map_is_empty (const hb_map_t *map)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_map_get_population:
|
* hb_map_get_population:
|
||||||
* @map: a map.
|
* @map: A map
|
||||||
*
|
*
|
||||||
|
* Returns the number of key-value pairs in the map.
|
||||||
*
|
*
|
||||||
|
* Return value: The population of @map
|
||||||
*
|
*
|
||||||
* Since: 1.7.7
|
* Since: 1.7.7
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -41,6 +41,12 @@ HB_BEGIN_DECLS
|
||||||
*/
|
*/
|
||||||
#define HB_MAP_VALUE_INVALID ((hb_codepoint_t) -1)
|
#define HB_MAP_VALUE_INVALID ((hb_codepoint_t) -1)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_map_t:
|
||||||
|
*
|
||||||
|
* Data type for holding integer-to-integer hash maps.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef struct hb_map_t hb_map_t;
|
typedef struct hb_map_t hb_map_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
207
src/hb-set.cc
207
src/hb-set.cc
|
@ -30,11 +30,11 @@
|
||||||
/**
|
/**
|
||||||
* SECTION:hb-set
|
* SECTION:hb-set
|
||||||
* @title: hb-set
|
* @title: hb-set
|
||||||
* @short_description: Object representing a set of integers
|
* @short_description: Objects representing a set of integers
|
||||||
* @include: hb.h
|
* @include: hb.h
|
||||||
*
|
*
|
||||||
* Set objects represent a mathematical set of integer values. They are
|
* Set objects represent a mathematical set of integer values. They are
|
||||||
* used in non-shaping API to query certain set of characters or glyphs,
|
* used in non-shaping APIs to query certain sets of characters or glyphs,
|
||||||
* or other integer values.
|
* or other integer values.
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
@ -42,7 +42,9 @@
|
||||||
/**
|
/**
|
||||||
* hb_set_create: (Xconstructor)
|
* hb_set_create: (Xconstructor)
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Creates a new, initially empty set.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The new #hb_set_t
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -62,7 +64,9 @@ hb_set_create ()
|
||||||
/**
|
/**
|
||||||
* hb_set_get_empty:
|
* hb_set_get_empty:
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Fetches the singleton empty #hb_set_t.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The empty #hb_set_t
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -74,9 +78,11 @@ hb_set_get_empty ()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_reference: (skip)
|
* hb_set_reference: (skip)
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
*
|
||||||
* Return value: (transfer full):
|
* Increases the reference count on a set.
|
||||||
|
*
|
||||||
|
* Return value: (transfer full): The set
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -88,7 +94,11 @@ hb_set_reference (hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_destroy: (skip)
|
* hb_set_destroy: (skip)
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
|
*
|
||||||
|
* Decreases the reference count on a set. When
|
||||||
|
* the reference count reaches zero, the set is
|
||||||
|
* destroyed, freeing all memory.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -104,13 +114,15 @@ hb_set_destroy (hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_set_user_data: (skip)
|
* hb_set_set_user_data: (skip)
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @key:
|
* @key: The user-data key to set
|
||||||
* @data:
|
* @data: A pointer to the user data to set
|
||||||
* @destroy:
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace:
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
* Return value:
|
* Attaches a user-data key/data pair to the specified set.
|
||||||
|
*
|
||||||
|
* Return value: %true if success, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -126,10 +138,13 @@ hb_set_set_user_data (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_get_user_data: (skip)
|
* hb_set_get_user_data: (skip)
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @key:
|
* @key: The user-data key to query
|
||||||
*
|
*
|
||||||
* Return value: (transfer none):
|
* Fetches the user data associated with the specified key,
|
||||||
|
* attached to the specified set.
|
||||||
|
*
|
||||||
|
* Return value: (transfer none): A pointer to the user data
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -143,11 +158,11 @@ hb_set_get_user_data (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_allocation_successful:
|
* hb_set_allocation_successful:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
*
|
||||||
|
* Tests whether memory allocation for a set was successful.
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if allocation succeeded, false otherwise
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -159,9 +174,9 @@ hb_set_allocation_successful (const hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_clear:
|
* hb_set_clear:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Clears out the contents of a set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -175,9 +190,9 @@ hb_set_clear (hb_set_t *set)
|
||||||
* hb_set_is_empty:
|
* hb_set_is_empty:
|
||||||
* @set: a set.
|
* @set: a set.
|
||||||
*
|
*
|
||||||
|
* Tests whether a set is empty (contains no elements).
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if @set is empty
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -189,12 +204,12 @@ hb_set_is_empty (const hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_has:
|
* hb_set_has:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @codepoint:
|
* @codepoint: The element to query
|
||||||
*
|
*
|
||||||
|
* Tests whether @codepoint belongs to @set.
|
||||||
*
|
*
|
||||||
*
|
* Return value: %true if @codepoint is in @set, false otherwise
|
||||||
* Return value:
|
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -207,10 +222,10 @@ hb_set_has (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_add:
|
* hb_set_add:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @codepoint:
|
* @codepoint: The element to add to @set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Adds @codepoint to @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -223,11 +238,12 @@ hb_set_add (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_add_range:
|
* hb_set_add_range:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @first:
|
* @first: The first element to add to @set
|
||||||
* @last:
|
* @last: The final element to add to @set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Adds all of the elements from @first to @last
|
||||||
|
* (inclusive) to @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -241,10 +257,10 @@ hb_set_add_range (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_del:
|
* hb_set_del:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @codepoint:
|
* @codepoint: Removes @codepoint from @set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Removes @codepoint from @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -257,11 +273,12 @@ hb_set_del (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_del_range:
|
* hb_set_del_range:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @first:
|
* @first: The first element to remove from @set
|
||||||
* @last:
|
* @last: The final element to remove from @set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Removes all of the elements from @first to @last
|
||||||
|
* (inclusive) from @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -275,10 +292,11 @@ hb_set_del_range (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_is_equal:
|
* hb_set_is_equal:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other: other set.
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Tests whether @set and @other are equal (contain the same
|
||||||
|
* elements).
|
||||||
*
|
*
|
||||||
* Return value: %TRUE if the two sets are equal, %FALSE otherwise.
|
* Return value: %TRUE if the two sets are equal, %FALSE otherwise.
|
||||||
*
|
*
|
||||||
|
@ -293,10 +311,10 @@ hb_set_is_equal (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_is_subset:
|
* hb_set_is_subset:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @larger_set: other set.
|
* @larger_set: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Tests whether @set is a subset of @larger_set.
|
||||||
*
|
*
|
||||||
* Return value: %TRUE if the @set is a subset of (or equal to) @larger_set, %FALSE otherwise.
|
* Return value: %TRUE if the @set is a subset of (or equal to) @larger_set, %FALSE otherwise.
|
||||||
*
|
*
|
||||||
|
@ -311,10 +329,10 @@ hb_set_is_subset (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_set:
|
* hb_set_set:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other:
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Makes the contents of @set equal to the contents of @other.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -327,10 +345,10 @@ hb_set_set (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_union:
|
* hb_set_union:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other:
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Makes @set the union of @set and @other.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -343,10 +361,10 @@ hb_set_union (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_intersect:
|
* hb_set_intersect:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other:
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Makes @set the intersection of @set and @other.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -359,10 +377,10 @@ hb_set_intersect (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_subtract:
|
* hb_set_subtract:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other:
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Subtracts the contents of @other from @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -375,10 +393,11 @@ hb_set_subtract (hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_symmetric_difference:
|
* hb_set_symmetric_difference:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @other:
|
* @other: Another set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Makes @set the symmetric difference of @set
|
||||||
|
* and @other.
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -392,9 +411,9 @@ hb_set_symmetric_difference (hb_set_t *set,
|
||||||
#ifndef HB_DISABLE_DEPRECATED
|
#ifndef HB_DISABLE_DEPRECATED
|
||||||
/**
|
/**
|
||||||
* hb_set_invert:
|
* hb_set_invert:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
|
||||||
*
|
*
|
||||||
|
* Inverts the contents of @set.
|
||||||
*
|
*
|
||||||
* Since: 0.9.10
|
* Since: 0.9.10
|
||||||
*
|
*
|
||||||
|
@ -408,11 +427,11 @@ hb_set_invert (hb_set_t *set HB_UNUSED)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_get_population:
|
* hb_set_get_population:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
*
|
||||||
* Returns the number of numbers in the set.
|
* Returns the number of elements in the set.
|
||||||
*
|
*
|
||||||
* Return value: set population.
|
* Return value: The population of @set
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -424,11 +443,11 @@ hb_set_get_population (const hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_get_min:
|
* hb_set_get_min:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
*
|
||||||
* Finds the minimum number in the set.
|
* Finds the smallest element in the set.
|
||||||
*
|
*
|
||||||
* Return value: minimum of the set, or %HB_SET_VALUE_INVALID if set is empty.
|
* Return value: minimum of @set, or %HB_SET_VALUE_INVALID if @set is empty.
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -440,11 +459,11 @@ hb_set_get_min (const hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_get_max:
|
* hb_set_get_max:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
*
|
*
|
||||||
* Finds the maximum number in the set.
|
* Finds the largest element in the set.
|
||||||
*
|
*
|
||||||
* Return value: minimum of the set, or %HB_SET_VALUE_INVALID if set is empty.
|
* Return value: maximum of @set, or %HB_SET_VALUE_INVALID if @set is empty.
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -456,14 +475,15 @@ hb_set_get_max (const hb_set_t *set)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_next:
|
* hb_set_next:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @codepoint: (inout):
|
* @codepoint: (inout): Input = Code point to query
|
||||||
|
* Output = Code point retrieved
|
||||||
*
|
*
|
||||||
* Gets the next number in @set that is greater than current value of @codepoint.
|
* Fetches the next element in @set that is greater than current value of @codepoint.
|
||||||
*
|
*
|
||||||
* Set @codepoint to %HB_SET_VALUE_INVALID to get started.
|
* Set @codepoint to %HB_SET_VALUE_INVALID to get started.
|
||||||
*
|
*
|
||||||
* Return value: whether there was a next value.
|
* Return value: %true if there was a next value, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
@ -476,14 +496,15 @@ hb_set_next (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_previous:
|
* hb_set_previous:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @codepoint: (inout):
|
* @codepoint: (inout): Input = Code point to query
|
||||||
|
* Output = Code point retrieved
|
||||||
*
|
*
|
||||||
* Gets the previous number in @set that is lower than current value of @codepoint.
|
* Fetches the previous element in @set that is lower than current value of @codepoint.
|
||||||
*
|
*
|
||||||
* Set @codepoint to %HB_SET_VALUE_INVALID to get started.
|
* Set @codepoint to %HB_SET_VALUE_INVALID to get started.
|
||||||
*
|
*
|
||||||
* Return value: whether there was a previous value.
|
* Return value: %true if there was a previous value, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.8.0
|
* Since: 1.8.0
|
||||||
**/
|
**/
|
||||||
|
@ -496,16 +517,17 @@ hb_set_previous (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_next_range:
|
* hb_set_next_range:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @first: (out): output first codepoint in the range.
|
* @first: (out): The first code point in the range
|
||||||
* @last: (inout): input current last and output last codepoint in the range.
|
* @last: (inout): Input = The current last code point in the range
|
||||||
|
* Output = The last code point in the range
|
||||||
*
|
*
|
||||||
* Gets the next consecutive range of numbers in @set that
|
* Fetches the next consecutive range of elements in @set that
|
||||||
* are greater than current value of @last.
|
* are greater than current value of @last.
|
||||||
*
|
*
|
||||||
* Set @last to %HB_SET_VALUE_INVALID to get started.
|
* Set @last to %HB_SET_VALUE_INVALID to get started.
|
||||||
*
|
*
|
||||||
* Return value: whether there was a next range.
|
* Return value: %true if there was a next range, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.7
|
* Since: 0.9.7
|
||||||
**/
|
**/
|
||||||
|
@ -519,16 +541,17 @@ hb_set_next_range (const hb_set_t *set,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* hb_set_previous_range:
|
* hb_set_previous_range:
|
||||||
* @set: a set.
|
* @set: A set
|
||||||
* @first: (inout): input current first and output first codepoint in the range.
|
* @first: (inout): Input = The current first code point in the range
|
||||||
* @last: (out): output last codepoint in the range.
|
* Output = The first code point in the range
|
||||||
|
* @last: (out): The last code point in the range
|
||||||
*
|
*
|
||||||
* Gets the previous consecutive range of numbers in @set that
|
* Fetches the previous consecutive range of elements in @set that
|
||||||
* are less than current value of @first.
|
* are greater than current value of @last.
|
||||||
*
|
*
|
||||||
* Set @first to %HB_SET_VALUE_INVALID to get started.
|
* Set @first to %HB_SET_VALUE_INVALID to get started.
|
||||||
*
|
*
|
||||||
* Return value: whether there was a previous range.
|
* Return value: %true if there was a previous range, false otherwise
|
||||||
*
|
*
|
||||||
* Since: 1.8.0
|
* Since: 1.8.0
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -41,6 +41,15 @@ HB_BEGIN_DECLS
|
||||||
*/
|
*/
|
||||||
#define HB_SET_VALUE_INVALID ((hb_codepoint_t) -1)
|
#define HB_SET_VALUE_INVALID ((hb_codepoint_t) -1)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hb_set_t:
|
||||||
|
*
|
||||||
|
* Data type for holding a set of integers. #hb_set_t's are
|
||||||
|
* used to gather and contain glyph IDs, Unicode code
|
||||||
|
* points, and various other collections of discrete
|
||||||
|
* values.
|
||||||
|
*
|
||||||
|
**/
|
||||||
typedef struct hb_set_t hb_set_t;
|
typedef struct hb_set_t hb_set_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -329,7 +329,7 @@ hb_shape_plan_destroy (hb_shape_plan_t *shape_plan)
|
||||||
* @shape_plan: A shaping plan
|
* @shape_plan: A shaping plan
|
||||||
* @key: The user-data key to set
|
* @key: The user-data key to set
|
||||||
* @data: A pointer to the user data
|
* @data: A pointer to the user data
|
||||||
* @destroy: A callback to call when @data is not needed anymore
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace: Whether to replace an existing data with the same key
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
* Attaches a user-data key/data pair to the given shaping plan.
|
* Attaches a user-data key/data pair to the given shaping plan.
|
||||||
|
|
|
@ -276,12 +276,12 @@ hb_unicode_funcs_destroy (hb_unicode_funcs_t *ufuncs)
|
||||||
* @ufuncs: The Unicode-functions structure
|
* @ufuncs: The Unicode-functions structure
|
||||||
* @key: The user-data key
|
* @key: The user-data key
|
||||||
* @data: A pointer to the user data
|
* @data: A pointer to the user data
|
||||||
* @destroy: A callback to call when @data is not needed anymore
|
* @destroy: (optional): A callback to call when @data is not needed anymore
|
||||||
* @replace: Whether to replace an existing data with the same key
|
* @replace: Whether to replace an existing data with the same key
|
||||||
*
|
*
|
||||||
* Attaches a user-data key/data pair to the specified Unicode-functions structure.
|
* Attaches a user-data key/data pair to the specified Unicode-functions structure.
|
||||||
*
|
*
|
||||||
* Return value: %true if success, false otherwise
|
* Return value: %true if success, %false otherwise
|
||||||
*
|
*
|
||||||
* Since: 0.9.2
|
* Since: 0.9.2
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -431,7 +431,7 @@ typedef hb_bool_t (*hb_unicode_decompose_func_t) (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_combining_class_func_t.
|
* Sets the implementation function for #hb_unicode_combining_class_func_t.
|
||||||
*
|
*
|
||||||
|
@ -447,7 +447,7 @@ hb_unicode_funcs_set_combining_class_func (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_general_category_func_t.
|
* Sets the implementation function for #hb_unicode_general_category_func_t.
|
||||||
*
|
*
|
||||||
|
@ -463,7 +463,7 @@ hb_unicode_funcs_set_general_category_func (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_mirroring_func_t.
|
* Sets the implementation function for #hb_unicode_mirroring_func_t.
|
||||||
*
|
*
|
||||||
|
@ -479,7 +479,7 @@ hb_unicode_funcs_set_mirroring_func (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_script_func_t.
|
* Sets the implementation function for #hb_unicode_script_func_t.
|
||||||
*
|
*
|
||||||
|
@ -495,7 +495,7 @@ hb_unicode_funcs_set_script_func (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_compose_func_t.
|
* Sets the implementation function for #hb_unicode_compose_func_t.
|
||||||
*
|
*
|
||||||
|
@ -511,7 +511,7 @@ hb_unicode_funcs_set_compose_func (hb_unicode_funcs_t *ufuncs,
|
||||||
* @ufuncs: A Unicode-functions structure
|
* @ufuncs: A Unicode-functions structure
|
||||||
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
* @func: (closure user_data) (destroy destroy) (scope notified): The callback function to assign
|
||||||
* @user_data: Data to pass to @func
|
* @user_data: Data to pass to @func
|
||||||
* @destroy: The function to call when @user_data is not needed anymore
|
* @destroy: (optional): The function to call when @user_data is not needed anymore
|
||||||
*
|
*
|
||||||
* Sets the implementation function for #hb_unicode_decompose_func_t.
|
* Sets the implementation function for #hb_unicode_decompose_func_t.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue