harfbuzz/test/api/test-var-coords.c
Ebrahim Byagowi ab2d3ec542 [var] Implement hb_font_get_var_coords_design
Hold design coords and simulate when normalized coords are set directly.
2020-02-08 11:04:34 +03:30

77 lines
2.6 KiB
C

/*
* 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_ */
#ifndef G_APPROX_VALUE
#define G_APPROX_VALUE(a, b, epsilon) \
(((a) > (b) ? (a) - (b) : (b) - (a)) < (epsilon))
#endif
#define EPSILON 0.05f
static void
test_get_var_coords (void)
{
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);
}
int
main (int argc, char **argv)
{
hb_test_init (&argc, &argv);
hb_test_add (test_get_var_coords);
return hb_test_run ();
}