From 70704b34ace5667ac700a5d85d7d8a1ba2b58da0 Mon Sep 17 00:00:00 2001 From: Werner Lemberg Date: Tue, 20 Dec 2016 12:27:22 +0100 Subject: [PATCH] [truetype] Improve logic for getting fast advance widths. * src/cff/cffdrivr.c (cff_get_advances), src/truetype/ttdriver.c (tt_get_advances): Use `is_default_instance' for test; this gets recomputed after changing blend coordinates. --- ChangeLog | 8 ++++++++ src/cff/cffdrivr.c | 8 ++++---- src/truetype/ttdriver.c | 8 ++++---- 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/ChangeLog b/ChangeLog index db292bf67..b0e369129 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2016-12-20 Werner Lemberg + + [truetype] Improve logic for getting fast advance widths. + + * src/cff/cffdrivr.c (cff_get_advances), src/truetype/ttdriver.c + (tt_get_advances): Use `is_default_instance' for test; this gets + recomputed after changing blend coordinates. + 2016-12-20 Ben Wagner Werner Lemberg diff --git a/src/cff/cffdrivr.c b/src/cff/cffdrivr.c index 3e0ef8614..3f426c658 100644 --- a/src/cff/cffdrivr.c +++ b/src/cff/cffdrivr.c @@ -219,8 +219,8 @@ { #ifdef TT_CONFIG_OPTION_GX_VAR_SUPPORT /* no fast retrieval for blended MM fonts without VVAR table */ - if ( ( FT_HAS_MULTIPLE_MASTERS( face ) && ttface->blend ) && - !( var && var->vadvance_adjust ) ) + if ( !ttface->is_default_instance && + !( var && var->vadvance_adjust ) ) return FT_THROW( Unimplemented_Feature ); #endif @@ -251,8 +251,8 @@ { #ifdef TT_CONFIG_OPTION_GX_VAR_SUPPORT /* no fast retrieval for blended MM fonts without HVAR table */ - if ( ( FT_HAS_MULTIPLE_MASTERS( face ) && ttface->blend ) && - !( var && var->hadvance_adjust ) ) + if ( !ttface->is_default_instance && + !( var && var->hadvance_adjust ) ) return FT_THROW( Unimplemented_Feature ); #endif diff --git a/src/truetype/ttdriver.c b/src/truetype/ttdriver.c index 66e721eb9..91ddff589 100644 --- a/src/truetype/ttdriver.c +++ b/src/truetype/ttdriver.c @@ -238,8 +238,8 @@ { #ifdef TT_CONFIG_OPTION_GX_VAR_SUPPORT /* no fast retrieval for blended MM fonts without VVAR table */ - if ( ( FT_HAS_MULTIPLE_MASTERS( ttface ) && face->blend ) && - !( var && var->vadvance_adjust ) ) + if ( !face->is_default_instance && + !( var && var->vadvance_adjust ) ) return FT_THROW( Unimplemented_Feature ); #endif @@ -258,8 +258,8 @@ { #ifdef TT_CONFIG_OPTION_GX_VAR_SUPPORT /* no fast retrieval for blended MM fonts without HVAR table */ - if ( ( FT_HAS_MULTIPLE_MASTERS( ttface ) && face->blend ) && - !( var && var->hadvance_adjust ) ) + if ( !face->is_default_instance && + !( var && var->hadvance_adjust ) ) return FT_THROW( Unimplemented_Feature ); #endif