1. 21 12月, 2016 1 次提交
  2. 17 12月, 2016 1 次提交
  3. 06 5月, 2016 1 次提交
  4. 18 3月, 2016 1 次提交
    • B
      Synthesize GDEF glyph class for any glyph that does not have one in GDEF · 69f9fbc4
      Behdad Esfahbod 提交于
      Previously we only synthesized GDEF glyph classes if the glyphClassDef
      array in GDEF was null.  This worked well enough, and is indeed what
      OpenType requires: "If the font does not include a GlyphClassDef table,
      the client must define and maintain this information when using the
      GSUB and GPOS tables."  That sentence does not quite make sense since
      one needs Unicode properties as well, but is close enough.
      
      However, looks like Arial Unicode as shipped on WinXP, does have GDEF
      glyph class array, but defines no classes for Hebrew.  This results
      in Hebrew marks not getting their widths zeroed.  So, with this change,
      we synthesize glyph class for any glyph that is not specified in the
      GDEF glyph class table.  Since, from our point of view, a glyph not
      being listed in that table is a font bug, any unwanted consequence of
      this change is a font bug :).
      
      Note that we still don't get the same rendering as Uniscribe, since
      Uniscribe seems to do fallback positioning as well, even though the
      font does have a GPOS table (which does NOT cover Hebrew!).  We are
      not going to try to match that though.
      
      Test string for Arial Unicode:
      
      	U+05E9,U+05B8,U+05C1,U+05DC
      
      Before:		[gid1166=3+991|gid1142=0+737|gid5798=0+1434]
      After:		[gid1166=3+991|gid1142=0+0|gid5798=0+1434]
      Uniscribe:	[gid1166=3+991|gid1142=0@348,0+0|gid5798=0+1434]
      
      Note that our new output matches what we were generating until July
      2014, because the Hebrew shaper used to zero mark advances based on
      Unicode, NOT GDEF.  That's 9e834e29.
      
      Reported by Greg Douglas.
      69f9fbc4
  5. 11 2月, 2016 1 次提交
  6. 03 11月, 2015 1 次提交
  7. 10 10月, 2015 1 次提交
  8. 29 9月, 2015 2 次提交
  9. 18 8月, 2015 1 次提交
  10. 09 4月, 2015 1 次提交
  11. 26 2月, 2015 12 次提交
  12. 13 12月, 2014 1 次提交
  13. 15 10月, 2014 1 次提交
  14. 03 8月, 2014 1 次提交
  15. 12 7月, 2014 1 次提交
  16. 06 6月, 2014 4 次提交
  17. 29 4月, 2014 1 次提交
  18. 31 10月, 2013 1 次提交
  19. 18 10月, 2013 5 次提交
  20. 17 10月, 2013 1 次提交
  21. 15 10月, 2013 1 次提交
    • B
      [otlayout] Fix (Chain)Context recursion! · 6b65a76b
      Behdad Esfahbod 提交于
      Previously we only supported recursive sublookups with
      ascending indices.  We were also not correctly handling
      non-1-to-1 recursed lookups.
      
      Fix all that!
      
      Fixes the three tests in test/shaping/tests/context-matching.tests,
      which were derived from NotoSansBengali and NotoSansDevanagari
      among others.
      6b65a76b