From eca8e33710cfce51454e64d974ff0c28b0eefa14 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Sun, 17 May 2009 09:07:27 -0400 Subject: [PATCH] [GSUB] Further optimize the main switch --- src/hb-ot-layout-gsub-private.h | 31 +++++++++++++++++-------------- 1 file changed, 17 insertions(+), 14 deletions(-) diff --git a/src/hb-ot-layout-gsub-private.h b/src/hb-ot-layout-gsub-private.h index 3b9b1a60..044703ab 100644 --- a/src/hb-ot-layout-gsub-private.h +++ b/src/hb-ot-layout-gsub-private.h @@ -735,11 +735,8 @@ struct SubstLookupSubTable { friend struct SubstLookup; inline bool substitute (LOOKUP_ARGS_DEF, - unsigned int lookup_type) const { - - unsigned int property; - if (!_hb_ot_layout_check_glyph_property (layout, IN_CURITEM (), lookup_flag, &property)) - return false; + unsigned int property, + unsigned int lookup_type) const { switch (lookup_type) { case GSUB_Single: return u.single.substitute (LOOKUP_ARGS, property); @@ -805,23 +802,21 @@ struct SubstLookup : Lookup { } } - bool substitute_once (hb_ot_layout_t *layout, - hb_buffer_t *buffer, - unsigned int context_length, - unsigned int nesting_level_left) const { + inline bool substitute_once (hb_ot_layout_t *layout, + hb_buffer_t *buffer, + unsigned int context_length, + unsigned int nesting_level_left) const { unsigned int lookup_type = get_type (); unsigned int lookup_flag = get_flag (); - if (HB_UNLIKELY (nesting_level_left == 0)) - return false; - nesting_level_left--; - - if (HB_UNLIKELY (context_length < 1)) + unsigned int property; + if (!_hb_ot_layout_check_glyph_property (layout, IN_CURITEM (), lookup_flag, &property)) return false; for (unsigned int i = 0; i < get_subtable_count (); i++) if (get_subtable (i).substitute (LOOKUP_ARGS, + property, lookup_type)) return true; @@ -903,6 +898,7 @@ inline bool ExtensionSubstFormat1::substitute (LOOKUP_ARGS_DEF, unsigned int pro /* XXX either check in sanitize or here that the lookuptype is not 7 again, * or we can loop indefinitely. */ return (*(SubstLookupSubTable *)(((char *) this) + extensionOffset)).substitute (LOOKUP_ARGS, + property, get_type ()); } @@ -910,6 +906,13 @@ static inline bool substitute_lookup (LOOKUP_ARGS_DEF, unsigned int lookup_index const GSUB &gsub = *(layout->gsub); const SubstLookup &l = gsub.get_lookup (lookup_index); + if (HB_UNLIKELY (nesting_level_left == 0)) + return false; + nesting_level_left--; + + if (HB_UNLIKELY (context_length < 1)) + return false; + return l.substitute_once (layout, buffer, context_length, nesting_level_left); } -- GitLab