test-subset-vmtx.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /*
  2. * Copyright © 2018 Google, Inc.
  3. *
  4. * This is part of HarfBuzz, a text shaping library.
  5. *
  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. * Google Author(s): Garret Rieger
  25. */
  26. #include "hb-test.h"
  27. #include "hb-subset-test.h"
  28. /* Unit tests for hmtx subsetting */
  29. static void check_num_vmetrics(hb_face_t *face, uint16_t expected_num_vmetrics)
  30. {
  31. hb_blob_t *vhea_blob = hb_face_reference_table (face, HB_TAG ('v','h','e','a'));
  32. hb_blob_t *vmtx_blob = hb_face_reference_table (face, HB_TAG ('v','m','t','x'));
  33. unsigned int vhea_len;
  34. uint8_t *raw_vhea = (uint8_t *) hb_blob_get_data(vhea_blob, &vhea_len);
  35. uint16_t num_vmetrics = (raw_vhea[vhea_len - 2] << 8) + raw_vhea[vhea_len - 1];
  36. g_assert_cmpuint(expected_num_vmetrics, ==, num_vmetrics);
  37. hb_blob_destroy (vhea_blob);
  38. hb_blob_destroy (vmtx_blob);
  39. }
  40. static void
  41. test_subset_vmtx_simple_subset (void)
  42. {
  43. hb_face_t *face_full = hb_test_open_font_file ("fonts/Mplus1p-Regular.660E,6975,73E0,5EA6,8F38,6E05.ttf");
  44. hb_face_t *face_subset = hb_test_open_font_file ("fonts/Mplus1p-Regular.660E.ttf");
  45. hb_face_t *face_full_subset;
  46. hb_set_t *codepoints = hb_set_create ();
  47. hb_set_add (codepoints, 0x660E);
  48. face_full_subset = hb_subset_test_create_subset (face_full, hb_subset_test_create_input (codepoints));
  49. hb_set_destroy (codepoints);
  50. check_num_vmetrics(face_full_subset, 1); /* nothing has same width */
  51. hb_subset_test_check (face_subset, face_full_subset, HB_TAG ('v','m','t','x'));
  52. hb_face_destroy (face_full_subset);
  53. hb_face_destroy (face_full);
  54. hb_face_destroy (face_subset);
  55. }
  56. static void
  57. test_subset_vmtx_noop (void)
  58. {
  59. hb_face_t *face_full = hb_test_open_font_file ("fonts/Mplus1p-Regular.660E,6975,73E0,5EA6,8F38,6E05.ttf");
  60. hb_face_t *face_full_subset;
  61. hb_set_t *codepoints = hb_set_create();
  62. hb_set_add (codepoints, 0x660E);
  63. hb_set_add (codepoints, 0x6975);
  64. hb_set_add (codepoints, 0x73E0);
  65. hb_set_add (codepoints, 0x5EA6);
  66. hb_set_add (codepoints, 0x8F38);
  67. hb_set_add (codepoints, 0x6E05);
  68. face_full_subset = hb_subset_test_create_subset (face_full, hb_subset_test_create_input (codepoints));
  69. hb_set_destroy (codepoints);
  70. check_num_vmetrics(face_full_subset, 1); /* all have the same width */
  71. hb_subset_test_check (face_full, face_full_subset, HB_TAG ('v','m','t','x'));
  72. hb_face_destroy (face_full_subset);
  73. hb_face_destroy (face_full);
  74. }
  75. int
  76. main (int argc, char **argv)
  77. {
  78. hb_test_init (&argc, &argv);
  79. hb_test_add (test_subset_vmtx_simple_subset);
  80. hb_test_add (test_subset_vmtx_noop);
  81. return hb_test_run();
  82. }