diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh index 957a35ff0..66e547531 100644 --- a/src/hb-ot-cff1-table.hh +++ b/src/hb-ot-cff1-table.hh @@ -446,7 +446,7 @@ struct Charset { dest->format.set (format); if (format == 0) { - Charset0 *fmt0 = c->allocate_size (Charset0::min_size + HBUINT8::static_size * (num_glyphs - 1)); + Charset0 *fmt0 = c->allocate_size (Charset0::min_size + HBUINT16::static_size * (num_glyphs - 1)); if (unlikely (fmt0 == nullptr)) return_trace (false); unsigned int glyph = 0; for (unsigned int i = 0; i < sid_ranges.len; i++) @@ -488,7 +488,7 @@ struct Charset { { unsigned int size = min_size; if (format == 0) - size += Charset0::min_size + HBUINT8::static_size * (count - 1); + size += Charset0::min_size + HBUINT16::static_size * (count - 1); else if (format == 1) size += Charset1::min_size + Charset1_Range::static_size * count; else diff --git a/src/hb-subset-cff1.cc b/src/hb-subset-cff1.cc index 5285a9e3f..62f81d8f0 100644 --- a/src/hb-subset-cff1.cc +++ b/src/hb-subset-cff1.cc @@ -321,6 +321,21 @@ struct CFF1CSOpSet_Flatten : CFF1CSOpSet typedef CFF1CSOpSet SUPER; }; +struct RangeList : hb_vector_t +{ + /* replace the first glyph ID in the "glyph" field each range with a nLeft value */ + inline void finalize (unsigned int last_glyph) + { + for (unsigned int i = (*this).len; i > 0; i--) + { + code_pair &pair = (*this)[i - 1]; + unsigned int nLeft = last_glyph - pair.glyph - 1; + last_glyph = pair.glyph; + pair.glyph = nLeft; + } + } +}; + struct cff_subset_plan { inline cff_subset_plan (void) : final_size (0), @@ -387,11 +402,6 @@ struct cff_subset_plan { if (code != last_code + 1) { - if (subset_enc_code_ranges.len > 0) - { - code_pair &pair = subset_enc_code_ranges[subset_enc_code_ranges.len - 1]; - pair.glyph = glyph - pair.glyph - 1; - } code_pair pair = { code, glyph }; subset_enc_code_ranges.push (pair); } @@ -410,11 +420,8 @@ struct cff_subset_plan { } } supp_codes.fini (); - if (subset_enc_code_ranges.len > 0) - { - code_pair &pair = subset_enc_code_ranges[subset_enc_code_ranges.len - 1]; - pair.glyph = glyph - pair.glyph - 1; - } + + subset_enc_code_ranges.finalize (glyph); assert (subset_enc_num_codes <= 0xFF); size0 = Encoding0::min_size + HBUINT8::static_size * subset_enc_num_codes; @@ -449,24 +456,13 @@ struct cff_subset_plan { if (sid != last_sid + 1) { - if (subset_charset_ranges.len > 0) - { - code_pair &pair = subset_charset_ranges[subset_charset_ranges.len - 1]; - pair.glyph = glyph - pair.glyph - 1; - if ((pair.glyph & ~0xFF) != 0) two_byte = true; - } code_pair pair = { sid, glyph }; subset_charset_ranges.push (pair); } last_sid = sid; } - if (subset_charset_ranges.len > 0) - { - code_pair &pair = subset_charset_ranges[subset_charset_ranges.len - 1]; - pair.glyph = glyph - pair.glyph - 1; - if ((pair.glyph & ~0xFF) != 0) two_byte = true; - } + subset_charset_ranges.finalize (glyph); size0 = Charset0::min_size + HBUINT16::static_size * (plan->glyphs.len - 1); if (!two_byte) @@ -706,11 +702,11 @@ struct cff_subset_plan { bool subset_encoding; uint8_t subset_enc_format; unsigned int subset_enc_num_codes; - hb_vector_t subset_enc_code_ranges; + RangeList subset_enc_code_ranges; hb_vector_t subset_enc_supp_codes; uint8_t subset_charset_format; - hb_vector_t subset_charset_ranges; + RangeList subset_charset_ranges; bool subset_charset; RemapSID sidmap;