[subset] Add drop tables to subset input.

This commit is contained in:
Garret Rieger 2019-05-16 11:29:15 -07:00
parent 0ca7ad4352
commit 3be0ffe45d
8 changed files with 95 additions and 1 deletions

View File

@ -45,6 +45,7 @@ hb_subset_input_create_or_fail ()
input->unicodes = hb_set_create (); input->unicodes = hb_set_create ();
input->glyphs = hb_set_create (); input->glyphs = hb_set_create ();
input->name_ids = hb_set_create (); input->name_ids = hb_set_create ();
input->drop_tables = hb_set_create ();
input->drop_hints = false; input->drop_hints = false;
input->drop_layout = true; input->drop_layout = true;
input->desubroutinize = false; input->desubroutinize = false;
@ -83,6 +84,7 @@ hb_subset_input_destroy (hb_subset_input_t *subset_input)
hb_set_destroy (subset_input->unicodes); hb_set_destroy (subset_input->unicodes);
hb_set_destroy (subset_input->glyphs); hb_set_destroy (subset_input->glyphs);
hb_set_destroy (subset_input->name_ids); hb_set_destroy (subset_input->name_ids);
hb_set_destroy (subset_input->drop_tables);
free (subset_input); free (subset_input);
} }
@ -117,6 +119,12 @@ hb_subset_input_nameid_set (hb_subset_input_t *subset_input)
return subset_input->name_ids; return subset_input->name_ids;
} }
HB_EXTERN hb_set_t *
hb_subset_input_drop_tables_set (hb_subset_input_t *subset_input)
{
return subset_input->drop_tables;
}
HB_EXTERN void HB_EXTERN void
hb_subset_input_set_drop_hints (hb_subset_input_t *subset_input, hb_subset_input_set_drop_hints (hb_subset_input_t *subset_input,
hb_bool_t drop_hints) hb_bool_t drop_hints)

View File

@ -41,6 +41,7 @@ struct hb_subset_input_t
hb_set_t *unicodes; hb_set_t *unicodes;
hb_set_t *glyphs; hb_set_t *glyphs;
hb_set_t *name_ids; hb_set_t *name_ids;
hb_set_t *drop_tables;
bool drop_hints : 1; bool drop_hints : 1;
bool drop_layout : 1; bool drop_layout : 1;

View File

