[subset] Fix namerecord ordering

This will fix inconsistency with fontTools.
Also according to the spec, namerecords must be sorted
first by platform ID, then by platform-specific ID,
then by language ID, and then by name ID.
This commit is contained in:
Qunxin Liu 2020-01-28 15:57:33 -08:00 committed by Ebrahim Byagowi
parent b4377afd28
commit 490ef1cc23
47 changed files with 37 additions and 1 deletions

View File

@ -116,6 +116,29 @@ struct NameRecord
return (p == 0 ||
(p == 3 && (e == 0 || e == 1 || e == 10)));
}
static int cmp (const void *pa, const void *pb)
{
const NameRecord *a = (const NameRecord *)pa;
const NameRecord *b = (const NameRecord *)pb;
if (a->platformID != b->platformID)
return a->platformID < b->platformID ? -1 : +1;
if (a->encodingID != b->encodingID)
return a->encodingID < b->encodingID ? -1 : +1;
if (a->languageID != b->languageID)
return a->languageID < b->languageID ? -1 : +1;
if (a->nameID != b->nameID)
return a->nameID < b->nameID ? -1 : +1;
if (a->length != b->length)
return a->length < b->length ? -1 : +1;
return 0;
}
bool sanitize (hb_sanitize_context_t *c, const void *base) const
{
@ -200,7 +223,19 @@ struct name
const void *dst_string_pool = &(this + this->stringOffset);
c->copy_all (it, src_string_pool, dst_string_pool);
NameRecord *name_records = (NameRecord *) calloc (it.len (), NameRecord::static_size);
hb_array_t<NameRecord> records (name_records, it.len ());
for (const NameRecord& record : it)
{
memcpy (name_records, &record, NameRecord::static_size);
name_records++;
}
records.qsort ();
c->copy_all (records, src_string_pool, dst_string_pool);
free (records.arrayZ);
if (unlikely (c->ran_out_of_room)) return_trace (false);

View File

@ -1,6 +1,7 @@
FONTS:
Roboto-Regular.abc.ttf
Comfortaa-Regular-new.ttf
NanumMyeongjo-Regular-subset.ttf
PROFILES:
default.txt