[subset] shrink the serialize buffer when pruning empty offsets in ChainContextFormat2.

Currently the code reduces the array length, but does not trim back the space allocated in the serializer for those empty offsets.
This commit is contained in:
Garret Rieger 2020-09-25 13:08:46 -07:00
parent 90eb1a40eb
commit dc375559fd
1 changed files with 9 additions and 7 deletions

View File

@ -2794,9 +2794,10 @@ struct ChainContextFormat2
if (unlikely (!c->serializer->check_success (!lookahead_klass_map.in_error ()))) if (unlikely (!c->serializer->check_success (!lookahead_klass_map.in_error ())))
return_trace (false); return_trace (false);
unsigned non_zero_index = 0, index = 0; int non_zero_index = -1, index = 0;
bool ret = true; bool ret = true;
const hb_map_t *lookup_map = c->table_tag == HB_OT_TAG_GSUB ? c->plan->gsub_lookups : c->plan->gpos_lookups; const hb_map_t *lookup_map = c->table_tag == HB_OT_TAG_GSUB ? c->plan->gsub_lookups : c->plan->gpos_lookups;
auto last_non_zero = c->serializer->snapshot ();
for (const OffsetTo<ChainRuleSet>& _ : + hb_enumerate (ruleSet) for (const OffsetTo<ChainRuleSet>& _ : + hb_enumerate (ruleSet)
| hb_filter (input_klass_map, hb_first) | hb_filter (input_klass_map, hb_first)
| hb_map (hb_second)) | hb_map (hb_second))
@ -2812,7 +2813,10 @@ struct ChainContextFormat2
&backtrack_klass_map, &backtrack_klass_map,
&input_klass_map, &input_klass_map,
&lookahead_klass_map)) &lookahead_klass_map))
{
last_non_zero = c->serializer->snapshot ();
non_zero_index = index; non_zero_index = index;
}
index++; index++;
} }
@ -2820,11 +2824,9 @@ struct ChainContextFormat2
if (!ret) return_trace (ret); if (!ret) return_trace (ret);
// prune empty trailing ruleSets // prune empty trailing ruleSets
--index; if (index > non_zero_index) {
while (index > non_zero_index) c->serializer->revert (last_non_zero);
{ out->ruleSet.len = non_zero_index + 1;
out->ruleSet.pop ();
index--;
} }
return_trace (bool (out->ruleSet)); return_trace (bool (out->ruleSet));