@ -241,6 +241,8 @@ hb_subset_plan_create (hb_face_t *face,
plan->retain_gids = input->retain_gids; plan->retain_gids = input->retain_gids;
plan->unicodes = hb_set_create (); plan->unicodes = hb_set_create ();
plan->name_ids = hb_set_reference (input->name_ids); plan->name_ids = hb_set_reference (input->name_ids);
plan->drop_tables = hb_set_reference (input->drop_tables);
/* TODO Clean this up... */ /* TODO Clean this up... */
if (hb_set_is_empty (plan->name_ids)) if (hb_set_is_empty (plan->name_ids))
hb_set_add_range (plan->name_ids, 0, 0x7FFF); hb_set_add_range (plan->name_ids, 0, 0x7FFF);
@ -279,6 +281,7 @@ hb_subset_plan_destroy (hb_subset_plan_t *plan)
hb_set_destroy (plan->unicodes); hb_set_destroy (plan->unicodes);
hb_set_destroy (plan->name_ids); hb_set_destroy (plan->name_ids);
hb_set_destroy (plan->drop_tables);
hb_face_destroy (plan->source); hb_face_destroy (plan->source);
hb_face_destroy (plan->dest); hb_face_destroy (plan->dest);
hb_map_destroy (plan->codepoint_to_glyph); hb_map_destroy (plan->codepoint_to_glyph);

View File

@ -50,6 +50,9 @@ struct hb_subset_plan_t
// name_ids we would like to retain // name_ids we would like to retain
hb_set_t *name_ids; hb_set_t *name_ids;
// Tables which should be dropped.
hb_set_t *drop_tables;
// The glyph subset // The glyph subset
hb_map_t *codepoint_to_glyph; hb_map_t *codepoint_to_glyph;

View File

@ -237,6 +237,9 @@ _subset_table (hb_subset_plan_t *plan,
static bool static bool
_should_drop_table (hb_subset_plan_t *plan, hb_tag_t tag) _should_drop_table (hb_subset_plan_t *plan, hb_tag_t tag)
{ {
if (plan->drop_tables->has (tag))
return true;
switch (tag) { switch (tag) {
case HB_TAG ('c', 'v', 'a', 'r'): /* hint table, fallthrough */ case HB_TAG ('c', 'v', 'a', 'r'): /* hint table, fallthrough */
case HB_TAG ('c', 'v', 't', ' '): /* hint table, fallthrough */ case HB_TAG ('c', 'v', 't', ' '): /* hint table, fallthrough */

View File

@ -57,6 +57,9 @@ hb_subset_input_glyph_set (hb_subset_input_t *subset_input);
HB_EXTERN hb_set_t * HB_EXTERN hb_set_t *
hb_subset_input_nameid_set (hb_subset_input_t *subset_input); hb_subset_input_nameid_set (hb_subset_input_t *subset_input);
HB_EXTERN hb_set_t *
hb_subset_input_drop_tables_set (hb_subset_input_t *subset_input);
HB_EXTERN void HB_EXTERN void
hb_subset_input_set_drop_hints (hb_subset_input_t *subset_input, hb_subset_input_set_drop_hints (hb_subset_input_t *subset_input,
hb_bool_t drop_hints); hb_bool_t drop_hints);

View File

@ -42,6 +42,7 @@ TEST_PROGS = \
test-shape \ test-shape \
test-subset \ test-subset \
test-subset-cmap \ test-subset-cmap \
test-subset-drop-tables \
test-subset-glyf \ test-subset-glyf \
test-subset-hdmx \ test-subset-hdmx \
test-subset-hmtx \ test-subset-hmtx \
@ -57,6 +58,7 @@ TEST_PROGS = \
test_subset_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la test_subset_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la
test_subset_cmap_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la test_subset_cmap_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la
test_subset_drop_tables_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la
test_subset_glyf_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la test_subset_glyf_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la
test_subset_hdmx_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la test_subset_hdmx_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la
test_subset_hmtx_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la test_subset_hmtx_LDADD = $(LDADD) $(top_builddir)/src/libharfbuzz-subset.la

View File

@ -0,0 +1,71 @@
/*
* Copyright © 2019 Google, Inc.
*
* 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.
*
* Google Author(s): Garret Rieger
*/
#include "hb-test.h"
#include "hb-subset-test.h"
/* Unit tests for hb-subset.cc drop tables functionality */
static void
test_subset_drop_tables (void)
{
hb_face_t *face = hb_test_open_font_file ("fonts/Roboto-Regular.abc.ttf");
hb_set_t *codepoints = hb_set_create();
hb_set_add (codepoints, 97);
hb_set_add (codepoints, 99);
hb_subset_input_t *input = hb_subset_test_create_input (codepoints);
hb_set_add (hb_subset_input_drop_tables_set (input), HB_TAG ('h', 'd', 'm', 'x'));
hb_set_add (hb_subset_input_drop_tables_set (input), HB_TAG ('h', 'm', 't', 'x'));
hb_set_destroy (codepoints);
hb_face_t* subset = hb_subset (face, input);
hb_blob_t *hdmx = hb_face_reference_table (subset, HB_TAG ('h', 'd', 'm', 'x'));
hb_blob_t *hmtx = hb_face_reference_table (subset, HB_TAG ('h', 'm', 't', 'x'));
hb_blob_t *cmap = hb_face_reference_table (subset, HB_TAG ('c', 'm', 'a', 'p'));
g_assert (!hb_blob_get_length (hdmx));
g_assert (!hb_blob_get_length (hmtx));
g_assert ( hb_blob_get_length (cmap));
hb_blob_destroy (hdmx);
hb_blob_destroy (hmtx);
hb_blob_destroy (cmap);
hb_face_destroy (subset);
hb_subset_input_destroy (input);
hb_face_destroy (face);
}
int
main (int argc, char **argv)
{
hb_test_init (&argc, &argv);
hb_test_add (test_subset_drop_tables);
return hb_test_run();
}