gdi32: Beautifully handle pre-Unicode symbol TTFs with symbols at U+00XX.

Konstantin L. Metlov metlov at fti.dn.ua
Wed May 11 11:01:59 CDT 2011


This patch augments the beautiful commit 834378183ad2dffa84fab63b080c31241ac33cba with the code, which actually 
makes it work. This is done while attempting to minimally distort the beauty. ;-)

---
 dlls/gdi32/freetype.c |    8 +++++---
 1 files changed, 5 insertions(+), 3 deletions(-)

diff --git a/dlls/gdi32/freetype.c b/dlls/gdi32/freetype.c
index a3e9cec..bdbcc33 100644
--- a/dlls/gdi32/freetype.c
+++ b/dlls/gdi32/freetype.c
@@ -4553,12 +4553,14 @@ static FT_UInt get_glyph_index(const GdiFont *font, UINT glyph)
         return get_GSUB_vert_glyph(font,ret);
     }
 
-    if(font->ft_face->charmap->encoding == FT_ENCODING_MS_SYMBOL && glyph < 0x100)
+    if(font->ft_face->charmap->encoding == FT_ENCODING_MS_SYMBOL)
     {
+        if (glyph < 0x100)
+            glyph = glyph + 0xf000;
         /* there is a number of old pre-Unicode "broken" TTFs, which
            do have symbols at U+00XX instead of U+f0XX */
-        if (!(glyphId = pFT_Get_Char_Index(font->ft_face, glyph + 0xf000)))
-            glyphId = pFT_Get_Char_Index(font->ft_face, glyph);
+        if (!(glyphId = pFT_Get_Char_Index(font->ft_face, glyph)))
+            glyphId = pFT_Get_Char_Index(font->ft_face, glyph-0xf000);
     }
     else glyphId = pFT_Get_Char_Index(font->ft_face, glyph);
 
-- 
1.7.0.4




More information about the wine-patches mailing list