[subset] post table to use _subset2
This commit is contained in:
parent
db938479d7
commit
93d592e0e1
|
@ -73,26 +73,25 @@ struct post
|
||||||
{
|
{
|
||||||
static constexpr hb_tag_t tableTag = HB_OT_TAG_post;
|
static constexpr hb_tag_t tableTag = HB_OT_TAG_post;
|
||||||
|
|
||||||
bool subset (hb_subset_plan_t *plan) const
|
void serialize (hb_serialize_context_t *c) const
|
||||||
{
|
{
|
||||||
unsigned int post_prime_length;
|
post *post_prime = c->allocate_min<post> ();
|
||||||
hb_blob_t *post_blob = hb_sanitize_context_t ().reference_table<post>(plan->source);
|
if (unlikely (!post_prime)) return;
|
||||||
hb_blob_t *post_prime_blob = hb_blob_create_sub_blob (post_blob, 0, post::min_size);
|
|
||||||
post *post_prime = (post *) hb_blob_get_data_writable (post_prime_blob, &post_prime_length);
|
|
||||||
hb_blob_destroy (post_blob);
|
|
||||||
|
|
||||||
if (unlikely (!post_prime || post_prime_length != post::min_size))
|
memcpy (post_prime, this, post::min_size);
|
||||||
{
|
post_prime->version.major = 3; // Version 3 does not have any glyph names.
|
||||||
hb_blob_destroy (post_prime_blob);
|
|
||||||
DEBUG_MSG(SUBSET, nullptr, "Invalid source post table with length %d.", post_prime_length);
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
post_prime->version.major = 3; // Version 3 does not have any glyph names.
|
bool subset (hb_subset_context_t *c) const
|
||||||
bool result = plan->add_table (HB_OT_TAG_post, post_prime_blob);
|
{
|
||||||
hb_blob_destroy (post_prime_blob);
|
TRACE_SUBSET (this);
|
||||||
|
post *post_prime = c->serializer->start_embed<post> ();
|
||||||
|
if (unlikely (!post_prime)) return_trace (false);
|
||||||
|
|
||||||
return result;
|
serialize (c->serializer);
|
||||||
|
if (c->serializer->in_error () || c->serializer->ran_out_of_room) return_trace (false);
|
||||||
|
|
||||||
|
return_trace (true);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct accelerator_t
|
struct accelerator_t
|
||||||
|
|
|
@ -193,7 +193,7 @@ _subset_table (hb_subset_plan_t *plan,
|
||||||
result = _subset<const OT::OS2> (plan);
|
result = _subset<const OT::OS2> (plan);
|
||||||
break;
|
break;
|
||||||
case HB_OT_TAG_post:
|
case HB_OT_TAG_post:
|
||||||
result = _subset<const OT::post> (plan);
|
result = _subset2<const OT::post> (plan);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifndef HB_NO_SUBSET_CFF
|
#ifndef HB_NO_SUBSET_CFF
|
||||||
|
|
Loading…
Reference in New Issue