xref: /aosp_15_r20/external/harfbuzz_ng/src/test-tuple-varstore.cc (revision 2d1272b857b1f7575e6e246373e1cb218663db8a)
1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker  * Copyright © 2020  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  */
25*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-var-cvar-table.hh"
26*2d1272b8SAndroid Build Coastguard Worker 
27*2d1272b8SAndroid Build Coastguard Worker // cvar table data from Multi-ABC.ttf
28*2d1272b8SAndroid Build Coastguard Worker const unsigned char cvar_data[] = "\x0\x1\x0\x0\x0\x2\x0\x14\x0\x51\xa0\x0\xc0\x0\x0\x54\xa0\x0\x40\x0\x2a\x29\x17\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\xd\xff\x0\xfd\x1\x0\xff\x0\xfd\x1\x0\xdb\xdb\xe6\xe6\x82\x0\xfd\x84\x6\xfd\x0\x2\xe3\xe3\xec\xec\x82\x4\x1\xe3\xe3\xec\xec\x82\x0\x1\x2a\x29\x17\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\x1\xd\x1\x0\x5\xfd\x0\x1\x0\x5\xfd\x0\x61\x61\x44\x44\x82\x0\x5\x81\x9\x1\xff\x1\x7\xff\xfb\x49\x49\x35\x35\x82\x4\xff\x49\x49\x35\x35\x82\x0\xff";
29*2d1272b8SAndroid Build Coastguard Worker 
30*2d1272b8SAndroid Build Coastguard Worker static void
test_decompile_cvar()31*2d1272b8SAndroid Build Coastguard Worker test_decompile_cvar ()
32*2d1272b8SAndroid Build Coastguard Worker {
33*2d1272b8SAndroid Build Coastguard Worker   const OT::cvar* cvar_table = reinterpret_cast<const OT::cvar*> (cvar_data);
34*2d1272b8SAndroid Build Coastguard Worker   unsigned point_count = 65;
35*2d1272b8SAndroid Build Coastguard Worker   unsigned axis_count = 1;
36*2d1272b8SAndroid Build Coastguard Worker 
37*2d1272b8SAndroid Build Coastguard Worker   hb_tag_t axis_tag = HB_TAG ('w', 'g', 'h', 't');
38*2d1272b8SAndroid Build Coastguard Worker   hb_map_t axis_idx_tag_map;
39*2d1272b8SAndroid Build Coastguard Worker   axis_idx_tag_map.set (0, axis_tag);
40*2d1272b8SAndroid Build Coastguard Worker 
41*2d1272b8SAndroid Build Coastguard Worker   OT::TupleVariationData::tuple_variations_t tuple_variations;
42*2d1272b8SAndroid Build Coastguard Worker   hb_vector_t<unsigned> shared_indices;
43*2d1272b8SAndroid Build Coastguard Worker   OT::TupleVariationData::tuple_iterator_t iterator;
44*2d1272b8SAndroid Build Coastguard Worker 
45*2d1272b8SAndroid Build Coastguard Worker   const OT::TupleVariationData* tuple_var_data = reinterpret_cast<const OT::TupleVariationData*> (cvar_data + 4);
46*2d1272b8SAndroid Build Coastguard Worker 
47*2d1272b8SAndroid Build Coastguard Worker   unsigned len = sizeof (cvar_data);
48*2d1272b8SAndroid Build Coastguard Worker   hb_bytes_t var_data_bytes{(const char* ) cvar_data + 4, len - 4};
49*2d1272b8SAndroid Build Coastguard Worker   bool result = OT::TupleVariationData::get_tuple_iterator (var_data_bytes, axis_count, cvar_table,
50*2d1272b8SAndroid Build Coastguard Worker                                                             shared_indices, &iterator);
51*2d1272b8SAndroid Build Coastguard Worker   assert (result);
52*2d1272b8SAndroid Build Coastguard Worker 
53*2d1272b8SAndroid Build Coastguard Worker   result = tuple_var_data->decompile_tuple_variations (point_count, false, iterator, &axis_idx_tag_map,
54*2d1272b8SAndroid Build Coastguard Worker                                                        shared_indices, hb_array<const OT::F2DOT14> (),
55*2d1272b8SAndroid Build Coastguard Worker                                                        tuple_variations);
56*2d1272b8SAndroid Build Coastguard Worker 
57*2d1272b8SAndroid Build Coastguard Worker   assert (result);
58*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars.length == 2);
59*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 2; i++)
60*2d1272b8SAndroid Build Coastguard Worker   {
61*2d1272b8SAndroid Build Coastguard Worker     assert (tuple_variations.tuple_vars[i].axis_tuples.get_population () == 1);
62*2d1272b8SAndroid Build Coastguard Worker     assert (!tuple_variations.tuple_vars[i].deltas_y);
63*2d1272b8SAndroid Build Coastguard Worker     assert (tuple_variations.tuple_vars[i].indices.length == 65);
64*2d1272b8SAndroid Build Coastguard Worker     assert (tuple_variations.tuple_vars[i].indices.length == tuple_variations.tuple_vars[i].deltas_x.length);
65*2d1272b8SAndroid Build Coastguard Worker   }
66*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[0].axis_tuples.get (axis_tag) == Triple (-1.0, -1.0, 0.0));
67*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[1].axis_tuples.get (axis_tag) == Triple (0.0, 1.0, 1.0));
68*2d1272b8SAndroid Build Coastguard Worker 
69*2d1272b8SAndroid Build Coastguard Worker   hb_vector_t<double> deltas_1 {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, -3.0, 1.0, 0.0, -1.0, 0.0, -3.0, 1.0, 0.0, -37.0, -37.0, -26.0, -26.0, 0.0, 0.0, 0.0, -3.0, 0.0, 0.0, 0.0, 0.0, 0.0, -3.0, 0.0, 2.0, -29.0, -29.0, -20.0, -20.0, 0.0, 0.0, 0.0, 1.0, -29.0, -29.0, -20.0, -20.0, 0.0, 0.0, 0.0, 1.0};
70*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 65; i++)
71*2d1272b8SAndroid Build Coastguard Worker   {
72*2d1272b8SAndroid Build Coastguard Worker     if (i < 23)
73*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[0].indices[i] == 0);
74*2d1272b8SAndroid Build Coastguard Worker     else
75*2d1272b8SAndroid Build Coastguard Worker     {
76*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[0].indices[i] == 1);
77*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[0].deltas_x[i] == deltas_1[i]);
78*2d1272b8SAndroid Build Coastguard Worker     }
79*2d1272b8SAndroid Build Coastguard Worker   }
80*2d1272b8SAndroid Build Coastguard Worker 
81*2d1272b8SAndroid Build Coastguard Worker   hb_vector_t<double> deltas_2 {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 5.0, -3.0, 0.0, 1.0, 0.0, 5.0, -3.0, 0.0, 97.0, 97.0, 68.0, 68.0, 0.0, 0.0, 0.0, 5.0, 0.0, 0.0, 1.0, -1.0, 1.0, 7.0, -1.0, -5.0, 73.0, 73.0, 53.0, 53.0, 0.0, 0.0, 0.0, -1.0, 73.0, 73.0, 53.0, 53.0, 0.0, 0.0, 0.0, -1.0};
82*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0 ; i < 65; i++)
83*2d1272b8SAndroid Build Coastguard Worker   {
84*2d1272b8SAndroid Build Coastguard Worker     if (i < 23)
85*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[1].indices[i] == 0);
86*2d1272b8SAndroid Build Coastguard Worker     else
87*2d1272b8SAndroid Build Coastguard Worker     {
88*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[1].indices[i] == 1);
89*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[1].deltas_x[i] == deltas_2[i]);
90*2d1272b8SAndroid Build Coastguard Worker     }
91*2d1272b8SAndroid Build Coastguard Worker   }
92*2d1272b8SAndroid Build Coastguard Worker 
93*2d1272b8SAndroid Build Coastguard Worker   /* partial instancing wght=300:800 */
94*2d1272b8SAndroid Build Coastguard Worker   hb_hashmap_t<hb_tag_t, Triple> normalized_axes_location;
95*2d1272b8SAndroid Build Coastguard Worker   normalized_axes_location.set (axis_tag, Triple (-0.512817, 0.0, 0.700012));
96*2d1272b8SAndroid Build Coastguard Worker 
97*2d1272b8SAndroid Build Coastguard Worker   hb_hashmap_t<hb_tag_t, TripleDistances> axes_triple_distances;
98*2d1272b8SAndroid Build Coastguard Worker   axes_triple_distances.set (axis_tag, TripleDistances (1.0, 1.0));
99*2d1272b8SAndroid Build Coastguard Worker 
100*2d1272b8SAndroid Build Coastguard Worker   tuple_variations.instantiate (normalized_axes_location, axes_triple_distances);
101*2d1272b8SAndroid Build Coastguard Worker 
102*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[0].indices.length == 65);
103*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[1].indices.length == 65);
104*2d1272b8SAndroid Build Coastguard Worker   assert (!tuple_variations.tuple_vars[0].deltas_y);
105*2d1272b8SAndroid Build Coastguard Worker   assert (!tuple_variations.tuple_vars[1].deltas_y);
106*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[0].axis_tuples.get (axis_tag) == Triple (-1.0, -1.0, 0.0));
107*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[1].axis_tuples.get (axis_tag) == Triple (0.0, 1.0, 1.0));
108*2d1272b8SAndroid Build Coastguard Worker 
109*2d1272b8SAndroid Build Coastguard Worker   hb_vector_t<double> rounded_deltas_1 {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1, 0.0, -2, 1, 0.0, -1, 0.0, -2, 1, 0.0, -19, -19, -13, -13, 0.0, 0.0, 0.0, -2, 0.0, 0.0, 0.0, 0.0, 0.0, -2, 0.0, 1, -15, -15, -10.0, -10.0, 0.0, 0.0, 0.0, 1, -15, -15, -10.0, -10.0, 0.0, 0.0, 0.0, 1};
110*2d1272b8SAndroid Build Coastguard Worker 
111*2d1272b8SAndroid Build Coastguard Worker   hb_vector_t<double> rounded_deltas_2 {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1, 0.0, 4, -2, 0.0, 1, 0.0, 4, -2, 0.0, 68, 68, 48, 48, 0.0, 0.0, 0.0, 4, 0.0, 0.0, 1, -1, 1, 5, -1, -4, 51, 51, 37, 37, 0.0, 0.0, 0.0, -1, 51, 51, 37, 37, 0.0, 0.0, 0.0, -1};
112*2d1272b8SAndroid Build Coastguard Worker 
113*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 65; i++)
114*2d1272b8SAndroid Build Coastguard Worker   {
115*2d1272b8SAndroid Build Coastguard Worker     if (i < 23)
116*2d1272b8SAndroid Build Coastguard Worker     {
117*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[0].indices[i] == 0);
118*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[1].indices[i] == 0);
119*2d1272b8SAndroid Build Coastguard Worker     }
120*2d1272b8SAndroid Build Coastguard Worker     else
121*2d1272b8SAndroid Build Coastguard Worker     {
122*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[0].indices[i] == 1);
123*2d1272b8SAndroid Build Coastguard Worker       assert (tuple_variations.tuple_vars[1].indices[i] == 1);
124*2d1272b8SAndroid Build Coastguard Worker       assert (roundf (tuple_variations.tuple_vars[0].deltas_x[i]) == rounded_deltas_1[i]);
125*2d1272b8SAndroid Build Coastguard Worker       assert (roundf (tuple_variations.tuple_vars[1].deltas_x[i]) == rounded_deltas_2[i]);
126*2d1272b8SAndroid Build Coastguard Worker     }
127*2d1272b8SAndroid Build Coastguard Worker   }
128*2d1272b8SAndroid Build Coastguard Worker 
129*2d1272b8SAndroid Build Coastguard Worker   hb_map_t axes_index_map;
130*2d1272b8SAndroid Build Coastguard Worker   axes_index_map.set (0, 0);
131*2d1272b8SAndroid Build Coastguard Worker   bool res = tuple_variations.compile_bytes (axes_index_map, axis_idx_tag_map, false);
132*2d1272b8SAndroid Build Coastguard Worker   assert (res);
133*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[0].compiled_tuple_header.length == 6);
134*2d1272b8SAndroid Build Coastguard Worker   const unsigned char tuple_var_header_1[] = "\x0\x51\xa0\x0\xc0\x0";
135*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 6; i++)
136*2d1272b8SAndroid Build Coastguard Worker     assert(tuple_variations.tuple_vars[0].compiled_tuple_header.arrayZ[i] == tuple_var_header_1[i]);
137*2d1272b8SAndroid Build Coastguard Worker 
138*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[1].compiled_tuple_header.length == 6);
139*2d1272b8SAndroid Build Coastguard Worker   const unsigned char tuple_var_header_2[] = "\x0\x54\xa0\x0\x40\x0";
140*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 6; i++)
141*2d1272b8SAndroid Build Coastguard Worker     assert(tuple_variations.tuple_vars[1].compiled_tuple_header.arrayZ[i] == tuple_var_header_2[i]);
142*2d1272b8SAndroid Build Coastguard Worker 
143*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[0].compiled_deltas.length == 37);
144*2d1272b8SAndroid Build Coastguard Worker   assert (tuple_variations.tuple_vars[1].compiled_deltas.length == 40);
145*2d1272b8SAndroid Build Coastguard Worker   const unsigned char compiled_deltas_1[] = "\x0d\xff\x00\xfe\x01\x00\xff\x00\xfe\x01\x00\xed\xed\xf3\xf3\x82\x00\xfe\x84\x06\xfe\x00\x01\xf1\xf1\xf6\xf6\x82\x04\x01\xf1\xf1\xf6\xf6\x82\x00\x01";
146*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 37; i++)
147*2d1272b8SAndroid Build Coastguard Worker     assert (tuple_variations.tuple_vars[0].compiled_deltas.arrayZ[i] == compiled_deltas_1[i]);
148*2d1272b8SAndroid Build Coastguard Worker 
149*2d1272b8SAndroid Build Coastguard Worker   const unsigned char compiled_deltas_2[] = "\x0d\x01\x00\x04\xfe\x00\x01\x00\x04\xfe\x00\x44\x44\x30\x30\x82\x00\x04\x81\x09\x01\xff\x01\x05\xff\xfc\x33\x33\x25\x25\x82\x04\xff\x33\x33\x25\x25\x82\x00\xff";
150*2d1272b8SAndroid Build Coastguard Worker   for (unsigned i = 0; i < 40; i++)
151*2d1272b8SAndroid Build Coastguard Worker     assert (tuple_variations.tuple_vars[1].compiled_deltas.arrayZ[i] == compiled_deltas_2[i]);
152*2d1272b8SAndroid Build Coastguard Worker }
153*2d1272b8SAndroid Build Coastguard Worker 
154*2d1272b8SAndroid Build Coastguard Worker int
main(int argc,char ** argv)155*2d1272b8SAndroid Build Coastguard Worker main (int argc, char **argv)
156*2d1272b8SAndroid Build Coastguard Worker {
157*2d1272b8SAndroid Build Coastguard Worker   test_decompile_cvar ();
158*2d1272b8SAndroid Build Coastguard Worker }
159