blob: 74c61aba487675c818205ce5f675e6672be075a0 [file] [log] [blame]
Behdad Esfahbodc62b5032009-08-01 19:54:49 -04001/*
Behdad Esfahbod2409d5f2011-04-21 17:14:28 -04002 * Copyright © 2009 Red Hat, Inc.
Behdad Esfahbodc62b5032009-08-01 19:54:49 -04003 *
Behdad Esfahbodc755cb32010-04-22 00:11:43 -04004 * This is part of HarfBuzz, a text shaping library.
Behdad Esfahbodc62b5032009-08-01 19:54:49 -04005 *
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 * Red Hat Author(s): Behdad Esfahbod
25 */
26
Behdad Esfahbodd1c9eb42012-04-12 13:17:44 -040027#ifndef HB_H_IN
28#error "Include <hb.h> instead."
29#endif
30
Behdad Esfahbodc62b5032009-08-01 19:54:49 -040031#ifndef HB_FONT_H
32#define HB_FONT_H
33
34#include "hb-common.h"
Behdad Esfahbod2e3a07a2013-08-26 18:49:07 -040035#include "hb-face.h"
Behdad Esfahbodc62b5032009-08-01 19:54:49 -040036
37HB_BEGIN_DECLS
38
Behdad Esfahbodacdba3f2010-07-23 15:11:18 -040039
Behdad Esfahbod1bc1cb32012-06-16 15:21:55 -040040typedef struct hb_font_t hb_font_t;
Behdad Esfahbodc62b5032009-08-01 19:54:49 -040041
Behdad Esfahbod5c441882009-08-10 20:05:16 -040042
43/*
44 * hb_font_funcs_t
45 */
46
Behdad Esfahbod1bc1cb32012-06-16 15:21:55 -040047typedef struct hb_font_funcs_t hb_font_funcs_t;
Behdad Esfahbod5c441882009-08-10 20:05:16 -040048
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080049HB_EXTERN hb_font_funcs_t *
Behdad Esfahbod5c441882009-08-10 20:05:16 -040050hb_font_funcs_create (void);
51
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080052HB_EXTERN hb_font_funcs_t *
Behdad Esfahbod80a68332011-05-11 18:14:44 -040053hb_font_funcs_get_empty (void);
54
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080055HB_EXTERN hb_font_funcs_t *
Behdad Esfahbod5c441882009-08-10 20:05:16 -040056hb_font_funcs_reference (hb_font_funcs_t *ffuncs);
57
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080058HB_EXTERN void
Behdad Esfahbod5c441882009-08-10 20:05:16 -040059hb_font_funcs_destroy (hb_font_funcs_t *ffuncs);
60
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080061HB_EXTERN hb_bool_t
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -040062hb_font_funcs_set_user_data (hb_font_funcs_t *ffuncs,
63 hb_user_data_key_t *key,
64 void * data,
Behdad Esfahbod33ccc772011-08-09 00:43:24 +020065 hb_destroy_func_t destroy,
66 hb_bool_t replace);
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -040067
68
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080069HB_EXTERN void *
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -040070hb_font_funcs_get_user_data (hb_font_funcs_t *ffuncs,
71 hb_user_data_key_t *key);
72
73
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080074HB_EXTERN void
Behdad Esfahbod8d703122009-08-10 23:50:51 -040075hb_font_funcs_make_immutable (hb_font_funcs_t *ffuncs);
76
Chun-wei Fan835bbdc2015-11-19 18:34:12 +080077HB_EXTERN hb_bool_t
Behdad Esfahbod645f6f22010-10-04 17:01:01 -040078hb_font_funcs_is_immutable (hb_font_funcs_t *ffuncs);
Behdad Esfahbod32c65a52009-08-18 18:37:36 -040079
Behdad Esfahbod21756932012-08-08 01:20:45 -040080
Simon Cozens6f2e6de2015-10-26 16:23:22 +090081/* font and glyph extents */
82
83/* Note that typically ascender is positive and descender negative in coordinate systems that grow up. */
84typedef struct hb_font_extents_t
85{
86 hb_position_t ascender; /* typographic ascender. */
87 hb_position_t descender; /* typographic descender. */
88 hb_position_t line_gap; /* suggested line spacing gap. */
Behdad Esfahbod25671462016-01-07 19:11:41 +000089 /*< private >*/
90 hb_position_t reserved9;
91 hb_position_t reserved8;
92 hb_position_t reserved7;
93 hb_position_t reserved6;
94 hb_position_t reserved5;
95 hb_position_t reserved4;
96 hb_position_t reserved3;
97 hb_position_t reserved2;
98 hb_position_t reserved1;
Simon Cozens6f2e6de2015-10-26 16:23:22 +090099} hb_font_extents_t;
Behdad Esfahbod32c65a52009-08-18 18:37:36 -0400100
Behdad Esfahbodb50fcfa2015-08-23 14:42:20 +0100101/* Note that height is negative in coordinate systems that grow up. */
Behdad Esfahbod1bc1cb32012-06-16 15:21:55 -0400102typedef struct hb_glyph_extents_t
Behdad Esfahbodc09ed982009-10-29 03:08:42 -0400103{
Behdad Esfahbodb50fcfa2015-08-23 14:42:20 +0100104 hb_position_t x_bearing; /* left side of glyph from origin. */
105 hb_position_t y_bearing; /* top side of glyph from origin. */
106 hb_position_t width; /* distance from left to right side. */
107 hb_position_t height; /* distance from top to bottom side. */
Behdad Esfahbod502f4cb2010-10-27 01:13:56 -0400108} hb_glyph_extents_t;
Behdad Esfahbod32c65a52009-08-18 18:37:36 -0400109
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400110/* func types */
111
Simon Cozens6f2e6de2015-10-26 16:23:22 +0900112typedef hb_bool_t (*hb_font_get_font_extents_func_t) (hb_font_t *font, void *font_data,
113 hb_font_extents_t *metrics,
114 void *user_data);
115typedef hb_font_get_font_extents_func_t hb_font_get_font_h_extents_func_t;
116typedef hb_font_get_font_extents_func_t hb_font_get_font_v_extents_func_t;
117
118
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900119typedef hb_bool_t (*hb_font_get_nominal_glyph_func_t) (hb_font_t *font, void *font_data,
120 hb_codepoint_t unicode,
121 hb_codepoint_t *glyph,
122 void *user_data);
123typedef hb_bool_t (*hb_font_get_variation_glyph_func_t) (hb_font_t *font, void *font_data,
124 hb_codepoint_t unicode, hb_codepoint_t variation_selector,
125 hb_codepoint_t *glyph,
126 void *user_data);
Behdad Esfahbod32c65a52009-08-18 18:37:36 -0400127
Behdad Esfahbodb314c4e2018-10-09 09:23:51 -0400128typedef unsigned int (*hb_font_get_nominal_glyphs_func_t) (hb_font_t *font, void *font_data,
129 unsigned int count,
130 const hb_codepoint_t *first_unicode,
131 unsigned int unicode_stride,
132 hb_codepoint_t *first_glyph,
133 unsigned int glyph_stride,
134 void *user_data);
135
Behdad Esfahbod5c441882009-08-10 20:05:16 -0400136
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400137typedef hb_position_t (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, void *font_data,
138 hb_codepoint_t glyph,
139 void *user_data);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400140typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_h_advance_func_t;
141typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_v_advance_func_t;
Behdad Esfahbod5c441882009-08-10 20:05:16 -0400142
Behdad Esfahbod79e21982018-08-06 09:45:17 -0700143typedef void (*hb_font_get_glyph_advances_func_t) (hb_font_t* font, void* font_data,
Behdad Esfahbodca6a3172018-10-09 09:06:07 -0400144 unsigned int count,
Behdad Esfahbodbee93e22018-10-09 08:01:49 -0400145 const hb_codepoint_t *first_glyph,
Behdad Esfahbod79e21982018-08-06 09:45:17 -0700146 unsigned glyph_stride,
147 hb_position_t *first_advance,
148 unsigned advance_stride,
149 void *user_data);
150typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_h_advances_func_t;
151typedef hb_font_get_glyph_advances_func_t hb_font_get_glyph_v_advances_func_t;
Koji Ishii95333642018-08-01 13:01:08 +0900152
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400153typedef hb_bool_t (*hb_font_get_glyph_origin_func_t) (hb_font_t *font, void *font_data,
154 hb_codepoint_t glyph,
155 hb_position_t *x, hb_position_t *y,
156 void *user_data);
157typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_h_origin_func_t;
158typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_v_origin_func_t;
Behdad Esfahbod5c441882009-08-10 20:05:16 -0400159
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400160
161typedef hb_bool_t (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, void *font_data,
162 hb_codepoint_t glyph,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400163 hb_glyph_extents_t *extents,
164 void *user_data);
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400165typedef hb_bool_t (*hb_font_get_glyph_contour_point_func_t) (hb_font_t *font, void *font_data,
166 hb_codepoint_t glyph, unsigned int point_index,
167 hb_position_t *x, hb_position_t *y,
168 void *user_data);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400169
170
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400171typedef hb_bool_t (*hb_font_get_glyph_name_func_t) (hb_font_t *font, void *font_data,
172 hb_codepoint_t glyph,
173 char *name, unsigned int size,
174 void *user_data);
175typedef hb_bool_t (*hb_font_get_glyph_from_name_func_t) (hb_font_t *font, void *font_data,
176 const char *name, int len, /* -1 means nul-terminated */
177 hb_codepoint_t *glyph,
178 void *user_data);
179
180
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400181/* func setters */
Behdad Esfahbod502f4cb2010-10-27 01:13:56 -0400182
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400183/**
Simon Cozens6f2e6de2015-10-26 16:23:22 +0900184 * hb_font_funcs_set_font_h_extents_func:
185 * @ffuncs: font functions.
186 * @func: (closure user_data) (destroy destroy) (scope notified):
187 * @user_data:
188 * @destroy:
189 *
190 *
191 *
192 * Since: 1.1.2
193 **/
194HB_EXTERN void
195hb_font_funcs_set_font_h_extents_func (hb_font_funcs_t *ffuncs,
196 hb_font_get_font_h_extents_func_t func,
197 void *user_data, hb_destroy_func_t destroy);
198
199/**
200 * hb_font_funcs_set_font_v_extents_func:
201 * @ffuncs: font functions.
202 * @func: (closure user_data) (destroy destroy) (scope notified):
203 * @user_data:
204 * @destroy:
205 *
206 *
207 *
208 * Since: 1.1.2
209 **/
210HB_EXTERN void
211hb_font_funcs_set_font_v_extents_func (hb_font_funcs_t *ffuncs,
212 hb_font_get_font_v_extents_func_t func,
213 void *user_data, hb_destroy_func_t destroy);
214
215/**
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900216 * hb_font_funcs_set_nominal_glyph_func:
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400217 * @ffuncs: font functions.
218 * @func: (closure user_data) (destroy destroy) (scope notified):
219 * @user_data:
220 * @destroy:
221 *
222 *
223 *
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900224 * Since: 1.2.3
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400225 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800226HB_EXTERN void
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900227hb_font_funcs_set_nominal_glyph_func (hb_font_funcs_t *ffuncs,
228 hb_font_get_nominal_glyph_func_t func,
229 void *user_data, hb_destroy_func_t destroy);
230
231/**
Behdad Esfahbodb314c4e2018-10-09 09:23:51 -0400232 * hb_font_funcs_set_nominal_glyphs_func:
233 * @ffuncs: font functions.
234 * @func: (closure user_data) (destroy destroy) (scope notified):
235 * @user_data:
236 * @destroy:
237 *
238 *
239 *
Behdad Esfahbod3d9a0302018-10-18 05:58:17 -0700240 * Since: 2.0.0
Behdad Esfahbodb314c4e2018-10-09 09:23:51 -0400241 **/
242HB_EXTERN void
243hb_font_funcs_set_nominal_glyphs_func (hb_font_funcs_t *ffuncs,
244 hb_font_get_nominal_glyphs_func_t func,
245 void *user_data, hb_destroy_func_t destroy);
246
247/**
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900248 * hb_font_funcs_set_variation_glyph_func:
249 * @ffuncs: font functions.
250 * @func: (closure user_data) (destroy destroy) (scope notified):
251 * @user_data:
252 * @destroy:
253 *
254 *
255 *
256 * Since: 1.2.3
257 **/
258HB_EXTERN void
259hb_font_funcs_set_variation_glyph_func (hb_font_funcs_t *ffuncs,
260 hb_font_get_variation_glyph_func_t func,
261 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahbod5c441882009-08-10 20:05:16 -0400262
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400263/**
264 * hb_font_funcs_set_glyph_h_advance_func:
265 * @ffuncs: font functions.
266 * @func: (closure user_data) (destroy destroy) (scope notified):
267 * @user_data:
268 * @destroy:
269 *
270 *
271 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430272 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400273 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800274HB_EXTERN void
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400275hb_font_funcs_set_glyph_h_advance_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400276 hb_font_get_glyph_h_advance_func_t func,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400277 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400278
279/**
280 * hb_font_funcs_set_glyph_v_advance_func:
281 * @ffuncs: font functions.
282 * @func: (closure user_data) (destroy destroy) (scope notified):
283 * @user_data:
284 * @destroy:
285 *
286 *
287 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430288 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400289 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800290HB_EXTERN void
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400291hb_font_funcs_set_glyph_v_advance_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400292 hb_font_get_glyph_v_advance_func_t func,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400293 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahbod2e336692009-11-05 13:55:41 -0500294
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400295/**
Behdad Esfahbod79e21982018-08-06 09:45:17 -0700296 * hb_font_funcs_set_glyph_h_advances_func:
297 * @ffuncs: font functions.
298 * @func: (closure user_data) (destroy destroy) (scope notified):
299 * @user_data:
300 * @destroy:
301 *
302 *
303 *
Behdad Esfahbode49a38b2018-08-07 09:55:42 -0700304 * Since: 1.8.6
Behdad Esfahbod79e21982018-08-06 09:45:17 -0700305 **/
306HB_EXTERN void
307hb_font_funcs_set_glyph_h_advances_func (hb_font_funcs_t *ffuncs,
308 hb_font_get_glyph_h_advances_func_t func,
309 void *user_data, hb_destroy_func_t destroy);
310
311/**
312 * hb_font_funcs_set_glyph_v_advances_func:
313 * @ffuncs: font functions.
314 * @func: (closure user_data) (destroy destroy) (scope notified):
315 * @user_data:
316 * @destroy:
317 *
318 *
319 *
Behdad Esfahbode49a38b2018-08-07 09:55:42 -0700320 * Since: 1.8.6
Behdad Esfahbod79e21982018-08-06 09:45:17 -0700321 **/
322HB_EXTERN void
323hb_font_funcs_set_glyph_v_advances_func (hb_font_funcs_t *ffuncs,
324 hb_font_get_glyph_v_advances_func_t func,
325 void *user_data, hb_destroy_func_t destroy);
326
327/**
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400328 * hb_font_funcs_set_glyph_h_origin_func:
329 * @ffuncs: font functions.
330 * @func: (closure user_data) (destroy destroy) (scope notified):
331 * @user_data:
332 * @destroy:
333 *
334 *
335 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430336 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400337 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800338HB_EXTERN void
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400339hb_font_funcs_set_glyph_h_origin_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400340 hb_font_get_glyph_h_origin_func_t func,
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400341 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400342
343/**
344 * hb_font_funcs_set_glyph_v_origin_func:
345 * @ffuncs: font functions.
346 * @func: (closure user_data) (destroy destroy) (scope notified):
347 * @user_data:
348 * @destroy:
349 *
350 *
351 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430352 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400353 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800354HB_EXTERN void
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400355hb_font_funcs_set_glyph_v_origin_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400356 hb_font_get_glyph_v_origin_func_t func,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400357 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahbod2e336692009-11-05 13:55:41 -0500358
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400359/**
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400360 * hb_font_funcs_set_glyph_extents_func:
361 * @ffuncs: font functions.
362 * @func: (closure user_data) (destroy destroy) (scope notified):
363 * @user_data:
364 * @destroy:
365 *
366 *
367 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430368 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400369 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800370HB_EXTERN void
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400371hb_font_funcs_set_glyph_extents_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400372 hb_font_get_glyph_extents_func_t func,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400373 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400374
375/**
376 * hb_font_funcs_set_glyph_contour_point_func:
377 * @ffuncs: font functions.
378 * @func: (closure user_data) (destroy destroy) (scope notified):
379 * @user_data:
380 * @destroy:
381 *
382 *
383 *
Behdad Esfahbodb8811422015-09-03 15:53:22 +0430384 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400385 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800386HB_EXTERN void
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400387hb_font_funcs_set_glyph_contour_point_func (hb_font_funcs_t *ffuncs,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400388 hb_font_get_glyph_contour_point_func_t func,
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400389 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400390
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400391/**
392 * hb_font_funcs_set_glyph_name_func:
393 * @ffuncs: font functions.
394 * @func: (closure user_data) (destroy destroy) (scope notified):
395 * @user_data:
396 * @destroy:
397 *
398 *
399 *
Sascha Brawer01c3a882015-06-01 13:22:01 +0200400 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400401 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800402HB_EXTERN void
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400403hb_font_funcs_set_glyph_name_func (hb_font_funcs_t *ffuncs,
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400404 hb_font_get_glyph_name_func_t func,
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400405 void *user_data, hb_destroy_func_t destroy);
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400406
407/**
408 * hb_font_funcs_set_glyph_from_name_func:
409 * @ffuncs: font functions.
410 * @func: (closure user_data) (destroy destroy) (scope notified):
411 * @user_data:
412 * @destroy:
413 *
414 *
415 *
Sascha Brawer01c3a882015-06-01 13:22:01 +0200416 * Since: 0.9.2
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400417 **/
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800418HB_EXTERN void
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400419hb_font_funcs_set_glyph_from_name_func (hb_font_funcs_t *ffuncs,
Behdad Esfahboda8949df2013-09-13 20:23:51 -0400420 hb_font_get_glyph_from_name_func_t func,
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400421 void *user_data, hb_destroy_func_t destroy);
422
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400423/* func dispatch */
Behdad Esfahbod502f4cb2010-10-27 01:13:56 -0400424
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800425HB_EXTERN hb_bool_t
Simon Cozens6f2e6de2015-10-26 16:23:22 +0900426hb_font_get_h_extents (hb_font_t *font,
427 hb_font_extents_t *extents);
428HB_EXTERN hb_bool_t
429hb_font_get_v_extents (hb_font_t *font,
430 hb_font_extents_t *extents);
431
432HB_EXTERN hb_bool_t
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900433hb_font_get_nominal_glyph (hb_font_t *font,
434 hb_codepoint_t unicode,
435 hb_codepoint_t *glyph);
436HB_EXTERN hb_bool_t
437hb_font_get_variation_glyph (hb_font_t *font,
438 hb_codepoint_t unicode, hb_codepoint_t variation_selector,
439 hb_codepoint_t *glyph);
Behdad Esfahbod2e336692009-11-05 13:55:41 -0500440
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800441HB_EXTERN hb_position_t
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400442hb_font_get_glyph_h_advance (hb_font_t *font,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400443 hb_codepoint_t glyph);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800444HB_EXTERN hb_position_t
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400445hb_font_get_glyph_v_advance (hb_font_t *font,
Behdad Esfahbod2d8ebcb2011-05-25 11:27:33 -0400446 hb_codepoint_t glyph);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400447
Behdad Esfahbod28e2f462018-08-07 09:47:00 -0700448HB_EXTERN void
449hb_font_get_glyph_h_advances (hb_font_t* font,
Behdad Esfahbodca6a3172018-10-09 09:06:07 -0400450 unsigned int count,
Behdad Esfahbodbee93e22018-10-09 08:01:49 -0400451 const hb_codepoint_t *first_glyph,
Behdad Esfahbod28e2f462018-08-07 09:47:00 -0700452 unsigned glyph_stride,
453 hb_position_t *first_advance,
454 unsigned advance_stride);
455HB_EXTERN void
456hb_font_get_glyph_v_advances (hb_font_t* font,
Behdad Esfahbodca6a3172018-10-09 09:06:07 -0400457 unsigned int count,
Behdad Esfahbodbee93e22018-10-09 08:01:49 -0400458 const hb_codepoint_t *first_glyph,
Behdad Esfahbod28e2f462018-08-07 09:47:00 -0700459 unsigned glyph_stride,
460 hb_position_t *first_advance,
461 unsigned advance_stride);
462
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800463HB_EXTERN hb_bool_t
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400464hb_font_get_glyph_h_origin (hb_font_t *font,
465 hb_codepoint_t glyph,
466 hb_position_t *x, hb_position_t *y);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800467HB_EXTERN hb_bool_t
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400468hb_font_get_glyph_v_origin (hb_font_t *font,
469 hb_codepoint_t glyph,
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400470 hb_position_t *x, hb_position_t *y);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400471
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800472HB_EXTERN hb_bool_t
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400473hb_font_get_glyph_extents (hb_font_t *font,
474 hb_codepoint_t glyph,
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400475 hb_glyph_extents_t *extents);
476
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800477HB_EXTERN hb_bool_t
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400478hb_font_get_glyph_contour_point (hb_font_t *font,
479 hb_codepoint_t glyph, unsigned int point_index,
480 hb_position_t *x, hb_position_t *y);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400481
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800482HB_EXTERN hb_bool_t
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400483hb_font_get_glyph_name (hb_font_t *font,
484 hb_codepoint_t glyph,
485 char *name, unsigned int size);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800486HB_EXTERN hb_bool_t
Behdad Esfahbodbce09552012-05-27 11:29:21 -0400487hb_font_get_glyph_from_name (hb_font_t *font,
488 const char *name, int len, /* -1 means nul-terminated */
489 hb_codepoint_t *glyph);
490
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400491
492/* high-level funcs, with fallback */
493
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900494/* Calls either hb_font_get_nominal_glyph() if variation_selector is 0,
Bruce Mitchener85ec6d32018-01-03 01:23:23 +0700495 * otherwise calls hb_font_get_variation_glyph(). */
Behdad Esfahbod8b5bc142016-02-24 19:05:23 +0900496HB_EXTERN hb_bool_t
497hb_font_get_glyph (hb_font_t *font,
498 hb_codepoint_t unicode, hb_codepoint_t variation_selector,
499 hb_codepoint_t *glyph);
500
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800501HB_EXTERN void
Simon Cozens6f2e6de2015-10-26 16:23:22 +0900502hb_font_get_extents_for_direction (hb_font_t *font,
503 hb_direction_t direction,
504 hb_font_extents_t *extents);
505HB_EXTERN void
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400506hb_font_get_glyph_advance_for_direction (hb_font_t *font,
507 hb_codepoint_t glyph,
508 hb_direction_t direction,
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400509 hb_position_t *x, hb_position_t *y);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800510HB_EXTERN void
Behdad Esfahbodb0ff79a2018-08-07 09:52:06 -0700511hb_font_get_glyph_advances_for_direction (hb_font_t* font,
512 hb_direction_t direction,
Behdad Esfahbodca6a3172018-10-09 09:06:07 -0400513 unsigned int count,
Behdad Esfahbodbee93e22018-10-09 08:01:49 -0400514 const hb_codepoint_t *first_glyph,
Behdad Esfahbodb0ff79a2018-08-07 09:52:06 -0700515 unsigned glyph_stride,
516 hb_position_t *first_advance,
517 unsigned advance_stride);
518HB_EXTERN void
Behdad Esfahbod7e2c85d2011-05-17 17:55:03 -0400519hb_font_get_glyph_origin_for_direction (hb_font_t *font,
520 hb_codepoint_t glyph,
521 hb_direction_t direction,
522 hb_position_t *x, hb_position_t *y);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800523HB_EXTERN void
Behdad Esfahbod8b38fae2011-05-19 13:08:00 -0400524hb_font_add_glyph_origin_for_direction (hb_font_t *font,
525 hb_codepoint_t glyph,
526 hb_direction_t direction,
527 hb_position_t *x, hb_position_t *y);
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800528HB_EXTERN void
Behdad Esfahbod8b38fae2011-05-19 13:08:00 -0400529hb_font_subtract_glyph_origin_for_direction (hb_font_t *font,
530 hb_codepoint_t glyph,
531 hb_direction_t direction,
532 hb_position_t *x, hb_position_t *y);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400533
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800534HB_EXTERN hb_bool_t
Behdad Esfahbod60fbb362011-05-19 18:46:15 -0400535hb_font_get_glyph_extents_for_origin (hb_font_t *font,
536 hb_codepoint_t glyph,
537 hb_direction_t direction,
538 hb_glyph_extents_t *extents);
Behdad Esfahbod744970a2011-05-16 18:15:37 -0400539
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800540HB_EXTERN hb_bool_t
Behdad Esfahbod60fbb362011-05-19 18:46:15 -0400541hb_font_get_glyph_contour_point_for_origin (hb_font_t *font,
542 hb_codepoint_t glyph, unsigned int point_index,
543 hb_direction_t direction,
544 hb_position_t *x, hb_position_t *y);
Behdad Esfahbod2e336692009-11-05 13:55:41 -0500545
Behdad Esfahbod6f3a3002012-08-07 22:13:25 -0400546/* Generates gidDDD if glyph has no name. */
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800547HB_EXTERN void
Behdad Esfahbod6f3a3002012-08-07 22:13:25 -0400548hb_font_glyph_to_string (hb_font_t *font,
549 hb_codepoint_t glyph,
550 char *s, unsigned int size);
551/* Parses gidDDD and uniUUUU strings automatically. */
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800552HB_EXTERN hb_bool_t
Behdad Esfahbod6f3a3002012-08-07 22:13:25 -0400553hb_font_glyph_from_string (hb_font_t *font,
554 const char *s, int len, /* -1 means nul-terminated */
555 hb_codepoint_t *glyph);
556
Behdad Esfahbod2e336692009-11-05 13:55:41 -0500557
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400558/*
559 * hb_font_t
560 */
561
562/* Fonts are very light-weight objects */
563
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800564HB_EXTERN hb_font_t *
Behdad Esfahbod72657e42011-05-02 20:46:32 -0400565hb_font_create (hb_face_t *face);
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400566
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800567HB_EXTERN hb_font_t *
Behdad Esfahboddefc45b2011-05-10 20:02:49 -0400568hb_font_create_sub_font (hb_font_t *parent);
569
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800570HB_EXTERN hb_font_t *
Behdad Esfahbod80a68332011-05-11 18:14:44 -0400571hb_font_get_empty (void);
572
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800573HB_EXTERN hb_font_t *
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400574hb_font_reference (hb_font_t *font);
575
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800576HB_EXTERN void
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400577hb_font_destroy (hb_font_t *font);
578
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800579HB_EXTERN hb_bool_t
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -0400580hb_font_set_user_data (hb_font_t *font,
581 hb_user_data_key_t *key,
582 void * data,
Behdad Esfahbod33ccc772011-08-09 00:43:24 +0200583 hb_destroy_func_t destroy,
584 hb_bool_t replace);
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -0400585
586
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800587HB_EXTERN void *
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -0400588hb_font_get_user_data (hb_font_t *font,
589 hb_user_data_key_t *key);
590
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800591HB_EXTERN void
Behdad Esfahbod74f1d892011-05-10 19:39:32 -0400592hb_font_make_immutable (hb_font_t *font);
593
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800594HB_EXTERN hb_bool_t
Behdad Esfahbod74f1d892011-05-10 19:39:32 -0400595hb_font_is_immutable (hb_font_t *font);
596
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800597HB_EXTERN void
Behdad Esfahbod3e905e32015-10-08 12:51:02 -0400598hb_font_set_parent (hb_font_t *font,
599 hb_font_t *parent);
600
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800601HB_EXTERN hb_font_t *
Behdad Esfahboddefc45b2011-05-10 20:02:49 -0400602hb_font_get_parent (hb_font_t *font);
Behdad Esfahbod5fa849b2011-04-27 21:46:01 -0400603
Behdad Esfahbod95808ba2017-02-03 10:39:40 -0800604HB_EXTERN void
605hb_font_set_face (hb_font_t *font,
606 hb_face_t *face);
607
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800608HB_EXTERN hb_face_t *
Behdad Esfahbod72657e42011-05-02 20:46:32 -0400609hb_font_get_face (hb_font_t *font);
610
611
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800612HB_EXTERN void
Behdad Esfahbod8fb3d1a2009-11-03 18:34:20 -0500613hb_font_set_funcs (hb_font_t *font,
614 hb_font_funcs_t *klass,
Behdad Esfahbodb9d975b2011-05-10 20:41:13 -0400615 void *font_data,
Behdad Esfahbod56681892011-04-20 03:03:32 -0400616 hb_destroy_func_t destroy);
Behdad Esfahbod0ead4812009-08-02 17:41:36 -0400617
Behdad Esfahbodb9415e72011-08-17 19:21:44 +0200618/* Be *very* careful with this function! */
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800619HB_EXTERN void
Behdad Esfahbodb9415e72011-08-17 19:21:44 +0200620hb_font_set_funcs_data (hb_font_t *font,
621 void *font_data,
622 hb_destroy_func_t destroy);
623
Behdad Esfahbod5ebabec2009-11-03 15:15:07 -0500624
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800625HB_EXTERN void
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400626hb_font_set_scale (hb_font_t *font,
Behdad Esfahbodda975412011-04-21 15:08:01 -0400627 int x_scale,
628 int y_scale);
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400629
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800630HB_EXTERN void
Behdad Esfahbod19c0eab2010-10-04 16:45:21 -0400631hb_font_get_scale (hb_font_t *font,
Behdad Esfahbodda975412011-04-21 15:08:01 -0400632 int *x_scale,
633 int *y_scale);
Behdad Esfahbod19c0eab2010-10-04 16:45:21 -0400634
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400635/*
636 * A zero value means "no hinting in that direction"
637 */
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800638HB_EXTERN void
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400639hb_font_set_ppem (hb_font_t *font,
640 unsigned int x_ppem,
641 unsigned int y_ppem);
642
Chun-wei Fan835bbdc2015-11-19 18:34:12 +0800643HB_EXTERN void
Behdad Esfahbod19c0eab2010-10-04 16:45:21 -0400644hb_font_get_ppem (hb_font_t *font,
645 unsigned int *x_ppem,
646 unsigned int *y_ppem);
647
Behdad Esfahbodb57f18d2017-10-11 11:47:47 +0200648/*
649 * Point size per EM. Used for optical-sizing in CoreText.
Behdad Esfahbod374bb482017-10-11 15:37:50 +0200650 * A value of zero means "not set".
Behdad Esfahbodb57f18d2017-10-11 11:47:47 +0200651 */
652HB_EXTERN void
653hb_font_set_ptem (hb_font_t *font, float ptem);
654
655HB_EXTERN float
656hb_font_get_ptem (hb_font_t *font);
657
Behdad Esfahbod24911342017-01-21 15:21:50 -0800658HB_EXTERN void
Behdad Esfahbodbb1e1922017-01-21 17:41:37 -0800659hb_font_set_variations (hb_font_t *font,
660 const hb_variation_t *variations,
661 unsigned int variations_length);
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400662
Behdad Esfahbodad69e8f2016-09-09 22:23:34 -0700663HB_EXTERN void
Behdad Esfahbod8b2a5802017-01-21 15:05:00 -0800664hb_font_set_var_coords_design (hb_font_t *font,
Behdad Esfahbod24911342017-01-21 15:21:50 -0800665 const float *coords,
Behdad Esfahbod8b2a5802017-01-21 15:05:00 -0800666 unsigned int coords_length);
667
668HB_EXTERN void
Behdad Esfahbodad69e8f2016-09-09 22:23:34 -0700669hb_font_set_var_coords_normalized (hb_font_t *font,
Behdad Esfahbod24911342017-01-21 15:21:50 -0800670 const int *coords, /* 2.14 normalized */
Behdad Esfahbodad69e8f2016-09-09 22:23:34 -0700671 unsigned int coords_length);
672
Behdad Esfahbod7647a052017-01-22 17:47:49 -0800673HB_EXTERN const int *
Behdad Esfahbodbf0d3a62017-01-21 14:48:46 -0800674hb_font_get_var_coords_normalized (hb_font_t *font,
675 unsigned int *length);
676
Behdad Esfahbodc62b5032009-08-01 19:54:49 -0400677HB_END_DECLS
678
679#endif /* HB_FONT_H */