[morx/kerx] Fix sanitize regression

Broke in 8dcc1913a1

If sanitizer is left with another object, it wouldn't work.

Better fix coming soon.
This commit is contained in:
Behdad Esfahbod 2018-11-24 14:52:34 -05:00
parent 3cc14e78ae
commit 20edc70d53
2 changed files with 2 additions and 8 deletions

View File

@ -961,12 +961,10 @@ struct KerxTable
const SubTable *st = &thiz()->firstSubTable;
unsigned int count = thiz()->tableCount;
for (unsigned int i = 0; i < count; i++)
{
if (unlikely (!st->u.header.sanitize (c)))
{
c->reset_object ();
if (unlikely (!st->u.header.sanitize (c)))
return_trace (false);
}
/* OpenType kern table has 2-byte subtable lengths. That's limiting.
* MS implementation also only supports one subtable, of format 0,
* anyway. Certain versions of some fonts, like Calibry, contain
@ -976,8 +974,6 @@ struct KerxTable
* the length for the last subtable. */
if (i < count - 1)
c->set_object (*st);
else
c->reset_object ();
if (unlikely (!st->sanitize (c)))
return_trace (false);

View File

@ -1060,12 +1060,10 @@ struct Chain
const ChainSubtable<Types> *subtable = &StructAfter<ChainSubtable<Types> > (featureZ.as_array (featureCount));
unsigned int count = subtableCount;
for (unsigned int i = 0; i < count; i++)
{
if (unlikely (!c->check_struct (subtable)))
{
c->reset_object ();
if (unlikely (!c->check_struct (subtable)))
return_trace (false);
}
c->set_object (*subtable);
if (!subtable->sanitize (c))
return_trace (false);