[subset] correct ClassDef format determination.
It was possible for glyph_min to be a glyph mapped to class zero which threw off the number of glyph calculation.
This commit is contained in:
parent
90713f270e
commit
be50779cda
|
@ -2308,11 +2308,13 @@ struct ClassDef
|
||||||
|
|
||||||
template<typename Iterator,
|
template<typename Iterator,
|
||||||
hb_requires (hb_is_iterator (Iterator))>
|
hb_requires (hb_is_iterator (Iterator))>
|
||||||
bool serialize (hb_serialize_context_t *c, Iterator it)
|
bool serialize (hb_serialize_context_t *c, Iterator it_with_class_zero)
|
||||||
{
|
{
|
||||||
TRACE_SERIALIZE (this);
|
TRACE_SERIALIZE (this);
|
||||||
if (unlikely (!c->extend_min (*this))) return_trace (false);
|
if (unlikely (!c->extend_min (*this))) return_trace (false);
|
||||||
|
|
||||||
|
auto it = + it_with_class_zero | hb_filter (hb_second);
|
||||||
|
|
||||||
unsigned format = 2;
|
unsigned format = 2;
|
||||||
if (likely (it))
|
if (likely (it))
|
||||||
{
|
{
|
||||||
|
@ -2328,8 +2330,8 @@ struct ClassDef
|
||||||
{
|
{
|
||||||
hb_codepoint_t cur_gid = gid_klass_pair.first;
|
hb_codepoint_t cur_gid = gid_klass_pair.first;
|
||||||
unsigned cur_klass = gid_klass_pair.second;
|
unsigned cur_klass = gid_klass_pair.second;
|
||||||
if (cur_klass) num_glyphs++;
|
num_glyphs++;
|
||||||
if (cur_gid == glyph_min || !cur_klass) continue;
|
if (cur_gid == glyph_min) continue;
|
||||||
if (cur_gid > glyph_max) glyph_max = cur_gid;
|
if (cur_gid > glyph_max) glyph_max = cur_gid;
|
||||||
if (cur_gid != prev_gid + 1 ||
|
if (cur_gid != prev_gid + 1 ||
|
||||||
cur_klass != prev_klass)
|
cur_klass != prev_klass)
|
||||||
|
|
Loading…
Reference in New Issue