[HB] Add check to avoid infinite recursion
authorBehdad Esfahbod <behdad@behdad.org>
Mon, 18 May 2009 01:11:49 +0000 (21:11 -0400)
committerBehdad Esfahbod <behdad@behdad.org>
Mon, 2 Nov 2009 19:40:11 +0000 (14:40 -0500)
src/hb-ot-layout-gsub-private.h

index f5a8ec5..c5834b0 100644 (file)
@@ -646,7 +646,7 @@ struct SubstLookup : Lookup {
     if (HB_UNLIKELY (type == GSUB_Extension)) {
       /* Return lookup type of first extension subtable.
        * The spec says all of them should have the same type.
-       * XXX check for that somehow */
+       * XXX check for that in sanitize() */
       type = get_subtable(0).u.extension->get_type ();
     }
 
@@ -763,10 +763,14 @@ ASSERT_SIZE (GSUB, 10);
 /* Out-of-class implementation for methods recursing */
 
 inline bool ExtensionSubstFormat1::substitute (LOOKUP_ARGS_DEF) const {
-  /* XXX either check in sanitize or here that the lookuptype is not 7 again,
-   * or we can loop indefinitely. */
+  unsigned int lookup_type = get_type ();
+
+  /* TODO: belongs to sanitize() */
+  if (HB_UNLIKELY (lookup_type == GSUB_ReverseChainSingle))
+    return false;
+
   return (*(SubstLookupSubTable *)(((char *) this) + get_offset ())).substitute (LOOKUP_ARGS,
-                                                                                get_type ());
+                                                                                lookup_type);
 }
 
 static inline bool substitute_lookup (LOOKUP_ARGS_DEF, unsigned int lookup_index) {