hb-subset.h 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. /*
  2. * Copyright © 2018 Google, Inc.
  3. *
  4. * This is part of HarfBuzz, a text shaping library.
  5. *
  6. * Permission is hereby granted, without written agreement and without
  7. * license or royalty fees, to use, copy, modify, and distribute this
  8. * software and its documentation for any purpose, provided that the
  9. * above copyright notice and the following two paragraphs appear in
  10. * all copies of this software.
  11. *
  12. * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
  13. * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
  14. * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
  15. * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
  16. * DAMAGE.
  17. *
  18. * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
  19. * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  20. * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
  21. * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
  22. * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
  23. *
  24. * Google Author(s): Rod Sheeter
  25. */
  26. #ifndef HB_SUBSET_H
  27. #define HB_SUBSET_H
  28. #include "hb.h"
  29. #include "hb-ot.h"
  30. HB_BEGIN_DECLS
  31. /**
  32. * hb_subset_input_t:
  33. *
  34. * Things that change based on the input. Characters to keep, etc.
  35. */
  36. typedef struct hb_subset_input_t hb_subset_input_t;
  37. /**
  38. * hb_subset_plan_t:
  39. *
  40. * Contains information about how the subset operation will be executed.
  41. * Such as mappings from the old glyph ids to the new ones in the subset.
  42. */
  43. typedef struct hb_subset_plan_t hb_subset_plan_t;
  44. /**
  45. * hb_subset_flags_t:
  46. * @HB_SUBSET_FLAGS_DEFAULT: all flags at their default value of false.
  47. * @HB_SUBSET_FLAGS_NO_HINTING: If set hinting instructions will be dropped in
  48. * the produced subset. Otherwise hinting instructions will be retained.
  49. * @HB_SUBSET_FLAGS_RETAIN_GIDS: If set glyph indices will not be modified in
  50. * the produced subset. If glyphs are dropped their indices will be retained
  51. * as an empty glyph.
  52. * @HB_SUBSET_FLAGS_DESUBROUTINIZE: If set and subsetting a CFF font the
  53. * subsetter will attempt to remove subroutines from the CFF glyphs.
  54. * @HB_SUBSET_FLAGS_NAME_LEGACY: If set non-unicode name records will be
  55. * retained in the subset.
  56. * @HB_SUBSET_FLAGS_SET_OVERLAPS_FLAG: If set the subsetter will set the
  57. * OVERLAP_SIMPLE flag on each simple glyph.
  58. * @HB_SUBSET_FLAGS_PASSTHROUGH_UNRECOGNIZED: If set the subsetter will not
  59. * drop unrecognized tables and instead pass them through untouched.
  60. * @HB_SUBSET_FLAGS_NOTDEF_OUTLINE: If set the notdef glyph outline will be
  61. * retained in the final subset.
  62. * @HB_SUBSET_FLAGS_GLYPH_NAMES: If set the PS glyph names will be retained
  63. * in the final subset.
  64. * @HB_SUBSET_FLAGS_NO_PRUNE_UNICODE_RANGES: If set then the unicode ranges in
  65. * OS/2 will not be recalculated.
  66. * @HB_SUBSET_FLAGS_NO_LAYOUT_CLOSURE: If set don't perform glyph closure on layout
  67. * substitution rules (GSUB). Since: 7.2.0.
  68. * @HB_SUBSET_FLAGS_OPTIMIZE_IUP_DELTAS: If set perform IUP delta optimization on the
  69. * remaining gvar table's deltas. Since: 8.5.0
  70. * @HB_SUBSET_FLAGS_IFTB_REQUIREMENTS: If set enforce requirements on the output subset
  71. * to allow it to be used with incremental font transfer IFTB patches. Primarily,
  72. * this forces all outline data to use long (32 bit) offsets. Since: EXPERIMENTAL
  73. *
  74. * List of boolean properties that can be configured on the subset input.
  75. *
  76. * Since: 2.9.0
  77. **/
  78. typedef enum { /*< flags >*/
  79. HB_SUBSET_FLAGS_DEFAULT = 0x00000000u,
  80. HB_SUBSET_FLAGS_NO_HINTING = 0x00000001u,
  81. HB_SUBSET_FLAGS_RETAIN_GIDS = 0x00000002u,
  82. HB_SUBSET_FLAGS_DESUBROUTINIZE = 0x00000004u,
  83. HB_SUBSET_FLAGS_NAME_LEGACY = 0x00000008u,
  84. HB_SUBSET_FLAGS_SET_OVERLAPS_FLAG = 0x00000010u,
  85. HB_SUBSET_FLAGS_PASSTHROUGH_UNRECOGNIZED = 0x00000020u,
  86. HB_SUBSET_FLAGS_NOTDEF_OUTLINE = 0x00000040u,
  87. HB_SUBSET_FLAGS_GLYPH_NAMES = 0x00000080u,
  88. HB_SUBSET_FLAGS_NO_PRUNE_UNICODE_RANGES = 0x00000100u,
  89. HB_SUBSET_FLAGS_NO_LAYOUT_CLOSURE = 0x00000200u,
  90. HB_SUBSET_FLAGS_OPTIMIZE_IUP_DELTAS = 0x00000400u,
  91. #ifdef HB_EXPERIMENTAL_API
  92. HB_SUBSET_FLAGS_IFTB_REQUIREMENTS = 0x00000800u,
  93. #endif
  94. } hb_subset_flags_t;
  95. /**
  96. * hb_subset_sets_t:
  97. * @HB_SUBSET_SETS_GLYPH_INDEX: the set of glyph indexes to retain in the subset.
  98. * @HB_SUBSET_SETS_UNICODE: the set of unicode codepoints to retain in the subset.
  99. * @HB_SUBSET_SETS_NO_SUBSET_TABLE_TAG: the set of table tags which specifies tables that should not be
  100. * subsetted.
  101. * @HB_SUBSET_SETS_DROP_TABLE_TAG: the set of table tags which specifies tables which will be dropped
  102. * in the subset.
  103. * @HB_SUBSET_SETS_NAME_ID: the set of name ids that will be retained.
  104. * @HB_SUBSET_SETS_NAME_LANG_ID: the set of name lang ids that will be retained.
  105. * @HB_SUBSET_SETS_LAYOUT_FEATURE_TAG: the set of layout feature tags that will be retained
  106. * in the subset.
  107. * @HB_SUBSET_SETS_LAYOUT_SCRIPT_TAG: the set of layout script tags that will be retained
  108. * in the subset. Defaults to all tags. Since: 5.0.0
  109. *
  110. * List of sets that can be configured on the subset input.
  111. *
  112. * Since: 2.9.1
  113. **/
  114. typedef enum {
  115. HB_SUBSET_SETS_GLYPH_INDEX = 0,
  116. HB_SUBSET_SETS_UNICODE,
  117. HB_SUBSET_SETS_NO_SUBSET_TABLE_TAG,
  118. HB_SUBSET_SETS_DROP_TABLE_TAG,
  119. HB_SUBSET_SETS_NAME_ID,
  120. HB_SUBSET_SETS_NAME_LANG_ID,
  121. HB_SUBSET_SETS_LAYOUT_FEATURE_TAG,
  122. HB_SUBSET_SETS_LAYOUT_SCRIPT_TAG,
  123. } hb_subset_sets_t;
  124. HB_EXTERN hb_subset_input_t *
  125. hb_subset_input_create_or_fail (void);
  126. HB_EXTERN hb_subset_input_t *
  127. hb_subset_input_reference (hb_subset_input_t *input);
  128. HB_EXTERN void
  129. hb_subset_input_destroy (hb_subset_input_t *input);
  130. HB_EXTERN hb_bool_t
  131. hb_subset_input_set_user_data (hb_subset_input_t *input,
  132. hb_user_data_key_t *key,
  133. void * data,
  134. hb_destroy_func_t destroy,
  135. hb_bool_t replace);
  136. HB_EXTERN void *
  137. hb_subset_input_get_user_data (const hb_subset_input_t *input,
  138. hb_user_data_key_t *key);
  139. HB_EXTERN void
  140. hb_subset_input_keep_everything (hb_subset_input_t *input);
  141. HB_EXTERN hb_set_t *
  142. hb_subset_input_unicode_set (hb_subset_input_t *input);
  143. HB_EXTERN hb_set_t *
  144. hb_subset_input_glyph_set (hb_subset_input_t *input);
  145. HB_EXTERN hb_set_t *
  146. hb_subset_input_set (hb_subset_input_t *input, hb_subset_sets_t set_type);
  147. HB_EXTERN hb_map_t*
  148. hb_subset_input_old_to_new_glyph_mapping (hb_subset_input_t *input);
  149. HB_EXTERN hb_subset_flags_t
  150. hb_subset_input_get_flags (hb_subset_input_t *input);
  151. HB_EXTERN void
  152. hb_subset_input_set_flags (hb_subset_input_t *input,
  153. unsigned value);
  154. HB_EXTERN hb_bool_t
  155. hb_subset_input_pin_all_axes_to_default (hb_subset_input_t *input,
  156. hb_face_t *face);
  157. HB_EXTERN hb_bool_t
  158. hb_subset_input_pin_axis_to_default (hb_subset_input_t *input,
  159. hb_face_t *face,
  160. hb_tag_t axis_tag);
  161. HB_EXTERN hb_bool_t
  162. hb_subset_input_pin_axis_location (hb_subset_input_t *input,
  163. hb_face_t *face,
  164. hb_tag_t axis_tag,
  165. float axis_value);
  166. HB_EXTERN hb_bool_t
  167. hb_subset_input_get_axis_range (hb_subset_input_t *input,
  168. hb_tag_t axis_tag,
  169. float *axis_min_value,
  170. float *axis_max_value,
  171. float *axis_def_value);
  172. HB_EXTERN hb_bool_t
  173. hb_subset_input_set_axis_range (hb_subset_input_t *input,
  174. hb_face_t *face,
  175. hb_tag_t axis_tag,
  176. float axis_min_value,
  177. float axis_max_value,
  178. float axis_def_value);
  179. #ifdef HB_EXPERIMENTAL_API
  180. HB_EXTERN hb_bool_t
  181. hb_subset_input_override_name_table (hb_subset_input_t *input,
  182. hb_ot_name_id_t name_id,
  183. unsigned platform_id,
  184. unsigned encoding_id,
  185. unsigned language_id,
  186. const char *name_str,
  187. int str_len);
  188. #endif
  189. HB_EXTERN hb_face_t *
  190. hb_subset_preprocess (hb_face_t *source);
  191. HB_EXTERN hb_face_t *
  192. hb_subset_or_fail (hb_face_t *source, const hb_subset_input_t *input);
  193. HB_EXTERN hb_face_t *
  194. hb_subset_plan_execute_or_fail (hb_subset_plan_t *plan);
  195. HB_EXTERN hb_subset_plan_t *
  196. hb_subset_plan_create_or_fail (hb_face_t *face,
  197. const hb_subset_input_t *input);
  198. HB_EXTERN void
  199. hb_subset_plan_destroy (hb_subset_plan_t *plan);
  200. HB_EXTERN hb_map_t *
  201. hb_subset_plan_old_to_new_glyph_mapping (const hb_subset_plan_t *plan);
  202. HB_EXTERN hb_map_t *
  203. hb_subset_plan_new_to_old_glyph_mapping (const hb_subset_plan_t *plan);
  204. HB_EXTERN hb_map_t *
  205. hb_subset_plan_unicode_to_old_glyph_mapping (const hb_subset_plan_t *plan);
  206. HB_EXTERN hb_subset_plan_t *
  207. hb_subset_plan_reference (hb_subset_plan_t *plan);
  208. HB_EXTERN hb_bool_t
  209. hb_subset_plan_set_user_data (hb_subset_plan_t *plan,
  210. hb_user_data_key_t *key,
  211. void *data,
  212. hb_destroy_func_t destroy,
  213. hb_bool_t replace);
  214. HB_EXTERN void *
  215. hb_subset_plan_get_user_data (const hb_subset_plan_t *plan,
  216. hb_user_data_key_t *key);
  217. HB_END_DECLS
  218. #endif /* HB_SUBSET_H */