hb-buffer.h 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352
  1. /*
  2. * Copyright © 1998-2004 David Turner and Werner Lemberg
  3. * Copyright © 2004,2007,2009 Red Hat, Inc.
  4. * Copyright © 2011,2012 Google, Inc.
  5. *
  6. * This is part of HarfBuzz, a text shaping library.
  7. *
  8. * Permission is hereby granted, without written agreement and without
  9. * license or royalty fees, to use, copy, modify, and distribute this
  10. * software and its documentation for any purpose, provided that the
  11. * above copyright notice and the following two paragraphs appear in
  12. * all copies of this software.
  13. *
  14. * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
  15. * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
  16. * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
  17. * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
  18. * DAMAGE.
  19. *
  20. * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
  21. * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  22. * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
  23. * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
  24. * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
  25. *
  26. * Red Hat Author(s): Owen Taylor, Behdad Esfahbod
  27. * Google Author(s): Behdad Esfahbod
  28. */
  29. #ifndef HB_H_IN
  30. #error "Include <hb.h> instead."
  31. #endif
  32. #ifndef HB_BUFFER_H
  33. #define HB_BUFFER_H
  34. #include "hb-common.h"
  35. #include "hb-unicode.h"
  36. #include "hb-font.h"
  37. HB_BEGIN_DECLS
  38. typedef struct hb_glyph_info_t {
  39. hb_codepoint_t codepoint;
  40. hb_mask_t mask;
  41. uint32_t cluster;
  42. /*< private >*/
  43. hb_var_int_t var1;
  44. hb_var_int_t var2;
  45. } hb_glyph_info_t;
  46. typedef struct hb_glyph_position_t {
  47. hb_position_t x_advance;
  48. hb_position_t y_advance;
  49. hb_position_t x_offset;
  50. hb_position_t y_offset;
  51. /*< private >*/
  52. hb_var_int_t var;
  53. } hb_glyph_position_t;
  54. typedef struct hb_segment_properties_t {
  55. hb_direction_t direction;
  56. hb_script_t script;
  57. hb_language_t language;
  58. /*< private >*/
  59. void *reserved1;
  60. void *reserved2;
  61. } hb_segment_properties_t;
  62. #define HB_SEGMENT_PROPERTIES_DEFAULT {HB_DIRECTION_INVALID, \
  63. HB_SCRIPT_INVALID, \
  64. HB_LANGUAGE_INVALID, \
  65. NULL, \
  66. NULL}
  67. hb_bool_t
  68. hb_segment_properties_equal (const hb_segment_properties_t *a,
  69. const hb_segment_properties_t *b);
  70. unsigned int
  71. hb_segment_properties_hash (const hb_segment_properties_t *p);
  72. /*
  73. * hb_buffer_t
  74. */
  75. typedef struct hb_buffer_t hb_buffer_t;
  76. hb_buffer_t *
  77. hb_buffer_create (void);
  78. hb_buffer_t *
  79. hb_buffer_get_empty (void);
  80. hb_buffer_t *
  81. hb_buffer_reference (hb_buffer_t *buffer);
  82. void
  83. hb_buffer_destroy (hb_buffer_t *buffer);
  84. hb_bool_t
  85. hb_buffer_set_user_data (hb_buffer_t *buffer,
  86. hb_user_data_key_t *key,
  87. void * data,
  88. hb_destroy_func_t destroy,
  89. hb_bool_t replace);
  90. void *
  91. hb_buffer_get_user_data (hb_buffer_t *buffer,
  92. hb_user_data_key_t *key);
  93. typedef enum {
  94. HB_BUFFER_CONTENT_TYPE_INVALID = 0,
  95. HB_BUFFER_CONTENT_TYPE_UNICODE,
  96. HB_BUFFER_CONTENT_TYPE_GLYPHS
  97. } hb_buffer_content_type_t;
  98. void
  99. hb_buffer_set_content_type (hb_buffer_t *buffer,
  100. hb_buffer_content_type_t content_type);
  101. hb_buffer_content_type_t
  102. hb_buffer_get_content_type (hb_buffer_t *buffer);
  103. void
  104. hb_buffer_set_unicode_funcs (hb_buffer_t *buffer,
  105. hb_unicode_funcs_t *unicode_funcs);
  106. hb_unicode_funcs_t *
  107. hb_buffer_get_unicode_funcs (hb_buffer_t *buffer);
  108. void
  109. hb_buffer_set_direction (hb_buffer_t *buffer,
  110. hb_direction_t direction);
  111. hb_direction_t
  112. hb_buffer_get_direction (hb_buffer_t *buffer);
  113. void
  114. hb_buffer_set_script (hb_buffer_t *buffer,
  115. hb_script_t script);
  116. hb_script_t
  117. hb_buffer_get_script (hb_buffer_t *buffer);
  118. void
  119. hb_buffer_set_language (hb_buffer_t *buffer,
  120. hb_language_t language);
  121. hb_language_t
  122. hb_buffer_get_language (hb_buffer_t *buffer);
  123. void
  124. hb_buffer_set_segment_properties (hb_buffer_t *buffer,
  125. const hb_segment_properties_t *props);
  126. void
  127. hb_buffer_get_segment_properties (hb_buffer_t *buffer,
  128. hb_segment_properties_t *props);
  129. void
  130. hb_buffer_guess_segment_properties (hb_buffer_t *buffer);
  131. typedef enum { /*< flags >*/
  132. HB_BUFFER_FLAG_DEFAULT = 0x00000000u,
  133. HB_BUFFER_FLAG_BOT = 0x00000001u, /* Beginning-of-text */
  134. HB_BUFFER_FLAG_EOT = 0x00000002u, /* End-of-text */
  135. HB_BUFFER_FLAG_PRESERVE_DEFAULT_IGNORABLES = 0x00000004u
  136. } hb_buffer_flags_t;
  137. void
  138. hb_buffer_set_flags (hb_buffer_t *buffer,
  139. hb_buffer_flags_t flags);
  140. hb_buffer_flags_t
  141. hb_buffer_get_flags (hb_buffer_t *buffer);
  142. #define HB_BUFFER_REPLACEMENT_CODEPOINT_DEFAULT 0xFFFDu
  143. /* Sets codepoint used to replace invalid UTF-8/16/32 entries.
  144. * Default is 0xFFFDu. */
  145. void
  146. hb_buffer_set_replacement_codepoint (hb_buffer_t *buffer,
  147. hb_codepoint_t replacement);
  148. hb_codepoint_t
  149. hb_buffer_get_replacement_codepoint (hb_buffer_t *buffer);
  150. /* Resets the buffer. Afterwards it's as if it was just created,
  151. * except that it has a larger buffer allocated perhaps... */
  152. void
  153. hb_buffer_reset (hb_buffer_t *buffer);
  154. /* Like reset, but does NOT clear unicode_funcs and replacement_codepoint. */
  155. void
  156. hb_buffer_clear_contents (hb_buffer_t *buffer);
  157. /* Returns false if allocation failed */
  158. hb_bool_t
  159. hb_buffer_pre_allocate (hb_buffer_t *buffer,
  160. unsigned int size);
  161. /* Returns false if allocation has failed before */
  162. hb_bool_t
  163. hb_buffer_allocation_successful (hb_buffer_t *buffer);
  164. void
  165. hb_buffer_reverse (hb_buffer_t *buffer);
  166. void
  167. hb_buffer_reverse_clusters (hb_buffer_t *buffer);
  168. /* Filling the buffer in */
  169. void
  170. hb_buffer_add (hb_buffer_t *buffer,
  171. hb_codepoint_t codepoint,
  172. unsigned int cluster);
  173. void
  174. hb_buffer_add_utf8 (hb_buffer_t *buffer,
  175. const char *text,
  176. int text_length,
  177. unsigned int item_offset,
  178. int item_length);
  179. void
  180. hb_buffer_add_utf16 (hb_buffer_t *buffer,
  181. const uint16_t *text,
  182. int text_length,
  183. unsigned int item_offset,
  184. int item_length);
  185. void
  186. hb_buffer_add_utf32 (hb_buffer_t *buffer,
  187. const uint32_t *text,
  188. int text_length,
  189. unsigned int item_offset,
  190. int item_length);
  191. /* Allows only access to first 256 Unicode codepoints. */
  192. void
  193. hb_buffer_add_latin1 (hb_buffer_t *buffer,
  194. const uint8_t *text,
  195. int text_length,
  196. unsigned int item_offset,
  197. int item_length);
  198. /* Like add_utf32 but does NOT check for invalid Unicode codepoints. */
  199. void
  200. hb_buffer_add_codepoints (hb_buffer_t *buffer,
  201. const hb_codepoint_t *text,
  202. int text_length,
  203. unsigned int item_offset,
  204. int item_length);
  205. /* Clears any new items added at the end */
  206. hb_bool_t
  207. hb_buffer_set_length (hb_buffer_t *buffer,
  208. unsigned int length);
  209. /* Return value valid as long as buffer not modified */
  210. unsigned int
  211. hb_buffer_get_length (hb_buffer_t *buffer);
  212. /* Getting glyphs out of the buffer */
  213. /* Return value valid as long as buffer not modified */
  214. hb_glyph_info_t *
  215. hb_buffer_get_glyph_infos (hb_buffer_t *buffer,
  216. unsigned int *length);
  217. /* Return value valid as long as buffer not modified */
  218. hb_glyph_position_t *
  219. hb_buffer_get_glyph_positions (hb_buffer_t *buffer,
  220. unsigned int *length);
  221. /* Reorders a glyph buffer to have canonical in-cluster glyph order / position.
  222. * The resulting clusters should behave identical to pre-reordering clusters.
  223. * NOTE: This has nothing to do with Unicode normalization. */
  224. void
  225. hb_buffer_normalize_glyphs (hb_buffer_t *buffer);
  226. /*
  227. * Serialize
  228. */
  229. typedef enum { /*< flags >*/
  230. HB_BUFFER_SERIALIZE_FLAG_DEFAULT = 0x00000000u,
  231. HB_BUFFER_SERIALIZE_FLAG_NO_CLUSTERS = 0x00000001u,
  232. HB_BUFFER_SERIALIZE_FLAG_NO_POSITIONS = 0x00000002u,
  233. HB_BUFFER_SERIALIZE_FLAG_NO_GLYPH_NAMES = 0x00000004u
  234. } hb_buffer_serialize_flags_t;
  235. typedef enum {
  236. HB_BUFFER_SERIALIZE_FORMAT_TEXT = HB_TAG('T','E','X','T'),
  237. HB_BUFFER_SERIALIZE_FORMAT_JSON = HB_TAG('J','S','O','N'),
  238. HB_BUFFER_SERIALIZE_FORMAT_INVALID = HB_TAG_NONE
  239. } hb_buffer_serialize_format_t;
  240. /* len=-1 means str is NUL-terminated. */
  241. hb_buffer_serialize_format_t
  242. hb_buffer_serialize_format_from_string (const char *str, int len);
  243. const char *
  244. hb_buffer_serialize_format_to_string (hb_buffer_serialize_format_t format);
  245. const char **
  246. hb_buffer_serialize_list_formats (void);
  247. /* Returns number of items, starting at start, that were serialized. */
  248. unsigned int
  249. hb_buffer_serialize_glyphs (hb_buffer_t *buffer,
  250. unsigned int start,
  251. unsigned int end,
  252. char *buf,
  253. unsigned int buf_size,
  254. unsigned int *buf_consumed, /* May be NULL */
  255. hb_font_t *font, /* May be NULL */
  256. hb_buffer_serialize_format_t format,
  257. hb_buffer_serialize_flags_t flags);
  258. hb_bool_t
  259. hb_buffer_deserialize_glyphs (hb_buffer_t *buffer,
  260. const char *buf,
  261. int buf_len, /* -1 means nul-terminated */
  262. const char **end_ptr, /* May be NULL */
  263. hb_font_t *font, /* May be NULL */
  264. hb_buffer_serialize_format_t format);
  265. HB_END_DECLS
  266. #endif /* HB_BUFFER_H */