[subset] Don't crash if subsetting GSUB/GPOS fails
Fixes fuzzer issue.
This commit is contained in:
parent
2b051e7aa1
commit
6977a95fed
|
@ -68,11 +68,11 @@ template<typename TableType>
|
|||
static bool
|
||||
_subset2 (hb_subset_plan_t *plan)
|
||||
{
|
||||
bool result = true;
|
||||
hb_blob_t *source_blob = hb_sanitize_context_t ().reference_table<TableType> (plan->source);
|
||||
const TableType *table = source_blob->as<TableType> ();
|
||||
|
||||
hb_tag_t tag = TableType::tableTag;
|
||||
hb_bool_t result = false;
|
||||
if (source_blob->data)
|
||||
{
|
||||
hb_vector_t<char> buf;
|
||||
|
@ -87,7 +87,7 @@ _subset2 (hb_subset_plan_t *plan)
|
|||
hb_serialize_context_t serializer ((void *) buf, buf_size);
|
||||
serializer.start_serialize<TableType> ();
|
||||
hb_subset_context_t c (plan, &serializer);
|
||||
result = table->subset (&c);
|
||||
bool needed = table->subset (&c);
|
||||
if (serializer.ran_out_of_room)
|
||||
{
|
||||
buf_size += (buf_size >> 1) + 32;
|
||||
|
@ -101,10 +101,11 @@ _subset2 (hb_subset_plan_t *plan)
|
|||
}
|
||||
serializer.end_serialize ();
|
||||
|
||||
if (serializer.in_error ())
|
||||
abort ();
|
||||
result = !serializer.in_error ();
|
||||
|
||||
if (result)
|
||||
{
|
||||
if (needed)
|
||||
{
|
||||
hb_blob_t *dest_blob = serializer.copy_blob ();
|
||||
DEBUG_MSG(SUBSET, nullptr, "OT::%c%c%c%c final subset table size: %u bytes.", HB_UNTAG (tag), dest_blob->length);
|
||||
|
@ -114,7 +115,7 @@ _subset2 (hb_subset_plan_t *plan)
|
|||
else
|
||||
{
|
||||
DEBUG_MSG(SUBSET, nullptr, "OT::%c%c%c%c::subset table subsetted to empty.", HB_UNTAG (tag));
|
||||
result = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
|
|
Loading…
Reference in New Issue