[subset] bug fix in prune_langsys
we should not cache visited langsys cause 2 different Record<Langsys> could have different Tag while pointing to the same Langsys, a langsys is redundant in Record<Langsys> A does not mean it's redundant in Record B. Same thing for visited_script. Also adding the number of features in the LangSys's feature list to the visited langsys count so it's more accurate. Plus some improvement in langsys compare()
This commit is contained in:
parent
cad2fe8e63
commit
7cb002cb58
|
@ -60,6 +60,10 @@
|
||||||
#define HB_MAX_LANGSYS 2000
|
#define HB_MAX_LANGSYS 2000
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef HB_MAX_LANGSYS_FEATURE_COUNT
|
||||||
|
#define HB_MAX_LANGSYS_FEATURE_COUNT 50000
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef HB_MAX_FEATURES
|
#ifndef HB_MAX_FEATURES
|
||||||
#define HB_MAX_FEATURES 750
|
#define HB_MAX_FEATURES 750
|
||||||
#endif
|
#endif
|
||||||
|
@ -105,34 +109,15 @@ struct hb_prune_langsys_context_t
|
||||||
script_langsys_map (script_langsys_map_),
|
script_langsys_map (script_langsys_map_),
|
||||||
duplicate_feature_map (duplicate_feature_map_),
|
duplicate_feature_map (duplicate_feature_map_),
|
||||||
new_feature_indexes (new_collected_feature_indexes_),
|
new_feature_indexes (new_collected_feature_indexes_),
|
||||||
script_count (0),langsys_count (0) {}
|
script_count (0),langsys_feature_count (0) {}
|
||||||
|
|
||||||
bool visitedScript (const void *s)
|
bool visitScript ()
|
||||||
|
{ return script_count++ < HB_MAX_SCRIPTS; }
|
||||||
|
|
||||||
|
bool visitLangsys (unsigned feature_count)
|
||||||
{
|
{
|
||||||
if (script_count++ > HB_MAX_SCRIPTS)
|
langsys_feature_count += feature_count;
|
||||||
return true;
|
return langsys_feature_count < HB_MAX_LANGSYS_FEATURE_COUNT;
|
||||||
|
|
||||||
return visited (s, visited_script);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool visitedLangsys (const void *l)
|
|
||||||
{
|
|
||||||
if (langsys_count++ > HB_MAX_LANGSYS)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return visited (l, visited_langsys);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
template <typename T>
|
|
||||||
bool visited (const T *p, hb_set_t &visited_set)
|
|
||||||
{
|
|
||||||
hb_codepoint_t delta = (hb_codepoint_t) ((uintptr_t) p - (uintptr_t) table);
|
|
||||||
if (visited_set.in_error () || visited_set.has (delta))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
visited_set.add (delta);
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -142,10 +127,8 @@ struct hb_prune_langsys_context_t
|
||||||
hb_set_t *new_feature_indexes;
|
hb_set_t *new_feature_indexes;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
hb_set_t visited_script;
|
|
||||||
hb_set_t visited_langsys;
|
|
||||||
unsigned script_count;
|
unsigned script_count;
|
||||||
unsigned langsys_count;
|
unsigned langsys_feature_count;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct hb_subset_layout_context_t :
|
struct hb_subset_layout_context_t :
|
||||||
|
@ -643,11 +626,14 @@ struct LangSys
|
||||||
| hb_map (feature_index_map)
|
| hb_map (feature_index_map)
|
||||||
;
|
;
|
||||||
|
|
||||||
if (iter.len () != o_iter.len ())
|
for (; iter && o_iter; iter++, o_iter++)
|
||||||
return false;
|
{
|
||||||
|
unsigned a = *iter;
|
||||||
|
unsigned b = *o_iter;
|
||||||
|
if (a != b) return false;
|
||||||
|
}
|
||||||
|
|
||||||
for (const auto _ : + hb_zip (iter, o_iter))
|
if (iter || o_iter) return false;
|
||||||
if (_.first != _.second) return false;
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -732,7 +718,7 @@ struct Script
|
||||||
unsigned script_index) const
|
unsigned script_index) const
|
||||||
{
|
{
|
||||||
if (!has_default_lang_sys () && !get_lang_sys_count ()) return;
|
if (!has_default_lang_sys () && !get_lang_sys_count ()) return;
|
||||||
if (c->visitedScript (this)) return;
|
if (!c->visitScript ()) return;
|
||||||
|
|
||||||
if (!c->script_langsys_map->has (script_index))
|
if (!c->script_langsys_map->has (script_index))
|
||||||
{
|
{
|
||||||
|
@ -749,15 +735,14 @@ struct Script
|
||||||
{
|
{
|
||||||
//only collect features from non-redundant langsys
|
//only collect features from non-redundant langsys
|
||||||
const LangSys& d = get_default_lang_sys ();
|
const LangSys& d = get_default_lang_sys ();
|
||||||
if (!c->visitedLangsys (&d)) {
|
if (c->visitLangsys (d.get_feature_count ())) {
|
||||||
d.collect_features (c);
|
d.collect_features (c);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto _ : + hb_zip (langSys, hb_range (langsys_count)))
|
for (auto _ : + hb_zip (langSys, hb_range (langsys_count)))
|
||||||
{
|
{
|
||||||
|
|
||||||
const LangSys& l = this+_.first.offset;
|
const LangSys& l = this+_.first.offset;
|
||||||
if (c->visitedLangsys (&l)) continue;
|
if (!c->visitLangsys (l.get_feature_count ())) continue;
|
||||||
if (l.compare (d, c->duplicate_feature_map)) continue;
|
if (l.compare (d, c->duplicate_feature_map)) continue;
|
||||||
|
|
||||||
l.collect_features (c);
|
l.collect_features (c);
|
||||||
|
@ -769,7 +754,7 @@ struct Script
|
||||||
for (auto _ : + hb_zip (langSys, hb_range (langsys_count)))
|
for (auto _ : + hb_zip (langSys, hb_range (langsys_count)))
|
||||||
{
|
{
|
||||||
const LangSys& l = this+_.first.offset;
|
const LangSys& l = this+_.first.offset;
|
||||||
if (c->visitedLangsys (&l)) continue;
|
if (!c->visitLangsys (l.get_feature_count ())) continue;
|
||||||
l.collect_features (c);
|
l.collect_features (c);
|
||||||
c->script_langsys_map->get (script_index)->add (_.second);
|
c->script_langsys_map->get (script_index)->add (_.second);
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
@ -9,4 +9,5 @@ drop-hints.txt
|
||||||
SUBSETS:
|
SUBSETS:
|
||||||
abc
|
abc
|
||||||
Ǽ!A bc
|
Ǽ!A bc
|
||||||
|
abcdefghijk
|
||||||
×ØÙÚÞ
|
×ØÙÚÞ
|
||||||
|
|
Loading…
Reference in New Issue