Don't skip setting the .end field of the first range
Fixes a bug in CoverageFormat2::serialize whereby the first range was not serialized correctly if it consists of only a single glyph ID. This broke shaping of U+0626 in the Arabic fallback shaper, because it is not found in the coverage table of the 'init' and 'medi' lookups. Also fix similar bug in ClassDefFormat2::serialize, noted during code inspection (I haven't observed a case that was actually affected by this, but it looks broken). Fixes https://github.com/harfbuzz/harfbuzz/issues/1504
This commit is contained in:
parent
8a8d45b924
commit
e5d6fe9782
|
@ -921,12 +921,13 @@ struct CoverageFormat2
|
||||||
{
|
{
|
||||||
if (glyphs[i - 1] + 1 != glyphs[i])
|
if (glyphs[i - 1] + 1 != glyphs[i])
|
||||||
{
|
{
|
||||||
|
rangeRecord[range].end = glyphs[i - 1];
|
||||||
range++;
|
range++;
|
||||||
rangeRecord[range].start = glyphs[i];
|
rangeRecord[range].start = glyphs[i];
|
||||||
rangeRecord[range].value = i;
|
rangeRecord[range].value = i;
|
||||||
}
|
}
|
||||||
rangeRecord[range].end = glyphs[i];
|
|
||||||
}
|
}
|
||||||
|
rangeRecord[range].end = glyphs[count - 1];
|
||||||
return_trace (true);
|
return_trace (true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1352,8 +1353,9 @@ struct ClassDefFormat2
|
||||||
return_trace (true);
|
return_trace (true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned int count = glyphs.len ();
|
||||||
unsigned int num_ranges = 1;
|
unsigned int num_ranges = 1;
|
||||||
for (unsigned int i = 1; i < glyphs.length; i++)
|
for (unsigned int i = 1; i < count; i++)
|
||||||
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
||||||
klasses[i - 1] != klasses[i])
|
klasses[i - 1] != klasses[i])
|
||||||
num_ranges++;
|
num_ranges++;
|
||||||
|
@ -1363,17 +1365,18 @@ struct ClassDefFormat2
|
||||||
unsigned int range = 0;
|
unsigned int range = 0;
|
||||||
rangeRecord[range].start = glyphs[0];
|
rangeRecord[range].start = glyphs[0];
|
||||||
rangeRecord[range].value = klasses[0];
|
rangeRecord[range].value = klasses[0];
|
||||||
for (unsigned int i = 1; i < glyphs.length; i++)
|
for (unsigned int i = 1; i < count; i++)
|
||||||
{
|
{
|
||||||
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
||||||
klasses[i - 1] != klasses[i])
|
klasses[i - 1] != klasses[i])
|
||||||
{
|
{
|
||||||
|
rangeRecord[range].end = glyphs[i - 1];
|
||||||
range++;
|
range++;
|
||||||
rangeRecord[range].start = glyphs[i];
|
rangeRecord[range].start = glyphs[i];
|
||||||
rangeRecord[range].value = klasses[i];
|
rangeRecord[range].value = klasses[i];
|
||||||
}
|
}
|
||||||
rangeRecord[range].end = glyphs[i];
|
|
||||||
}
|
}
|
||||||
|
rangeRecord[range].end = glyphs[count - 1];
|
||||||
return_trace (true);
|
return_trace (true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1510,8 +1513,9 @@ struct ClassDef
|
||||||
hb_codepoint_t glyph_min = glyphs[0];
|
hb_codepoint_t glyph_min = glyphs[0];
|
||||||
hb_codepoint_t glyph_max = glyphs[glyphs.length - 1];
|
hb_codepoint_t glyph_max = glyphs[glyphs.length - 1];
|
||||||
|
|
||||||
|
unsigned int count = glyphs.len ();
|
||||||
unsigned int num_ranges = 1;
|
unsigned int num_ranges = 1;
|
||||||
for (unsigned int i = 1; i < glyphs.length; i++)
|
for (unsigned int i = 1; i < count; i++)
|
||||||
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
if (glyphs[i - 1] + 1 != glyphs[i] ||
|
||||||
klasses[i - 1] != klasses[i])
|
klasses[i - 1] != klasses[i])
|
||||||
num_ranges++;
|
num_ranges++;
|
||||||
|
|
Loading…
Reference in New Issue