[subset] During lookup collection remember the features we've already processed.

This commit is contained in:
Garret Rieger 2018-07-26 17:42:02 -07:00
parent 42c183f803
commit 5edf454aa6
3 changed files with 21 additions and 5 deletions

View File

@ -663,6 +663,7 @@ _hb_ot_layout_collect_lookups_features (hb_face_t *face,
unsigned int script_index, unsigned int script_index,
unsigned int language_index, unsigned int language_index,
const hb_tag_t *features, const hb_tag_t *features,
hb_set_t *visited_features,
hb_set_t *lookup_indexes /* OUT */) hb_set_t *lookup_indexes /* OUT */)
{ {
if (!features) if (!features)
@ -673,11 +674,15 @@ _hb_ot_layout_collect_lookups_features (hb_face_t *face,
script_index, script_index,
language_index, language_index,
&required_feature_index, &required_feature_index,
nullptr)) nullptr)
_hb_ot_layout_collect_lookups_lookups (face, && !visited_features->has (required_feature_index))
table_tag, {
required_feature_index, _hb_ot_layout_collect_lookups_lookups (face,
lookup_indexes); table_tag,
required_feature_index,
lookup_indexes);
visited_features->add (required_feature_index);
}
/* All features */ /* All features */
unsigned int feature_indices[32]; unsigned int feature_indices[32];
@ -694,10 +699,14 @@ _hb_ot_layout_collect_lookups_features (hb_face_t *face,
feature_indices); feature_indices);
for (unsigned int i = 0; i < len; i++) for (unsigned int i = 0; i < len; i++)
{
if (visited_features->has (feature_indices[i])) continue;
_hb_ot_layout_collect_lookups_lookups (face, _hb_ot_layout_collect_lookups_lookups (face,
table_tag, table_tag,
feature_indices[i], feature_indices[i],
lookup_indexes); lookup_indexes);
visited_features->add (feature_indices[i]);
}
offset += len; offset += len;
} while (len == ARRAY_LENGTH (feature_indices)); } while (len == ARRAY_LENGTH (feature_indices));
@ -727,6 +736,7 @@ _hb_ot_layout_collect_lookups_languages (hb_face_t *face,
unsigned int script_index, unsigned int script_index,
const hb_tag_t *languages, const hb_tag_t *languages,
const hb_tag_t *features, const hb_tag_t *features,
hb_set_t *visited_features,
hb_set_t *lookup_indexes /* OUT */) hb_set_t *lookup_indexes /* OUT */)
{ {
_hb_ot_layout_collect_lookups_features (face, _hb_ot_layout_collect_lookups_features (face,
@ -734,6 +744,7 @@ _hb_ot_layout_collect_lookups_languages (hb_face_t *face,
script_index, script_index,
HB_OT_LAYOUT_DEFAULT_LANGUAGE_INDEX, HB_OT_LAYOUT_DEFAULT_LANGUAGE_INDEX,
features, features,
visited_features,
lookup_indexes); lookup_indexes);
if (!languages) if (!languages)
@ -749,6 +760,7 @@ _hb_ot_layout_collect_lookups_languages (hb_face_t *face,
script_index, script_index,
language_index, language_index,
features, features,
visited_features,
lookup_indexes); lookup_indexes);
} }
else else
@ -766,6 +778,7 @@ _hb_ot_layout_collect_lookups_languages (hb_face_t *face,
script_index, script_index,
language_index, language_index,
features, features,
visited_features,
lookup_indexes); lookup_indexes);
} }
} }
@ -784,6 +797,7 @@ hb_ot_layout_collect_lookups (hb_face_t *face,
const hb_tag_t *features, const hb_tag_t *features,
hb_set_t *lookup_indexes /* OUT */) hb_set_t *lookup_indexes /* OUT */)
{ {
hb_auto_t<hb_set_t> visited_features;
if (!scripts) if (!scripts)
{ {
/* All scripts */ /* All scripts */
@ -796,6 +810,7 @@ hb_ot_layout_collect_lookups (hb_face_t *face,
script_index, script_index,
languages, languages,
features, features,
&visited_features,
lookup_indexes); lookup_indexes);
} }
else else
@ -812,6 +827,7 @@ hb_ot_layout_collect_lookups (hb_face_t *face,
script_index, script_index,
languages, languages,
features, features,
&visited_features,
lookup_indexes); lookup_indexes);
} }
} }