1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker * Copyright © 2018 Google, Inc.
3*2d1272b8SAndroid Build Coastguard Worker *
4*2d1272b8SAndroid Build Coastguard Worker * This is part of HarfBuzz, a text shaping library.
5*2d1272b8SAndroid Build Coastguard Worker *
6*2d1272b8SAndroid Build Coastguard Worker * Permission is hereby granted, without written agreement and without
7*2d1272b8SAndroid Build Coastguard Worker * license or royalty fees, to use, copy, modify, and distribute this
8*2d1272b8SAndroid Build Coastguard Worker * software and its documentation for any purpose, provided that the
9*2d1272b8SAndroid Build Coastguard Worker * above copyright notice and the following two paragraphs appear in
10*2d1272b8SAndroid Build Coastguard Worker * all copies of this software.
11*2d1272b8SAndroid Build Coastguard Worker *
12*2d1272b8SAndroid Build Coastguard Worker * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
13*2d1272b8SAndroid Build Coastguard Worker * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
14*2d1272b8SAndroid Build Coastguard Worker * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
15*2d1272b8SAndroid Build Coastguard Worker * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
16*2d1272b8SAndroid Build Coastguard Worker * DAMAGE.
17*2d1272b8SAndroid Build Coastguard Worker *
18*2d1272b8SAndroid Build Coastguard Worker * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
19*2d1272b8SAndroid Build Coastguard Worker * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
20*2d1272b8SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
21*2d1272b8SAndroid Build Coastguard Worker * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
22*2d1272b8SAndroid Build Coastguard Worker * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
23*2d1272b8SAndroid Build Coastguard Worker *
24*2d1272b8SAndroid Build Coastguard Worker * Google Author(s): Garret Rieger, Rod Sheeter, Behdad Esfahbod
25*2d1272b8SAndroid Build Coastguard Worker */
26*2d1272b8SAndroid Build Coastguard Worker
27*2d1272b8SAndroid Build Coastguard Worker #include "hb-subset-instancer-solver.hh"
28*2d1272b8SAndroid Build Coastguard Worker #include "hb-subset.hh"
29*2d1272b8SAndroid Build Coastguard Worker #include "hb-set.hh"
30*2d1272b8SAndroid Build Coastguard Worker #include "hb-utf.hh"
31*2d1272b8SAndroid Build Coastguard Worker
32*2d1272b8SAndroid Build Coastguard Worker
hb_subset_input_t()33*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_t::hb_subset_input_t ()
34*2d1272b8SAndroid Build Coastguard Worker {
35*2d1272b8SAndroid Build Coastguard Worker for (auto& set : sets_iter ())
36*2d1272b8SAndroid Build Coastguard Worker set = hb::shared_ptr<hb_set_t> (hb_set_create ());
37*2d1272b8SAndroid Build Coastguard Worker
38*2d1272b8SAndroid Build Coastguard Worker if (in_error ())
39*2d1272b8SAndroid Build Coastguard Worker return;
40*2d1272b8SAndroid Build Coastguard Worker
41*2d1272b8SAndroid Build Coastguard Worker flags = HB_SUBSET_FLAGS_DEFAULT;
42*2d1272b8SAndroid Build Coastguard Worker
43*2d1272b8SAndroid Build Coastguard Worker hb_set_add_range (sets.name_ids, 0, 6);
44*2d1272b8SAndroid Build Coastguard Worker hb_set_add (sets.name_languages, 0x0409);
45*2d1272b8SAndroid Build Coastguard Worker
46*2d1272b8SAndroid Build Coastguard Worker hb_tag_t default_drop_tables[] = {
47*2d1272b8SAndroid Build Coastguard Worker // Layout disabled by default
48*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'o', 'r', 'x'),
49*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'o', 'r', 't'),
50*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('k', 'e', 'r', 'x'),
51*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('k', 'e', 'r', 'n'),
52*2d1272b8SAndroid Build Coastguard Worker
53*2d1272b8SAndroid Build Coastguard Worker // Copied from fontTools:
54*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('J', 'S', 'T', 'F'),
55*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('D', 'S', 'I', 'G'),
56*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('E', 'B', 'D', 'T'),
57*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('E', 'B', 'L', 'C'),
58*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('E', 'B', 'S', 'C'),
59*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('S', 'V', 'G', ' '),
60*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('P', 'C', 'L', 'T'),
61*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('L', 'T', 'S', 'H'),
62*2d1272b8SAndroid Build Coastguard Worker // Graphite tables
63*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('F', 'e', 'a', 't'),
64*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('G', 'l', 'a', 't'),
65*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('G', 'l', 'o', 'c'),
66*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('S', 'i', 'l', 'f'),
67*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('S', 'i', 'l', 'l'),
68*2d1272b8SAndroid Build Coastguard Worker };
69*2d1272b8SAndroid Build Coastguard Worker sets.drop_tables->add_array (default_drop_tables, ARRAY_LENGTH (default_drop_tables));
70*2d1272b8SAndroid Build Coastguard Worker
71*2d1272b8SAndroid Build Coastguard Worker hb_tag_t default_no_subset_tables[] = {
72*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('g', 'a', 's', 'p'),
73*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('f', 'p', 'g', 'm'),
74*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('p', 'r', 'e', 'p'),
75*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('V', 'D', 'M', 'X'),
76*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('D', 'S', 'I', 'G'),
77*2d1272b8SAndroid Build Coastguard Worker };
78*2d1272b8SAndroid Build Coastguard Worker sets.no_subset_tables->add_array (default_no_subset_tables,
79*2d1272b8SAndroid Build Coastguard Worker ARRAY_LENGTH (default_no_subset_tables));
80*2d1272b8SAndroid Build Coastguard Worker
81*2d1272b8SAndroid Build Coastguard Worker //copied from _layout_features_groups in fonttools
82*2d1272b8SAndroid Build Coastguard Worker hb_tag_t default_layout_features[] = {
83*2d1272b8SAndroid Build Coastguard Worker // default shaper
84*2d1272b8SAndroid Build Coastguard Worker // common
85*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'v', 'r', 'n'),
86*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'c', 'm', 'p'),
87*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('l', 'i', 'g', 'a'),
88*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('l', 'o', 'c', 'l'),
89*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'a', 'r', 'k'),
90*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'k', 'm', 'k'),
91*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'l', 'i', 'g'),
92*2d1272b8SAndroid Build Coastguard Worker
93*2d1272b8SAndroid Build Coastguard Worker //fractions
94*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('f', 'r', 'a', 'c'),
95*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('n', 'u', 'm', 'r'),
96*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('d', 'n', 'o', 'm'),
97*2d1272b8SAndroid Build Coastguard Worker
98*2d1272b8SAndroid Build Coastguard Worker //horizontal
99*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'a', 'l', 't'),
100*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'l', 'i', 'g'),
101*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'u', 'r', 's'),
102*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('k', 'e', 'r', 'n'),
103*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'c', 'l', 't'),
104*2d1272b8SAndroid Build Coastguard Worker
105*2d1272b8SAndroid Build Coastguard Worker //vertical
106*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'a', 'l', 't'),
107*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'e', 'r', 't'),
108*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'k', 'r', 'n'),
109*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'p', 'a', 'l'),
110*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'r', 't', '2'),
111*2d1272b8SAndroid Build Coastguard Worker
112*2d1272b8SAndroid Build Coastguard Worker //ltr
113*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('l', 't', 'r', 'a'),
114*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('l', 't', 'r', 'm'),
115*2d1272b8SAndroid Build Coastguard Worker
116*2d1272b8SAndroid Build Coastguard Worker //rtl
117*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 't', 'l', 'a'),
118*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 't', 'l', 'm'),
119*2d1272b8SAndroid Build Coastguard Worker
120*2d1272b8SAndroid Build Coastguard Worker //random
121*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'a', 'n', 'd'),
122*2d1272b8SAndroid Build Coastguard Worker
123*2d1272b8SAndroid Build Coastguard Worker //justify
124*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('j', 'a', 'l', 't'), // HarfBuzz doesn't use; others might
125*2d1272b8SAndroid Build Coastguard Worker
126*2d1272b8SAndroid Build Coastguard Worker //East Asian spacing
127*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'h', 'w', 's'),
128*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'c', 'h', 'w'),
129*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('h', 'a', 'l', 't'),
130*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'h', 'a', 'l'),
131*2d1272b8SAndroid Build Coastguard Worker
132*2d1272b8SAndroid Build Coastguard Worker //private
133*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('H', 'a', 'r', 'f'),
134*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('H', 'A', 'R', 'F'),
135*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('B', 'u', 'z', 'z'),
136*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('B', 'U', 'Z', 'Z'),
137*2d1272b8SAndroid Build Coastguard Worker
138*2d1272b8SAndroid Build Coastguard Worker //shapers
139*2d1272b8SAndroid Build Coastguard Worker
140*2d1272b8SAndroid Build Coastguard Worker //arabic
141*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('i', 'n', 'i', 't'),
142*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'e', 'd', 'i'),
143*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('f', 'i', 'n', 'a'),
144*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('i', 's', 'o', 'l'),
145*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 'e', 'd', '2'),
146*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('f', 'i', 'n', '2'),
147*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('f', 'i', 'n', '3'),
148*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 's', 'w', 'h'),
149*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('m', 's', 'e', 't'),
150*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('s', 't', 'c', 'h'),
151*2d1272b8SAndroid Build Coastguard Worker
152*2d1272b8SAndroid Build Coastguard Worker //hangul
153*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('l', 'j', 'm', 'o'),
154*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'j', 'm', 'o'),
155*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('t', 'j', 'm', 'o'),
156*2d1272b8SAndroid Build Coastguard Worker
157*2d1272b8SAndroid Build Coastguard Worker //tibetan
158*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'b', 'v', 's'),
159*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('b', 'l', 'w', 's'),
160*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'b', 'v', 'm'),
161*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('b', 'l', 'w', 'm'),
162*2d1272b8SAndroid Build Coastguard Worker
163*2d1272b8SAndroid Build Coastguard Worker //indic
164*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('n', 'u', 'k', 't'),
165*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'k', 'h', 'n'),
166*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'p', 'h', 'f'),
167*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('r', 'k', 'r', 'f'),
168*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('p', 'r', 'e', 'f'),
169*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('b', 'l', 'w', 'f'),
170*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('h', 'a', 'l', 'f'),
171*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'b', 'v', 'f'),
172*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('p', 's', 't', 'f'),
173*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'f', 'a', 'r'),
174*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('v', 'a', 't', 'u'),
175*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('c', 'j', 'c', 't'),
176*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('i', 'n', 'i', 't'),
177*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('p', 'r', 'e', 's'),
178*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'b', 'v', 's'),
179*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('b', 'l', 'w', 's'),
180*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('p', 's', 't', 's'),
181*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('h', 'a', 'l', 'n'),
182*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('d', 'i', 's', 't'),
183*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('a', 'b', 'v', 'm'),
184*2d1272b8SAndroid Build Coastguard Worker HB_TAG ('b', 'l', 'w', 'm'),
185*2d1272b8SAndroid Build Coastguard Worker };
186*2d1272b8SAndroid Build Coastguard Worker
187*2d1272b8SAndroid Build Coastguard Worker sets.layout_features->add_array (default_layout_features, ARRAY_LENGTH (default_layout_features));
188*2d1272b8SAndroid Build Coastguard Worker
189*2d1272b8SAndroid Build Coastguard Worker sets.layout_scripts->invert (); // Default to all scripts.
190*2d1272b8SAndroid Build Coastguard Worker }
191*2d1272b8SAndroid Build Coastguard Worker
192*2d1272b8SAndroid Build Coastguard Worker /**
193*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_create_or_fail:
194*2d1272b8SAndroid Build Coastguard Worker *
195*2d1272b8SAndroid Build Coastguard Worker * Creates a new subset input object.
196*2d1272b8SAndroid Build Coastguard Worker *
197*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer full): New subset input, or `NULL` if failed. Destroy
198*2d1272b8SAndroid Build Coastguard Worker * with hb_subset_input_destroy().
199*2d1272b8SAndroid Build Coastguard Worker *
200*2d1272b8SAndroid Build Coastguard Worker * Since: 1.8.0
201*2d1272b8SAndroid Build Coastguard Worker **/
202*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_t *
hb_subset_input_create_or_fail(void)203*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_create_or_fail (void)
204*2d1272b8SAndroid Build Coastguard Worker {
205*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_t *input = hb_object_create<hb_subset_input_t>();
206*2d1272b8SAndroid Build Coastguard Worker
207*2d1272b8SAndroid Build Coastguard Worker if (unlikely (!input))
208*2d1272b8SAndroid Build Coastguard Worker return nullptr;
209*2d1272b8SAndroid Build Coastguard Worker
210*2d1272b8SAndroid Build Coastguard Worker if (input->in_error ())
211*2d1272b8SAndroid Build Coastguard Worker {
212*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_destroy (input);
213*2d1272b8SAndroid Build Coastguard Worker return nullptr;
214*2d1272b8SAndroid Build Coastguard Worker }
215*2d1272b8SAndroid Build Coastguard Worker
216*2d1272b8SAndroid Build Coastguard Worker return input;
217*2d1272b8SAndroid Build Coastguard Worker }
218*2d1272b8SAndroid Build Coastguard Worker
219*2d1272b8SAndroid Build Coastguard Worker /**
220*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_reference: (skip)
221*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
222*2d1272b8SAndroid Build Coastguard Worker *
223*2d1272b8SAndroid Build Coastguard Worker * Increases the reference count on @input.
224*2d1272b8SAndroid Build Coastguard Worker *
225*2d1272b8SAndroid Build Coastguard Worker * Return value: @input.
226*2d1272b8SAndroid Build Coastguard Worker *
227*2d1272b8SAndroid Build Coastguard Worker * Since: 1.8.0
228*2d1272b8SAndroid Build Coastguard Worker **/
229*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_t *
hb_subset_input_reference(hb_subset_input_t * input)230*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_reference (hb_subset_input_t *input)
231*2d1272b8SAndroid Build Coastguard Worker {
232*2d1272b8SAndroid Build Coastguard Worker return hb_object_reference (input);
233*2d1272b8SAndroid Build Coastguard Worker }
234*2d1272b8SAndroid Build Coastguard Worker
235*2d1272b8SAndroid Build Coastguard Worker /**
236*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_destroy:
237*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
238*2d1272b8SAndroid Build Coastguard Worker *
239*2d1272b8SAndroid Build Coastguard Worker * Decreases the reference count on @input, and if it reaches zero, destroys
240*2d1272b8SAndroid Build Coastguard Worker * @input, freeing all memory.
241*2d1272b8SAndroid Build Coastguard Worker *
242*2d1272b8SAndroid Build Coastguard Worker * Since: 1.8.0
243*2d1272b8SAndroid Build Coastguard Worker **/
244*2d1272b8SAndroid Build Coastguard Worker void
hb_subset_input_destroy(hb_subset_input_t * input)245*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_destroy (hb_subset_input_t *input)
246*2d1272b8SAndroid Build Coastguard Worker {
247*2d1272b8SAndroid Build Coastguard Worker if (!hb_object_destroy (input)) return;
248*2d1272b8SAndroid Build Coastguard Worker
249*2d1272b8SAndroid Build Coastguard Worker hb_free (input);
250*2d1272b8SAndroid Build Coastguard Worker }
251*2d1272b8SAndroid Build Coastguard Worker
252*2d1272b8SAndroid Build Coastguard Worker /**
253*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_unicode_set:
254*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
255*2d1272b8SAndroid Build Coastguard Worker *
256*2d1272b8SAndroid Build Coastguard Worker * Gets the set of Unicode code points to retain, the caller should modify the
257*2d1272b8SAndroid Build Coastguard Worker * set as needed.
258*2d1272b8SAndroid Build Coastguard Worker *
259*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer none): pointer to the #hb_set_t of Unicode code
260*2d1272b8SAndroid Build Coastguard Worker * points.
261*2d1272b8SAndroid Build Coastguard Worker *
262*2d1272b8SAndroid Build Coastguard Worker * Since: 1.8.0
263*2d1272b8SAndroid Build Coastguard Worker **/
264*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_set_t *
hb_subset_input_unicode_set(hb_subset_input_t * input)265*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_unicode_set (hb_subset_input_t *input)
266*2d1272b8SAndroid Build Coastguard Worker {
267*2d1272b8SAndroid Build Coastguard Worker return input->sets.unicodes;
268*2d1272b8SAndroid Build Coastguard Worker }
269*2d1272b8SAndroid Build Coastguard Worker
270*2d1272b8SAndroid Build Coastguard Worker /**
271*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_glyph_set:
272*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
273*2d1272b8SAndroid Build Coastguard Worker *
274*2d1272b8SAndroid Build Coastguard Worker * Gets the set of glyph IDs to retain, the caller should modify the set as
275*2d1272b8SAndroid Build Coastguard Worker * needed.
276*2d1272b8SAndroid Build Coastguard Worker *
277*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer none): pointer to the #hb_set_t of glyph IDs.
278*2d1272b8SAndroid Build Coastguard Worker *
279*2d1272b8SAndroid Build Coastguard Worker * Since: 1.8.0
280*2d1272b8SAndroid Build Coastguard Worker **/
281*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_set_t *
hb_subset_input_glyph_set(hb_subset_input_t * input)282*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_glyph_set (hb_subset_input_t *input)
283*2d1272b8SAndroid Build Coastguard Worker {
284*2d1272b8SAndroid Build Coastguard Worker return input->sets.glyphs;
285*2d1272b8SAndroid Build Coastguard Worker }
286*2d1272b8SAndroid Build Coastguard Worker
287*2d1272b8SAndroid Build Coastguard Worker /**
288*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_set:
289*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
290*2d1272b8SAndroid Build Coastguard Worker * @set_type: a #hb_subset_sets_t set type.
291*2d1272b8SAndroid Build Coastguard Worker *
292*2d1272b8SAndroid Build Coastguard Worker * Gets the set of the specified type.
293*2d1272b8SAndroid Build Coastguard Worker *
294*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer none): pointer to the #hb_set_t of the specified type.
295*2d1272b8SAndroid Build Coastguard Worker *
296*2d1272b8SAndroid Build Coastguard Worker * Since: 2.9.1
297*2d1272b8SAndroid Build Coastguard Worker **/
298*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_set_t *
hb_subset_input_set(hb_subset_input_t * input,hb_subset_sets_t set_type)299*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_set (hb_subset_input_t *input, hb_subset_sets_t set_type)
300*2d1272b8SAndroid Build Coastguard Worker {
301*2d1272b8SAndroid Build Coastguard Worker return input->sets_iter () [set_type];
302*2d1272b8SAndroid Build Coastguard Worker }
303*2d1272b8SAndroid Build Coastguard Worker
304*2d1272b8SAndroid Build Coastguard Worker /**
305*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_get_flags:
306*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
307*2d1272b8SAndroid Build Coastguard Worker *
308*2d1272b8SAndroid Build Coastguard Worker * Gets all of the subsetting flags in the input object.
309*2d1272b8SAndroid Build Coastguard Worker *
310*2d1272b8SAndroid Build Coastguard Worker * Return value: the subsetting flags bit field.
311*2d1272b8SAndroid Build Coastguard Worker *
312*2d1272b8SAndroid Build Coastguard Worker * Since: 2.9.0
313*2d1272b8SAndroid Build Coastguard Worker **/
314*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_subset_flags_t
hb_subset_input_get_flags(hb_subset_input_t * input)315*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_get_flags (hb_subset_input_t *input)
316*2d1272b8SAndroid Build Coastguard Worker {
317*2d1272b8SAndroid Build Coastguard Worker return (hb_subset_flags_t) input->flags;
318*2d1272b8SAndroid Build Coastguard Worker }
319*2d1272b8SAndroid Build Coastguard Worker
320*2d1272b8SAndroid Build Coastguard Worker /**
321*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_set_flags:
322*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
323*2d1272b8SAndroid Build Coastguard Worker * @value: bit field of flags
324*2d1272b8SAndroid Build Coastguard Worker *
325*2d1272b8SAndroid Build Coastguard Worker * Sets all of the flags in the input object to the values specified by the bit
326*2d1272b8SAndroid Build Coastguard Worker * field.
327*2d1272b8SAndroid Build Coastguard Worker *
328*2d1272b8SAndroid Build Coastguard Worker * Since: 2.9.0
329*2d1272b8SAndroid Build Coastguard Worker **/
330*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN void
hb_subset_input_set_flags(hb_subset_input_t * input,unsigned value)331*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_set_flags (hb_subset_input_t *input,
332*2d1272b8SAndroid Build Coastguard Worker unsigned value)
333*2d1272b8SAndroid Build Coastguard Worker {
334*2d1272b8SAndroid Build Coastguard Worker input->flags = (hb_subset_flags_t) value;
335*2d1272b8SAndroid Build Coastguard Worker }
336*2d1272b8SAndroid Build Coastguard Worker
337*2d1272b8SAndroid Build Coastguard Worker /**
338*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_set_user_data: (skip)
339*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
340*2d1272b8SAndroid Build Coastguard Worker * @key: The user-data key to set
341*2d1272b8SAndroid Build Coastguard Worker * @data: A pointer to the user data
342*2d1272b8SAndroid Build Coastguard Worker * @destroy: (nullable): A callback to call when @data is not needed anymore
343*2d1272b8SAndroid Build Coastguard Worker * @replace: Whether to replace an existing data with the same key
344*2d1272b8SAndroid Build Coastguard Worker *
345*2d1272b8SAndroid Build Coastguard Worker * Attaches a user-data key/data pair to the given subset input object.
346*2d1272b8SAndroid Build Coastguard Worker *
347*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if success, `false` otherwise
348*2d1272b8SAndroid Build Coastguard Worker *
349*2d1272b8SAndroid Build Coastguard Worker * Since: 2.9.0
350*2d1272b8SAndroid Build Coastguard Worker **/
351*2d1272b8SAndroid Build Coastguard Worker hb_bool_t
hb_subset_input_set_user_data(hb_subset_input_t * input,hb_user_data_key_t * key,void * data,hb_destroy_func_t destroy,hb_bool_t replace)352*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_set_user_data (hb_subset_input_t *input,
353*2d1272b8SAndroid Build Coastguard Worker hb_user_data_key_t *key,
354*2d1272b8SAndroid Build Coastguard Worker void * data,
355*2d1272b8SAndroid Build Coastguard Worker hb_destroy_func_t destroy,
356*2d1272b8SAndroid Build Coastguard Worker hb_bool_t replace)
357*2d1272b8SAndroid Build Coastguard Worker {
358*2d1272b8SAndroid Build Coastguard Worker return hb_object_set_user_data (input, key, data, destroy, replace);
359*2d1272b8SAndroid Build Coastguard Worker }
360*2d1272b8SAndroid Build Coastguard Worker
361*2d1272b8SAndroid Build Coastguard Worker /**
362*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_get_user_data: (skip)
363*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
364*2d1272b8SAndroid Build Coastguard Worker * @key: The user-data key to query
365*2d1272b8SAndroid Build Coastguard Worker *
366*2d1272b8SAndroid Build Coastguard Worker * Fetches the user data associated with the specified key,
367*2d1272b8SAndroid Build Coastguard Worker * attached to the specified subset input object.
368*2d1272b8SAndroid Build Coastguard Worker *
369*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer none): A pointer to the user data
370*2d1272b8SAndroid Build Coastguard Worker *
371*2d1272b8SAndroid Build Coastguard Worker * Since: 2.9.0
372*2d1272b8SAndroid Build Coastguard Worker **/
373*2d1272b8SAndroid Build Coastguard Worker void *
hb_subset_input_get_user_data(const hb_subset_input_t * input,hb_user_data_key_t * key)374*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_get_user_data (const hb_subset_input_t *input,
375*2d1272b8SAndroid Build Coastguard Worker hb_user_data_key_t *key)
376*2d1272b8SAndroid Build Coastguard Worker {
377*2d1272b8SAndroid Build Coastguard Worker return hb_object_get_user_data (input, key);
378*2d1272b8SAndroid Build Coastguard Worker }
379*2d1272b8SAndroid Build Coastguard Worker
380*2d1272b8SAndroid Build Coastguard Worker /**
381*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_keep_everything:
382*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object
383*2d1272b8SAndroid Build Coastguard Worker *
384*2d1272b8SAndroid Build Coastguard Worker * Configure input object to keep everything in the font face.
385*2d1272b8SAndroid Build Coastguard Worker * That is, all Unicodes, glyphs, names, layout items,
386*2d1272b8SAndroid Build Coastguard Worker * glyph names, etc.
387*2d1272b8SAndroid Build Coastguard Worker *
388*2d1272b8SAndroid Build Coastguard Worker * The input can be tailored afterwards by the caller.
389*2d1272b8SAndroid Build Coastguard Worker *
390*2d1272b8SAndroid Build Coastguard Worker * Since: 7.0.0
391*2d1272b8SAndroid Build Coastguard Worker */
392*2d1272b8SAndroid Build Coastguard Worker void
hb_subset_input_keep_everything(hb_subset_input_t * input)393*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_keep_everything (hb_subset_input_t *input)
394*2d1272b8SAndroid Build Coastguard Worker {
395*2d1272b8SAndroid Build Coastguard Worker const hb_subset_sets_t indices[] = {HB_SUBSET_SETS_UNICODE,
396*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_SETS_GLYPH_INDEX,
397*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_SETS_NAME_ID,
398*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_SETS_NAME_LANG_ID,
399*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_SETS_LAYOUT_FEATURE_TAG,
400*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_SETS_LAYOUT_SCRIPT_TAG};
401*2d1272b8SAndroid Build Coastguard Worker
402*2d1272b8SAndroid Build Coastguard Worker for (auto idx : hb_iter (indices))
403*2d1272b8SAndroid Build Coastguard Worker {
404*2d1272b8SAndroid Build Coastguard Worker hb_set_t *set = hb_subset_input_set (input, idx);
405*2d1272b8SAndroid Build Coastguard Worker hb_set_clear (set);
406*2d1272b8SAndroid Build Coastguard Worker hb_set_invert (set);
407*2d1272b8SAndroid Build Coastguard Worker }
408*2d1272b8SAndroid Build Coastguard Worker
409*2d1272b8SAndroid Build Coastguard Worker // Don't drop any tables
410*2d1272b8SAndroid Build Coastguard Worker hb_set_clear (hb_subset_input_set (input, HB_SUBSET_SETS_DROP_TABLE_TAG));
411*2d1272b8SAndroid Build Coastguard Worker
412*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_set_flags (input,
413*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_FLAGS_NOTDEF_OUTLINE |
414*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_FLAGS_GLYPH_NAMES |
415*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_FLAGS_NAME_LEGACY |
416*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_FLAGS_NO_PRUNE_UNICODE_RANGES |
417*2d1272b8SAndroid Build Coastguard Worker HB_SUBSET_FLAGS_PASSTHROUGH_UNRECOGNIZED);
418*2d1272b8SAndroid Build Coastguard Worker }
419*2d1272b8SAndroid Build Coastguard Worker
420*2d1272b8SAndroid Build Coastguard Worker #ifndef HB_NO_VAR
421*2d1272b8SAndroid Build Coastguard Worker /**
422*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_pin_all_axes_to_default: (skip)
423*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
424*2d1272b8SAndroid Build Coastguard Worker * @face: a #hb_face_t object.
425*2d1272b8SAndroid Build Coastguard Worker *
426*2d1272b8SAndroid Build Coastguard Worker * Pin all axes to default locations in the given subset input object.
427*2d1272b8SAndroid Build Coastguard Worker *
428*2d1272b8SAndroid Build Coastguard Worker * All axes in a font must be pinned. Additionally, `CFF2` table, if present,
429*2d1272b8SAndroid Build Coastguard Worker * will be de-subroutinized.
430*2d1272b8SAndroid Build Coastguard Worker *
431*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if success, `false` otherwise
432*2d1272b8SAndroid Build Coastguard Worker *
433*2d1272b8SAndroid Build Coastguard Worker * Since: 8.3.1
434*2d1272b8SAndroid Build Coastguard Worker **/
435*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_pin_all_axes_to_default(hb_subset_input_t * input,hb_face_t * face)436*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_pin_all_axes_to_default (hb_subset_input_t *input,
437*2d1272b8SAndroid Build Coastguard Worker hb_face_t *face)
438*2d1272b8SAndroid Build Coastguard Worker {
439*2d1272b8SAndroid Build Coastguard Worker unsigned axis_count = hb_ot_var_get_axis_count (face);
440*2d1272b8SAndroid Build Coastguard Worker if (!axis_count) return false;
441*2d1272b8SAndroid Build Coastguard Worker
442*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_axis_info_t *axis_infos = (hb_ot_var_axis_info_t *) hb_calloc (axis_count, sizeof (hb_ot_var_axis_info_t));
443*2d1272b8SAndroid Build Coastguard Worker if (unlikely (!axis_infos)) return false;
444*2d1272b8SAndroid Build Coastguard Worker
445*2d1272b8SAndroid Build Coastguard Worker (void) hb_ot_var_get_axis_infos (face, 0, &axis_count, axis_infos);
446*2d1272b8SAndroid Build Coastguard Worker
447*2d1272b8SAndroid Build Coastguard Worker for (unsigned i = 0; i < axis_count; i++)
448*2d1272b8SAndroid Build Coastguard Worker {
449*2d1272b8SAndroid Build Coastguard Worker hb_tag_t axis_tag = axis_infos[i].tag;
450*2d1272b8SAndroid Build Coastguard Worker double default_val = (double) axis_infos[i].default_value;
451*2d1272b8SAndroid Build Coastguard Worker if (!input->axes_location.set (axis_tag, Triple (default_val, default_val, default_val)))
452*2d1272b8SAndroid Build Coastguard Worker {
453*2d1272b8SAndroid Build Coastguard Worker hb_free (axis_infos);
454*2d1272b8SAndroid Build Coastguard Worker return false;
455*2d1272b8SAndroid Build Coastguard Worker }
456*2d1272b8SAndroid Build Coastguard Worker }
457*2d1272b8SAndroid Build Coastguard Worker hb_free (axis_infos);
458*2d1272b8SAndroid Build Coastguard Worker return true;
459*2d1272b8SAndroid Build Coastguard Worker }
460*2d1272b8SAndroid Build Coastguard Worker
461*2d1272b8SAndroid Build Coastguard Worker /**
462*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_pin_axis_to_default: (skip)
463*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
464*2d1272b8SAndroid Build Coastguard Worker * @face: a #hb_face_t object.
465*2d1272b8SAndroid Build Coastguard Worker * @axis_tag: Tag of the axis to be pinned
466*2d1272b8SAndroid Build Coastguard Worker *
467*2d1272b8SAndroid Build Coastguard Worker * Pin an axis to its default location in the given subset input object.
468*2d1272b8SAndroid Build Coastguard Worker *
469*2d1272b8SAndroid Build Coastguard Worker * All axes in a font must be pinned. Additionally, `CFF2` table, if present,
470*2d1272b8SAndroid Build Coastguard Worker * will be de-subroutinized.
471*2d1272b8SAndroid Build Coastguard Worker *
472*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if success, `false` otherwise
473*2d1272b8SAndroid Build Coastguard Worker *
474*2d1272b8SAndroid Build Coastguard Worker * Since: 6.0.0
475*2d1272b8SAndroid Build Coastguard Worker **/
476*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_pin_axis_to_default(hb_subset_input_t * input,hb_face_t * face,hb_tag_t axis_tag)477*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_pin_axis_to_default (hb_subset_input_t *input,
478*2d1272b8SAndroid Build Coastguard Worker hb_face_t *face,
479*2d1272b8SAndroid Build Coastguard Worker hb_tag_t axis_tag)
480*2d1272b8SAndroid Build Coastguard Worker {
481*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_axis_info_t axis_info;
482*2d1272b8SAndroid Build Coastguard Worker if (!hb_ot_var_find_axis_info (face, axis_tag, &axis_info))
483*2d1272b8SAndroid Build Coastguard Worker return false;
484*2d1272b8SAndroid Build Coastguard Worker
485*2d1272b8SAndroid Build Coastguard Worker double default_val = (double) axis_info.default_value;
486*2d1272b8SAndroid Build Coastguard Worker return input->axes_location.set (axis_tag, Triple (default_val, default_val, default_val));
487*2d1272b8SAndroid Build Coastguard Worker }
488*2d1272b8SAndroid Build Coastguard Worker
489*2d1272b8SAndroid Build Coastguard Worker /**
490*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_pin_axis_location: (skip)
491*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
492*2d1272b8SAndroid Build Coastguard Worker * @face: a #hb_face_t object.
493*2d1272b8SAndroid Build Coastguard Worker * @axis_tag: Tag of the axis to be pinned
494*2d1272b8SAndroid Build Coastguard Worker * @axis_value: Location on the axis to be pinned at
495*2d1272b8SAndroid Build Coastguard Worker *
496*2d1272b8SAndroid Build Coastguard Worker * Pin an axis to a fixed location in the given subset input object.
497*2d1272b8SAndroid Build Coastguard Worker *
498*2d1272b8SAndroid Build Coastguard Worker * All axes in a font must be pinned. Additionally, `CFF2` table, if present,
499*2d1272b8SAndroid Build Coastguard Worker * will be de-subroutinized.
500*2d1272b8SAndroid Build Coastguard Worker *
501*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if success, `false` otherwise
502*2d1272b8SAndroid Build Coastguard Worker *
503*2d1272b8SAndroid Build Coastguard Worker * Since: 6.0.0
504*2d1272b8SAndroid Build Coastguard Worker **/
505*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_pin_axis_location(hb_subset_input_t * input,hb_face_t * face,hb_tag_t axis_tag,float axis_value)506*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_pin_axis_location (hb_subset_input_t *input,
507*2d1272b8SAndroid Build Coastguard Worker hb_face_t *face,
508*2d1272b8SAndroid Build Coastguard Worker hb_tag_t axis_tag,
509*2d1272b8SAndroid Build Coastguard Worker float axis_value)
510*2d1272b8SAndroid Build Coastguard Worker {
511*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_axis_info_t axis_info;
512*2d1272b8SAndroid Build Coastguard Worker if (!hb_ot_var_find_axis_info (face, axis_tag, &axis_info))
513*2d1272b8SAndroid Build Coastguard Worker return false;
514*2d1272b8SAndroid Build Coastguard Worker
515*2d1272b8SAndroid Build Coastguard Worker double val = hb_clamp((double) axis_value, (double) axis_info.min_value, (double) axis_info.max_value);
516*2d1272b8SAndroid Build Coastguard Worker return input->axes_location.set (axis_tag, Triple (val, val, val));
517*2d1272b8SAndroid Build Coastguard Worker }
518*2d1272b8SAndroid Build Coastguard Worker
519*2d1272b8SAndroid Build Coastguard Worker /**
520*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_set_axis_range: (skip)
521*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
522*2d1272b8SAndroid Build Coastguard Worker * @face: a #hb_face_t object.
523*2d1272b8SAndroid Build Coastguard Worker * @axis_tag: Tag of the axis
524*2d1272b8SAndroid Build Coastguard Worker * @axis_min_value: Minimum value of the axis variation range to set, if NaN the existing min will be used.
525*2d1272b8SAndroid Build Coastguard Worker * @axis_max_value: Maximum value of the axis variation range to set if NaN the existing max will be used.
526*2d1272b8SAndroid Build Coastguard Worker * @axis_def_value: Default value of the axis variation range to set, if NaN the existing default will be used.
527*2d1272b8SAndroid Build Coastguard Worker *
528*2d1272b8SAndroid Build Coastguard Worker * Restricting the range of variation on an axis in the given subset input object.
529*2d1272b8SAndroid Build Coastguard Worker * New min/default/max values will be clamped if they're not within the fvar axis range.
530*2d1272b8SAndroid Build Coastguard Worker *
531*2d1272b8SAndroid Build Coastguard Worker * If the fvar axis default value is not within the new range, the new default
532*2d1272b8SAndroid Build Coastguard Worker * value will be changed to the new min or max value, whichever is closer to the fvar
533*2d1272b8SAndroid Build Coastguard Worker * axis default.
534*2d1272b8SAndroid Build Coastguard Worker *
535*2d1272b8SAndroid Build Coastguard Worker * Note: input min value can not be bigger than input max value. If the input
536*2d1272b8SAndroid Build Coastguard Worker * default value is not within the new min/max range, it'll be clamped.
537*2d1272b8SAndroid Build Coastguard Worker * Note: currently it supports gvar and cvar tables only.
538*2d1272b8SAndroid Build Coastguard Worker *
539*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if success, `false` otherwise
540*2d1272b8SAndroid Build Coastguard Worker *
541*2d1272b8SAndroid Build Coastguard Worker * Since: 8.5.0
542*2d1272b8SAndroid Build Coastguard Worker **/
543*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_set_axis_range(hb_subset_input_t * input,hb_face_t * face,hb_tag_t axis_tag,float axis_min_value,float axis_max_value,float axis_def_value)544*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_set_axis_range (hb_subset_input_t *input,
545*2d1272b8SAndroid Build Coastguard Worker hb_face_t *face,
546*2d1272b8SAndroid Build Coastguard Worker hb_tag_t axis_tag,
547*2d1272b8SAndroid Build Coastguard Worker float axis_min_value,
548*2d1272b8SAndroid Build Coastguard Worker float axis_max_value,
549*2d1272b8SAndroid Build Coastguard Worker float axis_def_value)
550*2d1272b8SAndroid Build Coastguard Worker {
551*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_axis_info_t axis_info;
552*2d1272b8SAndroid Build Coastguard Worker if (!hb_ot_var_find_axis_info (face, axis_tag, &axis_info))
553*2d1272b8SAndroid Build Coastguard Worker return false;
554*2d1272b8SAndroid Build Coastguard Worker
555*2d1272b8SAndroid Build Coastguard Worker float min = !std::isnan(axis_min_value) ? axis_min_value : axis_info.min_value;
556*2d1272b8SAndroid Build Coastguard Worker float max = !std::isnan(axis_max_value) ? axis_max_value : axis_info.max_value;
557*2d1272b8SAndroid Build Coastguard Worker float def = !std::isnan(axis_def_value) ? axis_def_value : axis_info.default_value;
558*2d1272b8SAndroid Build Coastguard Worker
559*2d1272b8SAndroid Build Coastguard Worker if (min > max)
560*2d1272b8SAndroid Build Coastguard Worker return false;
561*2d1272b8SAndroid Build Coastguard Worker
562*2d1272b8SAndroid Build Coastguard Worker float new_min_val = hb_clamp(min, axis_info.min_value, axis_info.max_value);
563*2d1272b8SAndroid Build Coastguard Worker float new_max_val = hb_clamp(max, axis_info.min_value, axis_info.max_value);
564*2d1272b8SAndroid Build Coastguard Worker float new_default_val = hb_clamp(def, new_min_val, new_max_val);
565*2d1272b8SAndroid Build Coastguard Worker return input->axes_location.set (axis_tag, Triple ((double) new_min_val, (double) new_default_val, (double) new_max_val));
566*2d1272b8SAndroid Build Coastguard Worker }
567*2d1272b8SAndroid Build Coastguard Worker
568*2d1272b8SAndroid Build Coastguard Worker /**
569*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_get_axis_range: (skip)
570*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
571*2d1272b8SAndroid Build Coastguard Worker * @axis_tag: Tag of the axis
572*2d1272b8SAndroid Build Coastguard Worker * @axis_min_value: Set to the previously configured minimum value of the axis variation range.
573*2d1272b8SAndroid Build Coastguard Worker * @axis_max_value: Set to the previously configured maximum value of the axis variation range.
574*2d1272b8SAndroid Build Coastguard Worker * @axis_def_value: Set to the previously configured default value of the axis variation range.
575*2d1272b8SAndroid Build Coastguard Worker *
576*2d1272b8SAndroid Build Coastguard Worker * Gets the axis range assigned by previous calls to hb_subset_input_set_axis_range.
577*2d1272b8SAndroid Build Coastguard Worker *
578*2d1272b8SAndroid Build Coastguard Worker * Return value: `true` if a range has been set for this axis tag, `false` otherwise.
579*2d1272b8SAndroid Build Coastguard Worker *
580*2d1272b8SAndroid Build Coastguard Worker * Since: 8.5.0
581*2d1272b8SAndroid Build Coastguard Worker **/
582*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_get_axis_range(hb_subset_input_t * input,hb_tag_t axis_tag,float * axis_min_value,float * axis_max_value,float * axis_def_value)583*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_get_axis_range (hb_subset_input_t *input,
584*2d1272b8SAndroid Build Coastguard Worker hb_tag_t axis_tag,
585*2d1272b8SAndroid Build Coastguard Worker float *axis_min_value,
586*2d1272b8SAndroid Build Coastguard Worker float *axis_max_value,
587*2d1272b8SAndroid Build Coastguard Worker float *axis_def_value)
588*2d1272b8SAndroid Build Coastguard Worker
589*2d1272b8SAndroid Build Coastguard Worker {
590*2d1272b8SAndroid Build Coastguard Worker Triple* triple;
591*2d1272b8SAndroid Build Coastguard Worker if (!input->axes_location.has(axis_tag, &triple)) {
592*2d1272b8SAndroid Build Coastguard Worker return false;
593*2d1272b8SAndroid Build Coastguard Worker }
594*2d1272b8SAndroid Build Coastguard Worker
595*2d1272b8SAndroid Build Coastguard Worker *axis_min_value = triple->minimum;
596*2d1272b8SAndroid Build Coastguard Worker *axis_def_value = triple->middle;
597*2d1272b8SAndroid Build Coastguard Worker *axis_max_value = triple->maximum;
598*2d1272b8SAndroid Build Coastguard Worker return true;
599*2d1272b8SAndroid Build Coastguard Worker }
600*2d1272b8SAndroid Build Coastguard Worker #endif
601*2d1272b8SAndroid Build Coastguard Worker
602*2d1272b8SAndroid Build Coastguard Worker /**
603*2d1272b8SAndroid Build Coastguard Worker * hb_subset_preprocess:
604*2d1272b8SAndroid Build Coastguard Worker * @source: a #hb_face_t object.
605*2d1272b8SAndroid Build Coastguard Worker *
606*2d1272b8SAndroid Build Coastguard Worker * Preprocesses the face and attaches data that will be needed by the
607*2d1272b8SAndroid Build Coastguard Worker * subsetter. Future subsetting operations can then use the precomputed data
608*2d1272b8SAndroid Build Coastguard Worker * to speed up the subsetting operation.
609*2d1272b8SAndroid Build Coastguard Worker *
610*2d1272b8SAndroid Build Coastguard Worker * See [subset-preprocessing](https://github.com/harfbuzz/harfbuzz/blob/main/docs/subset-preprocessing.md)
611*2d1272b8SAndroid Build Coastguard Worker * for more information.
612*2d1272b8SAndroid Build Coastguard Worker *
613*2d1272b8SAndroid Build Coastguard Worker * Note: the preprocessed face may contain sub-blobs that reference the memory
614*2d1272b8SAndroid Build Coastguard Worker * backing the source #hb_face_t. Therefore in the case that this memory is not
615*2d1272b8SAndroid Build Coastguard Worker * owned by the source face you will need to ensure that memory lives
616*2d1272b8SAndroid Build Coastguard Worker * as long as the returned #hb_face_t.
617*2d1272b8SAndroid Build Coastguard Worker *
618*2d1272b8SAndroid Build Coastguard Worker * Returns: a new #hb_face_t.
619*2d1272b8SAndroid Build Coastguard Worker *
620*2d1272b8SAndroid Build Coastguard Worker * Since: 6.0.0
621*2d1272b8SAndroid Build Coastguard Worker **/
622*2d1272b8SAndroid Build Coastguard Worker
623*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_face_t *
hb_subset_preprocess(hb_face_t * source)624*2d1272b8SAndroid Build Coastguard Worker hb_subset_preprocess (hb_face_t *source)
625*2d1272b8SAndroid Build Coastguard Worker {
626*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_t* input = hb_subset_input_create_or_fail ();
627*2d1272b8SAndroid Build Coastguard Worker if (!input)
628*2d1272b8SAndroid Build Coastguard Worker return hb_face_reference (source);
629*2d1272b8SAndroid Build Coastguard Worker
630*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_keep_everything (input);
631*2d1272b8SAndroid Build Coastguard Worker
632*2d1272b8SAndroid Build Coastguard Worker input->attach_accelerator_data = true;
633*2d1272b8SAndroid Build Coastguard Worker
634*2d1272b8SAndroid Build Coastguard Worker // Always use long loca in the preprocessed version. This allows
635*2d1272b8SAndroid Build Coastguard Worker // us to store the glyph bytes unpadded which allows the future subset
636*2d1272b8SAndroid Build Coastguard Worker // operation to run faster by skipping the trim padding step.
637*2d1272b8SAndroid Build Coastguard Worker input->force_long_loca = true;
638*2d1272b8SAndroid Build Coastguard Worker
639*2d1272b8SAndroid Build Coastguard Worker hb_face_t* new_source = hb_subset_or_fail (source, input);
640*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_destroy (input);
641*2d1272b8SAndroid Build Coastguard Worker
642*2d1272b8SAndroid Build Coastguard Worker if (!new_source) {
643*2d1272b8SAndroid Build Coastguard Worker DEBUG_MSG (SUBSET, nullptr, "Preprocessing failed due to subset failure.");
644*2d1272b8SAndroid Build Coastguard Worker return hb_face_reference (source);
645*2d1272b8SAndroid Build Coastguard Worker }
646*2d1272b8SAndroid Build Coastguard Worker
647*2d1272b8SAndroid Build Coastguard Worker return new_source;
648*2d1272b8SAndroid Build Coastguard Worker }
649*2d1272b8SAndroid Build Coastguard Worker
650*2d1272b8SAndroid Build Coastguard Worker /**
651*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_old_to_new_glyph_mapping:
652*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
653*2d1272b8SAndroid Build Coastguard Worker *
654*2d1272b8SAndroid Build Coastguard Worker * Returns a map which can be used to provide an explicit mapping from old to new glyph
655*2d1272b8SAndroid Build Coastguard Worker * id's in the produced subset. The caller should populate the map as desired.
656*2d1272b8SAndroid Build Coastguard Worker * If this map is left empty then glyph ids will be automatically mapped to new
657*2d1272b8SAndroid Build Coastguard Worker * values by the subsetter. If populated, the mapping must be unique. That
658*2d1272b8SAndroid Build Coastguard Worker * is no two original glyph ids can be mapped to the same new id.
659*2d1272b8SAndroid Build Coastguard Worker * Additionally, if a mapping is provided then the retain gids option cannot
660*2d1272b8SAndroid Build Coastguard Worker * be enabled.
661*2d1272b8SAndroid Build Coastguard Worker *
662*2d1272b8SAndroid Build Coastguard Worker * Any glyphs that are retained in the subset which are not specified
663*2d1272b8SAndroid Build Coastguard Worker * in this mapping will be assigned glyph ids after the highest glyph
664*2d1272b8SAndroid Build Coastguard Worker * id in the mapping.
665*2d1272b8SAndroid Build Coastguard Worker *
666*2d1272b8SAndroid Build Coastguard Worker * Note: this will accept and apply non-monotonic mappings, however this
667*2d1272b8SAndroid Build Coastguard Worker * may result in unsorted Coverage tables. Such fonts may not work for all
668*2d1272b8SAndroid Build Coastguard Worker * use cases (for example ots will reject unsorted coverage tables). So it's
669*2d1272b8SAndroid Build Coastguard Worker * recommended, if possible, to supply a monotonic mapping.
670*2d1272b8SAndroid Build Coastguard Worker *
671*2d1272b8SAndroid Build Coastguard Worker * Return value: (transfer none): pointer to the #hb_map_t of the custom glyphs ID map.
672*2d1272b8SAndroid Build Coastguard Worker *
673*2d1272b8SAndroid Build Coastguard Worker * Since: 7.3.0
674*2d1272b8SAndroid Build Coastguard Worker **/
675*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_map_t*
hb_subset_input_old_to_new_glyph_mapping(hb_subset_input_t * input)676*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_old_to_new_glyph_mapping (hb_subset_input_t *input)
677*2d1272b8SAndroid Build Coastguard Worker {
678*2d1272b8SAndroid Build Coastguard Worker return &input->glyph_map;
679*2d1272b8SAndroid Build Coastguard Worker }
680*2d1272b8SAndroid Build Coastguard Worker
681*2d1272b8SAndroid Build Coastguard Worker #ifdef HB_EXPERIMENTAL_API
682*2d1272b8SAndroid Build Coastguard Worker /**
683*2d1272b8SAndroid Build Coastguard Worker * hb_subset_input_override_name_table:
684*2d1272b8SAndroid Build Coastguard Worker * @input: a #hb_subset_input_t object.
685*2d1272b8SAndroid Build Coastguard Worker * @name_id: name_id of a nameRecord
686*2d1272b8SAndroid Build Coastguard Worker * @platform_id: platform ID of a nameRecord
687*2d1272b8SAndroid Build Coastguard Worker * @encoding_id: encoding ID of a nameRecord
688*2d1272b8SAndroid Build Coastguard Worker * @language_id: language ID of a nameRecord
689*2d1272b8SAndroid Build Coastguard Worker * @name_str: pointer to name string new value or null to indicate should remove
690*2d1272b8SAndroid Build Coastguard Worker * @str_len: the size of @name_str, or -1 if it is `NULL`-terminated
691*2d1272b8SAndroid Build Coastguard Worker *
692*2d1272b8SAndroid Build Coastguard Worker * Override the name string of the NameRecord identified by name_id,
693*2d1272b8SAndroid Build Coastguard Worker * platform_id, encoding_id and language_id. If a record with that name_id
694*2d1272b8SAndroid Build Coastguard Worker * doesn't exist, create it and insert to the name table.
695*2d1272b8SAndroid Build Coastguard Worker *
696*2d1272b8SAndroid Build Coastguard Worker * Note: for mac platform, we only support name_str with all ascii characters,
697*2d1272b8SAndroid Build Coastguard Worker * name_str with non-ascii characters will be ignored.
698*2d1272b8SAndroid Build Coastguard Worker *
699*2d1272b8SAndroid Build Coastguard Worker * XSince: EXPERIMENTAL
700*2d1272b8SAndroid Build Coastguard Worker **/
701*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_subset_input_override_name_table(hb_subset_input_t * input,hb_ot_name_id_t name_id,unsigned platform_id,unsigned encoding_id,unsigned language_id,const char * name_str,int str_len)702*2d1272b8SAndroid Build Coastguard Worker hb_subset_input_override_name_table (hb_subset_input_t *input,
703*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_id_t name_id,
704*2d1272b8SAndroid Build Coastguard Worker unsigned platform_id,
705*2d1272b8SAndroid Build Coastguard Worker unsigned encoding_id,
706*2d1272b8SAndroid Build Coastguard Worker unsigned language_id,
707*2d1272b8SAndroid Build Coastguard Worker const char *name_str,
708*2d1272b8SAndroid Build Coastguard Worker int str_len /* -1 means nul-terminated */)
709*2d1272b8SAndroid Build Coastguard Worker {
710*2d1272b8SAndroid Build Coastguard Worker if (!name_str)
711*2d1272b8SAndroid Build Coastguard Worker {
712*2d1272b8SAndroid Build Coastguard Worker str_len = 0;
713*2d1272b8SAndroid Build Coastguard Worker }
714*2d1272b8SAndroid Build Coastguard Worker else if (str_len == -1)
715*2d1272b8SAndroid Build Coastguard Worker {
716*2d1272b8SAndroid Build Coastguard Worker str_len = strlen (name_str);
717*2d1272b8SAndroid Build Coastguard Worker }
718*2d1272b8SAndroid Build Coastguard Worker
719*2d1272b8SAndroid Build Coastguard Worker hb_bytes_t name_bytes (nullptr, 0);
720*2d1272b8SAndroid Build Coastguard Worker if (str_len)
721*2d1272b8SAndroid Build Coastguard Worker {
722*2d1272b8SAndroid Build Coastguard Worker if (platform_id == 1)
723*2d1272b8SAndroid Build Coastguard Worker {
724*2d1272b8SAndroid Build Coastguard Worker const uint8_t *src = reinterpret_cast<const uint8_t*> (name_str);
725*2d1272b8SAndroid Build Coastguard Worker const uint8_t *src_end = src + str_len;
726*2d1272b8SAndroid Build Coastguard Worker
727*2d1272b8SAndroid Build Coastguard Worker hb_codepoint_t unicode;
728*2d1272b8SAndroid Build Coastguard Worker const hb_codepoint_t replacement = HB_BUFFER_REPLACEMENT_CODEPOINT_DEFAULT;
729*2d1272b8SAndroid Build Coastguard Worker while (src < src_end)
730*2d1272b8SAndroid Build Coastguard Worker {
731*2d1272b8SAndroid Build Coastguard Worker src = hb_utf8_t::next (src, src_end, &unicode, replacement);
732*2d1272b8SAndroid Build Coastguard Worker if (unicode >= 0x0080u)
733*2d1272b8SAndroid Build Coastguard Worker {
734*2d1272b8SAndroid Build Coastguard Worker printf ("Non-ascii character detected, ignored...This API supports ascii characters only for mac platform\n");
735*2d1272b8SAndroid Build Coastguard Worker return false;
736*2d1272b8SAndroid Build Coastguard Worker }
737*2d1272b8SAndroid Build Coastguard Worker }
738*2d1272b8SAndroid Build Coastguard Worker }
739*2d1272b8SAndroid Build Coastguard Worker char *override_name = (char *) hb_malloc (str_len);
740*2d1272b8SAndroid Build Coastguard Worker if (unlikely (!override_name)) return false;
741*2d1272b8SAndroid Build Coastguard Worker
742*2d1272b8SAndroid Build Coastguard Worker hb_memcpy (override_name, name_str, str_len);
743*2d1272b8SAndroid Build Coastguard Worker name_bytes = hb_bytes_t (override_name, str_len);
744*2d1272b8SAndroid Build Coastguard Worker }
745*2d1272b8SAndroid Build Coastguard Worker input->name_table_overrides.set (hb_ot_name_record_ids_t (platform_id, encoding_id, language_id, name_id), name_bytes);
746*2d1272b8SAndroid Build Coastguard Worker return true;
747*2d1272b8SAndroid Build Coastguard Worker }
748*2d1272b8SAndroid Build Coastguard Worker #endif
749