| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- /*
- * Copyright © 2019 Ebrahim Byagowi
- *
- * This is part of HarfBuzz, a text shaping library.
- *
- * Permission is hereby granted, without written agreement and without
- * license or royalty fees, to use, copy, modify, and distribute this
- * software and its documentation for any purpose, provided that the
- * above copyright notice and the following two paragraphs appear in
- * all copies of this software.
- *
- * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
- * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
- * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
- * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
- * DAMAGE.
- *
- * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
- * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
- * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
- * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
- * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
- */
- #include "hb-test.h"
- #include <hb-ot.h>
- /* Unit tests for hb_font_[gs]et_var_coords_ */
- static void
- test_get_var_coords (void)
- {
- #ifndef G_APPROX_VALUE
- #define G_APPROX_VALUE(a, b, epsilon) \
- (((a) > (b) ? (a) - (b) : (b) - (a)) < (epsilon))
- #endif
- #define EPSILON 0.05f
-
- hb_face_t *face = hb_test_open_font_file ("fonts/TestCFF2VF.otf");
- hb_font_t *font = hb_font_create (face);
- /* Normalized coords as input */
- int normalized_coords[] = {100, 0};
- hb_font_set_var_coords_normalized (font, normalized_coords, 2);
- g_assert_cmpint ((int) hb_font_get_var_coords_design (font, NULL)[0], ==, 403);
- g_assert_cmpint ((int) hb_font_get_var_coords_normalized (font, NULL)[0], ==, 100);
- /* Design coords as input */
- float design_coords[] = {206.f, 0};
- hb_font_set_var_coords_design (font, design_coords, 2);
- g_assert_cmpint ((int) hb_font_get_var_coords_normalized (font, NULL)[0], ==, -16117);
- g_assert_cmpint ((int) hb_font_get_var_coords_design (font, NULL)[0], ==, 206);
- for (float weight = 200; weight < 901; ++weight)
- {
- int normalized;
- hb_ot_var_normalize_coords (face, 1, &weight, &normalized);
- hb_font_set_var_coords_normalized (font, &normalized, 1);
- float converted_back = hb_font_get_var_coords_design (font, NULL)[0];
- // fprintf (stderr, "%f: %d => %f\n", weight, normalized, converted_back);
- g_assert_true (G_APPROX_VALUE (converted_back, weight, EPSILON));
- }
- hb_font_destroy (font);
- hb_face_destroy (face);
- }
- static void
- test_get_var_get_axis_infos (void)
- {
- hb_face_t *face = hb_test_open_font_file ("fonts/Estedad-VF.ttf");
- g_assert_cmpint (hb_ot_var_get_axis_count (face), ==, 2);
- hb_ot_var_axis_info_t info;
- unsigned c = 1;
- g_assert_cmpint (hb_ot_var_get_axis_infos (face, 0, &c, &info), ==, 2);
- g_assert (info.tag == HB_TAG ('w','g','h','t'));
- g_assert_cmpint (c, ==, 1);
- hb_ot_var_get_axis_infos (face, 1, &c, &info);
- g_assert (info.tag == HB_TAG ('w','d','t','h'));
- g_assert_cmpint (c, ==, 1);
- hb_ot_var_get_axis_infos (face, 2, &c, &info);
- g_assert_cmpint (c, ==, 0);
- hb_face_destroy (face);
- }
- int
- main (int argc, char **argv)
- {
- hb_test_init (&argc, &argv);
- hb_test_add (test_get_var_coords);
- hb_test_add (test_get_var_get_axis_infos);
- return hb_test_run ();
- }
|