From 6d29f0f1e8bc3dfbb0af274ffde41ee41bc35150 Mon Sep 17 00:00:00 2001 From: Werner Lemberg Date: Sat, 3 May 2008 15:54:15 +0000 Subject: [PATCH] * src/base/ftobjs.c (FT_Load_Glyph): Call the auto-hinter without transformation since it recursively calls FT_Load_Glyph. This fixes Savannah bug #23143. --- ChangeLog | 6 ++++++ src/base/ftobjs.c | 22 +++++++++++++++++----- 2 files changed, 23 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index dd8eb1211..b1e69f4ab 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2008-05-03 Werner Lemberg + + * src/base/ftobjs.c (FT_Load_Glyph): Call the auto-hinter without + transformation since it recursively calls FT_Load_Glyph. This fixes + Savannah bug #23143. + 2008-04-26 Werner Lemberg * include/freetype/internal/psaux.h (T1_BuilderRec): Mark `scale_x' diff --git a/src/base/ftobjs.c b/src/base/ftobjs.c index ed9fc96fa..efa5ffe27 100644 --- a/src/base/ftobjs.c +++ b/src/base/ftobjs.c @@ -634,12 +634,24 @@ goto Load_Ok; } - /* load auto-hinted outline */ - hinting = (FT_AutoHinter_Service)hinter->clazz->module_interface; + { + FT_Face_Internal internal = face->internal; + FT_Int transform_flags = internal->transform_flags; + + + /* since the auto-hinter calls FT_Load_Glyph by itself, */ + /* make sure that glyphs aren't transformed */ + internal->transform_flags = 0; - error = hinting->load_glyph( (FT_AutoHinter)hinter, - slot, face->size, - glyph_index, load_flags ); + /* load auto-hinted outline */ + hinting = (FT_AutoHinter_Service)hinter->clazz->module_interface; + + error = hinting->load_glyph( (FT_AutoHinter)hinter, + slot, face->size, + glyph_index, load_flags ); + + internal->transform_flags = transform_flags; + } } else {