[subset-perf] Cache a glyph map for gsub.

This allows us in some cases to avoid using glyph_set_gsub as a filter.
This commit is contained in:
Garret Rieger 2022-05-18 21:42:28 +00:00 committed by Behdad Esfahbod
parent 202e6c4699
commit adae2f2272
3 changed files with 25 additions and 5 deletions

View File

@ -1717,14 +1717,12 @@ struct Coverage
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
const hb_set_t &glyphset = *c->plan->glyphset_gsub ();
const hb_map_t &glyph_map = *c->plan->glyph_map;
auto it = auto it =
+ iter () + iter ()
| hb_filter (glyphset) | hb_filter (c->plan->glyph_map_gsub)
| hb_map_retains_sorting (glyph_map) | hb_map_retains_sorting (c->plan->glyph_map_gsub)
; ;
// Cache the iterator result as it will be iterated multiple times // Cache the iterator result as it will be iterated multiple times
// by the serialize code below. // by the serialize code below.
hb_sorted_vector_t<hb_codepoint_t> glyphs (it); hb_sorted_vector_t<hb_codepoint_t> glyphs (it);

View File

@ -420,6 +420,20 @@ _populate_gids_to_retain (hb_subset_plan_t* plan,
#endif #endif
} }
static void
_create_glyph_map_gsub (const hb_set_t* glyph_set_gsub,
const hb_map_t* glyph_map,
hb_map_t* out)
{
+ hb_iter (glyph_set_gsub)
| hb_map ([&] (hb_codepoint_t gid) {
return hb_pair_t<hb_codepoint_t, hb_codepoint_t> (gid,
glyph_map->get (gid));
})
| hb_sink (out)
;
}
static void static void
_create_old_gid_to_new_gid_map (const hb_face_t *face, _create_old_gid_to_new_gid_map (const hb_face_t *face,
bool retain_gids, bool retain_gids,
@ -518,6 +532,7 @@ hb_subset_plan_create_or_fail (hb_face_t *face,
plan->codepoint_to_glyph = hb_map_create (); plan->codepoint_to_glyph = hb_map_create ();
plan->glyph_map = hb_map_create (); plan->glyph_map = hb_map_create ();
plan->reverse_glyph_map = hb_map_create (); plan->reverse_glyph_map = hb_map_create ();
plan->glyph_map_gsub = hb_map_create ();
plan->gsub_lookups = hb_map_create (); plan->gsub_lookups = hb_map_create ();
plan->gpos_lookups = hb_map_create (); plan->gpos_lookups = hb_map_create ();
@ -552,6 +567,11 @@ hb_subset_plan_create_or_fail (hb_face_t *face,
plan->reverse_glyph_map, plan->reverse_glyph_map,
&plan->_num_output_glyphs); &plan->_num_output_glyphs);
_create_glyph_map_gsub (
plan->_glyphset_gsub,
plan->glyph_map,
plan->glyph_map_gsub);
// Now that we have old to new gid map update the unicode to new gid list. // Now that we have old to new gid map update the unicode to new gid list.
for (unsigned i = 0; i < plan->unicode_to_new_gid_list.length; i++) for (unsigned i = 0; i < plan->unicode_to_new_gid_list.length; i++)
{ {
@ -594,6 +614,7 @@ hb_subset_plan_destroy (hb_subset_plan_t *plan)
hb_map_destroy (plan->codepoint_to_glyph); hb_map_destroy (plan->codepoint_to_glyph);
hb_map_destroy (plan->glyph_map); hb_map_destroy (plan->glyph_map);
hb_map_destroy (plan->reverse_glyph_map); hb_map_destroy (plan->reverse_glyph_map);
hb_map_destroy (plan->glyph_map_gsub);
hb_set_destroy (plan->_glyphset); hb_set_destroy (plan->_glyphset);
hb_set_destroy (plan->_glyphset_gsub); hb_set_destroy (plan->_glyphset_gsub);
hb_set_destroy (plan->_glyphset_mathed); hb_set_destroy (plan->_glyphset_mathed);

View File

@ -70,6 +70,7 @@ struct hb_subset_plan_t
// Old -> New glyph id mapping // Old -> New glyph id mapping
hb_map_t *glyph_map; hb_map_t *glyph_map;
hb_map_t *reverse_glyph_map; hb_map_t *reverse_glyph_map;
hb_map_t *glyph_map_gsub;
// Plan is only good for a specific source/dest so keep them with it // Plan is only good for a specific source/dest so keep them with it
hb_face_t *source; hb_face_t *source;