提交 a31d0146 编写于 作者: N Nigel Tao

Loosen the SLOOP (Set LOOP) opcode precondition.

This goes against spec, but matches the C Freetype implementation and
works around a bug in DejaVuSansMono.ttf's hinted '2' glyph.
上级 c67e4d98
...@@ -341,7 +341,14 @@ func (h *hinter) run(program []byte, pCurrent, pUnhinted, pInFontUnits []Point, ...@@ -341,7 +341,14 @@ func (h *hinter) run(program []byte, pCurrent, pUnhinted, pInFontUnits []Point,
case opSLOOP: case opSLOOP:
top-- top--
if h.stack[top] <= 0 { // https://developer.apple.com/fonts/TrueType-Reference-Manual/RM05/Chap5.html#SLOOP
// says that "Setting the loop variable to zero is an error". In
// theory, the inequality on the next line should be "<=" instead
// of "<". In practice, some font files' bytecode, such as the '2'
// glyph in the DejaVuSansMono.ttf that comes with Ubuntu 14.04,
// issue SLOOP with a zero on top of the stack. Just like the C
// Freetype code, we allow the zero.
if h.stack[top] < 0 {
return errors.New("truetype: hinting: invalid data") return errors.New("truetype: hinting: invalid data")
} }
h.gs.loop = h.stack[top] h.gs.loop = h.stack[top]
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册