src/Makefile.sources                                                           
     |    2 
 src/hb-aat-fdsc-table.hh                                                       
     |  103 ++++++++++
 src/hb-aat-layout.cc                                                           
     |    1 
 src/hb-cff-interp-cs-common.hh                                                 
     |   22 +-
 src/hb-coretext.cc                                                             
     |   16 -
 src/hb-ot-cff-common.hh                                                        
     |    2 
 src/hb-ot-cff1-table.hh                                                        
     |   16 -
 src/hb-ot-cff2-table.hh                                                        
     |    3 
 src/hb-ot-gasp-table.hh                                                        
     |   84 ++++++++
 src/hb-ot-layout.cc                                                            
     |    5 
 src/hb-ot-os2-table.hh                                                         
     |   88 ++++++--
 
test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5175735354916864
  |binary
 
test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5700264032468992
  |binary
 
test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-subset-fuzzer-5672913680728064
 |binary
 14 files changed, 290 insertions(+), 52 deletions(-)

New commits:
commit 8394a6cb252dd8b4230c2b59e8c346ec5403bf88
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Wed Dec 5 15:23:41 2018 +0330

    [os2] Make newer table fields accessible (#1452)

diff --git a/src/hb-ot-os2-table.hh b/src/hb-ot-os2-table.hh
index e53eda73..46e8b708 100644
--- a/src/hb-ot-os2-table.hh
+++ b/src/hb-ot-os2-table.hh
@@ -30,7 +30,7 @@
 #include "hb-open-type.hh"
 #include "hb-ot-os2-unicode-ranges.hh"
 
-namespace OT {
+#include "hb-set.hh"
 
 /*
  * OS/2 and Windows Metrics
@@ -38,16 +38,65 @@ namespace OT {
  */
 #define HB_OT_TAG_OS2 HB_TAG('O','S','/','2')
 
-struct OS2
+
+namespace OT {
+
+struct OS2V1Tail
 {
-  enum { tableTag = HB_OT_TAG_OS2 };
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this));
+  }
+
+  public:
+  HBUINT32     ulCodePageRange1;
+  HBUINT32     ulCodePageRange2;
+  public:
+  DEFINE_SIZE_STATIC (8);
+};
+
+struct OS2V2Tail
+{
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this));
+  }
+
+  public:
+  HBINT16      sxHeight;
+  HBINT16      sCapHeight;
+  HBUINT16     usDefaultChar;
+  HBUINT16     usBreakChar;
+  HBUINT16     usMaxContext;
+  public:
+  DEFINE_SIZE_STATIC (10);
+};
 
+struct OS2V5Tail
+{
   inline bool sanitize (hb_sanitize_context_t *c) const
   {
     TRACE_SANITIZE (this);
     return_trace (c->check_struct (this));
   }
 
+  public:
+  HBUINT16     usLowerOpticalPointSize;
+  HBUINT16     usUpperOpticalPointSize;
+  public:
+  DEFINE_SIZE_STATIC (4);
+};
+
+struct OS2
+{
+  enum { tableTag = HB_OT_TAG_OS2 };
+
+  inline const OS2V1Tail &v1 (void) const { return version >= 1 ? v1X : Null 
(OS2V1Tail); }
+  inline const OS2V2Tail &v2 (void) const { return version >= 2 ? v2X : Null 
(OS2V2Tail); }
+  inline const OS2V5Tail &v5 (void) const { return version >= 5 ? v5X : Null 
(OS2V5Tail); }
+
   inline bool subset (hb_subset_plan_t *plan) const
   {
     hb_blob_t *os2_blob = hb_sanitize_context_t ().reference_table<OS2> 
(plan->source);
@@ -125,10 +174,18 @@ struct OS2
     return (font_page_t) (fsSelection & 0xFF00);
   }
 
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    if (unlikely (!c->check_struct (this))) return_trace (false);
+    if (unlikely (version >= 1 && !v1X.sanitize (c))) return_trace (false);
+    if (unlikely (version >= 2 && !v2X.sanitize (c))) return_trace (false);
+    if (unlikely (version >= 5 && !v5X.sanitize (c))) return_trace (false);
+    return_trace (true);
+  }
+
   public:
   HBUINT16     version;
-
-  /* Version 0 */
   HBINT16      xAvgCharWidth;
   HBUINT16     usWeightClass;
   HBUINT16     usWidthClass;
@@ -155,24 +212,11 @@ struct OS2
   HBINT16      sTypoLineGap;
   HBUINT16     usWinAscent;
   HBUINT16     usWinDescent;
-
-  /* Version 1 */
-  //HBUINT32   ulCodePageRange1;
-  //HBUINT32   ulCodePageRange2;
-
-  /* Version 2 */
-  //HBINT16    sxHeight;
-  //HBINT16    sCapHeight;
-  //HBUINT16   usDefaultChar;
-  //HBUINT16   usBreakChar;
-  //HBUINT16   usMaxContext;
-
-  /* Version 5 */
-  //HBUINT16   usLowerOpticalPointSize;
-  //HBUINT16   usUpperOpticalPointSize;
-
+  OS2V1Tail    v1X;
+  OS2V2Tail    v2X;
+  OS2V5Tail    v5X;
   public:
-  DEFINE_SIZE_STATIC (78);
+  DEFINE_SIZE_MIN (78);
 };
 
 } /* namespace OT */
commit 5ab086ebb18112ef48bf6c913acc91b2009a9bed
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Wed Dec 5 14:17:37 2018 +0330

    [fdsc] Implement the table parsing
    
    Related to https://github.com/harfbuzz/harfbuzz/issues/1337
    
    May used in addition to an API related to STAT.
    
    Lots of Apple fonts have it.

diff --git a/src/Makefile.sources b/src/Makefile.sources
index 2eb589f9..01ce0aca 100644
--- a/src/Makefile.sources
+++ b/src/Makefile.sources
@@ -1,6 +1,7 @@
 # Base and default-included sources and headers
 
 HB_BASE_sources = \
+       hb-aat-fdsc-table.hh \
        hb-aat-layout-ankr-table.hh \
        hb-aat-layout-bsln-table.hh \
        hb-aat-layout-common.hh \
diff --git a/src/hb-aat-fdsc-table.hh b/src/hb-aat-fdsc-table.hh
new file mode 100644
index 00000000..d432d7fc
--- /dev/null
+++ b/src/hb-aat-fdsc-table.hh
@@ -0,0 +1,103 @@
+/*
+ * Copyright © 2018  Ebrahim Byagowi
+ *
+ *  This is part of HarfBuzz, a text shaping library.
+ *
+ * Permission is hereby granted, without written agreement and without
+ * license or royalty fees, to use, copy, modify, and distribute this
+ * software and its documentation for any purpose, provided that the
+ * above copyright notice and the following two paragraphs appear in
+ * all copies of this software.
+ *
+ * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
+ * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+ * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
+ * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
+ *
+ * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
+ * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
+ * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
+ * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
+ */
+
+#ifndef HB_AAT_FDSC_TABLE_HH
+#define HB_AAT_FDSC_TABLE_HH
+
+#include "hb-aat-layout-common.hh"
+
+/*
+ * fdsc -- Font descriptors
+ * 
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6fdsc.html
+ */
+#define HB_AAT_TAG_fdsc HB_TAG('f','d','s','c')
+
+
+namespace AAT {
+
+
+struct GXFontDescriptor
+{
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this));
+  }
+
+  public:
+  Tag          tag;            /* The 4-byte table tag name. */
+  Fixed                value;          /* The value for the descriptor tag. */
+  public:
+  DEFINE_SIZE_STATIC (8);
+};
+
+struct gasp
+{
+  enum { tableTag = HB_AAT_TAG_fdsc };
+
+  enum {
+    Weight      = HB_TAG ('w','g','h','t'),
+                               /* Percent weight relative to regular weight.
+                                * (defaul value: 1.0) */
+    Width       = HB_TAG ('w','d','t','h'),
+                               /* Percent width relative to regular width.
+                                * (default value: 1.0) */
+    Slant       = HB_TAG ('s','l','n','t'),
+                               /* Angle of slant in degrees, where positive
+                                * is clockwise from straight up.
+                                * (default value: 0.0) */
+    OpticalSize  = HB_TAG ('o','p','s','z'),
+                               /* Point size the font was designed for.
+                                * (default value: 12.0) */
+    NonAlphabetic= HB_TAG ('n','a','l','f')
+                               /* These values are treated as integers,
+                                * not fixed32s. 0 means alphabetic, and greater
+                                * integers mean the font is non-alphabetic 
(e.g. symbols).
+                                * (default value: 0) */
+  };
+
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this) &&
+                 descriptors.sanitize (c));
+  }
+
+  protected:
+  Fixed                version;        /* Version number of the font 
descriptors
+                                * table (0x00010000 for the current version). 
*/
+  LArrayOf<GXFontDescriptor>
+               descriptors;    /* List of tagged-coordinate pairs style 
descriptors
+                                * that will be included to characterize this 
font.
+                                * Each descriptor consists of a <tag, value> 
pair.
+                                * These pairs are located in the 
gxFontDescriptor
+                                * array that follows. */
+  public:
+  DEFINE_SIZE_ARRAY (8, descriptors);
+};
+
+} /* namespace AAT */
+
+
+#endif /* HB_AAT_FDSC_TABLE_HH */
diff --git a/src/hb-aat-layout.cc b/src/hb-aat-layout.cc
index e39df0e1..08afa5df 100644
--- a/src/hb-aat-layout.cc
+++ b/src/hb-aat-layout.cc
@@ -29,6 +29,7 @@
 
 #include "hb-ot-face.hh"
 #include "hb-aat-layout.hh"
+#include "hb-aat-fdsc-table.hh" // Just so we compile it; unused otherwise.
 #include "hb-aat-layout-ankr-table.hh"
 #include "hb-aat-layout-bsln-table.hh" // Just so we compile it; unused 
otherwise.
 #include "hb-aat-layout-feat-table.hh"
commit 8f80e53341a3d5bac6c2c39ab6d6973eedb0b074
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Wed Dec 5 13:51:14 2018 +0330

    [gasp] Implement the table parsing
    
    May or may not be used in https://github.com/harfbuzz/harfbuzz/pull/1432

diff --git a/src/Makefile.sources b/src/Makefile.sources
index e12d3b55..2eb589f9 100644
--- a/src/Makefile.sources
+++ b/src/Makefile.sources
@@ -59,6 +59,7 @@ HB_BASE_sources = \
        hb-ot-face.cc \
        hb-ot-face.hh \
        hb-ot-font.cc \
+       hb-ot-gasp-table.hh \
        hb-ot-glyf-table.hh \
        hb-ot-hdmx-table.hh \
        hb-ot-head-table.hh \
diff --git a/src/hb-ot-gasp-table.hh b/src/hb-ot-gasp-table.hh
new file mode 100644
index 00000000..73c5b3fc
--- /dev/null
+++ b/src/hb-ot-gasp-table.hh
@@ -0,0 +1,84 @@
+/*
+ * Copyright © 2018  Ebrahim Byagowi
+ *
+ *  This is part of HarfBuzz, a text shaping library.
+ *
+ * Permission is hereby granted, without written agreement and without
+ * license or royalty fees, to use, copy, modify, and distribute this
+ * software and its documentation for any purpose, provided that the
+ * above copyright notice and the following two paragraphs appear in
+ * all copies of this software.
+ *
+ * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
+ * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+ * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
+ * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
+ *
+ * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
+ * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
+ * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
+ * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
+ */
+
+#ifndef HB_OT_GASP_TABLE_HH
+#define HB_OT_GASP_TABLE_HH
+
+#include "hb-open-type.hh"
+#include "hb-ot-hhea-table.hh"
+#include "hb-ot-os2-table.hh"
+#include "hb-ot-var-hvar-table.hh"
+
+/*
+ * gasp -- Grid-fitting and Scan-conversion Procedure
+ * https://docs.microsoft.com/en-us/typography/opentype/spec/gasp
+ */
+#define HB_OT_TAG_gasp HB_TAG('g','a','s','p')
+
+
+namespace OT {
+
+struct GaspRange
+{
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this));
+  }
+
+  public:
+  HBUINT16     rangeMaxPPEM;   /* Upper limit of range, in PPEM */
+  HBUINT16     rangeGaspBehavior;
+                               /* Flags describing desired rasterizer 
behavior. */
+  public:
+  DEFINE_SIZE_STATIC (4);
+};
+
+struct gasp
+{
+  enum { tableTag = HB_OT_TAG_gasp };
+
+  inline const GaspRange &get_gasp_range (unsigned int i) const
+  { return gaspRanges[i]; }
+
+  inline bool sanitize (hb_sanitize_context_t *c) const
+  {
+    TRACE_SANITIZE (this);
+    return_trace (c->check_struct (this) &&
+                 gaspRanges.sanitize (c));
+  }
+
+  protected:
+  HBUINT16     version;        /* Version number (set to 1) */
+  ArrayOf<GaspRange>
+               gaspRanges;     /* Number of records to follow
+                                * Sorted by ppem */
+  public:
+  DEFINE_SIZE_ARRAY (4, gaspRanges);
+};
+
+} /* namespace OT */
+
+
+#endif /* HB_OT_GASP_TABLE_HH */
diff --git a/src/hb-ot-layout.cc b/src/hb-ot-layout.cc
index b08ee7f6..67ce9235 100644
--- a/src/hb-ot-layout.cc
+++ b/src/hb-ot-layout.cc
@@ -35,11 +35,12 @@
 #include "hb-map.hh"
 
 #include "hb-ot-kern-table.hh"
+#include "hb-ot-gasp-table.hh" // Just so we compile it; unused otherwise.
 #include "hb-ot-layout-gdef-table.hh"
 #include "hb-ot-layout-gsub-table.hh"
 #include "hb-ot-layout-gpos-table.hh"
-#include "hb-ot-layout-base-table.hh" // Just so we compile it; unused 
otherwise
-#include "hb-ot-layout-jstf-table.hh" // Just so we compile it; unused 
otherwise
+#include "hb-ot-layout-base-table.hh" // Just so we compile it; unused 
otherwise.
+#include "hb-ot-layout-jstf-table.hh" // Just so we compile it; unused 
otherwise.
 #include "hb-ot-name-table.hh"
 #include "hb-ot-os2-table.hh"
 
commit 79e7e3445efef2dc57f8a10c7e355e802af08868
Merge: cf4b7db6 78f639b8
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Wed Dec 5 13:25:18 2018 +0330

    Merge pull request #1449 from harfbuzz/cff-fixcharset
    
    [CFF] fix for oss-fuzz 11657: Charset overrun

commit cf4b7db6b1e01c11d7a8a26d95cf947935a234a7
Merge: 32cc46c7 803d2f92
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Wed Dec 5 13:23:23 2018 +0330

    Merge pull request #1448 from harfbuzz/cff-leak
    
    [CFF] fix leak: oss-fuzz 11662

commit 32cc46c75a5f163f254b7998ed9193d5bbc85e4b
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 21:32:34 2018 -0800

    [CFF] fix oss-fuzz issue 11670: NULL dereference (#1450)
    
    * guard against no subr access
    
    * code tweak
    
    * add minimized testcase for oss-fuzz 11670 (Null deference)

diff --git a/src/hb-cff-interp-cs-common.hh b/src/hb-cff-interp-cs-common.hh
index 85546fcc..067dc1cc 100644
--- a/src/hb-cff-interp-cs-common.hh
+++ b/src/hb-cff-interp-cs-common.hh
@@ -65,7 +65,7 @@ struct BiasedSubrs
   inline void init (const SUBRS &subrs_)
   {
     subrs = &subrs_;
-    unsigned int  nSubrs = subrs_.count;
+    unsigned int  nSubrs = get_count ();
     if (nSubrs < 1240)
       bias = 107;
     else if (nSubrs < 33900)
@@ -76,8 +76,20 @@ struct BiasedSubrs
 
   inline void fini (void) {}
 
-  const SUBRS   *subrs;
+  inline unsigned int get_count (void) const { return (subrs == nullptr)? 0: 
subrs->count; }
+  inline unsigned int get_bias (void) const { return bias; }
+
+  inline ByteStr operator [] (unsigned int index) const
+  {
+    if (unlikely ((subrs == nullptr) || index >= subrs->count))
+      return Null(ByteStr);
+    else
+      return (*subrs)[index];
+  }
+
+  protected:
   unsigned int  bias;
+  const SUBRS   *subrs;
 };
 
 struct Point
@@ -137,8 +149,8 @@ struct CSInterpEnv : InterpEnv<ARG>
   inline bool popSubrNum (const BiasedSubrs<SUBRS>& biasedSubrs, unsigned int 
&subr_num)
   {
     int n = SUPER::argStack.pop_int ();
-    n += biasedSubrs.bias;
-    if (unlikely ((n < 0) || ((unsigned int)n >= biasedSubrs.subrs->count)))
+    n += biasedSubrs.get_bias ();
+    if (unlikely ((n < 0) || ((unsigned int)n >= biasedSubrs.get_count ())))
       return false;
 
     subr_num = (unsigned int)n;
@@ -158,7 +170,7 @@ struct CSInterpEnv : InterpEnv<ARG>
     context.substr = SUPER::substr;
     callStack.push (context);
 
-    context.init ( (*biasedSubrs.subrs)[subr_num], type, subr_num);
+    context.init ( biasedSubrs[subr_num], type, subr_num);
     SUPER::substr = context.substr;
   }
 
diff --git a/src/hb-ot-cff-common.hh b/src/hb-ot-cff-common.hh
index e824dae3..2c165004 100644
--- a/src/hb-ot-cff-common.hh
+++ b/src/hb-ot-cff-common.hh
@@ -208,7 +208,7 @@ struct CFFIndex
   inline unsigned int data_size (void) const
   { return HBINT8::static_size; }
 
-  ByteStr operator [] (unsigned int index) const
+  inline ByteStr operator [] (unsigned int index) const
   {
     if (likely (index < count))
       return ByteStr (data_base () + offset_at (index) - 1, offset_at (index + 
1) - offset_at (index));
diff --git 
a/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-subset-fuzzer-5672913680728064
 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-subset-fuzzer-5672913680728064
new file mode 100644
index 00000000..fdb5bff2
Binary files /dev/null and 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-subset-fuzzer-5672913680728064
 differ
commit 78f639b8bf508ccfb27224f12442f8e8a1460e08
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 14:17:03 2018 -0800

    added minimized testcase for oss-fuzz issue 11657

diff --git 
a/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5700264032468992
 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5700264032468992
new file mode 100644
index 00000000..82a462bc
Binary files /dev/null and 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5700264032468992
 differ
commit d3d2f32c6e85de1d7fbbb18afef356e09110e61c
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 13:51:26 2018 -0800

    fix oss-fuzz 11657: buffer overrun
    
    Check overrun in Charset1_2::get_glyph

diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh
index 01c0e435..aac66d87 100644
--- a/src/hb-ot-cff1-table.hh
+++ b/src/hb-ot-cff1-table.hh
@@ -392,13 +392,15 @@ struct Charset1_2 {
     return 0;
   }
 
-  inline hb_codepoint_t get_glyph (hb_codepoint_t sid) const
+  inline hb_codepoint_t get_glyph (hb_codepoint_t sid, unsigned int 
num_glyphs) const
   {
     if (sid == 0) return 0;
     hb_codepoint_t  glyph = 1;
     for (unsigned int i = 0;; i++)
     {
-      if ((ranges[i].first <= sid) && sid <= ranges[i].first + ranges[i].nLeft)
+      if (glyph >= num_glyphs)
+       return 0;
+      if ((ranges[i].first <= sid) && (sid <= ranges[i].first + 
ranges[i].nLeft))
        return glyph + (sid - ranges[i].first);
       glyph += (ranges[i].nLeft + 1);
     }
@@ -550,9 +552,9 @@ struct Charset {
     if (format == 0)
       return u.format0.get_glyph (sid, num_glyphs);
     else if (format == 1)
-      return u.format1.get_glyph (sid);
+      return u.format1.get_glyph (sid, num_glyphs);
     else
-      return u.format2.get_glyph (sid);
+      return u.format2.get_glyph (sid, num_glyphs);
   }
 
   HBUINT8       format;
commit d0a250a7b15f1099c2005bc2427d62e7370dcc33
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Tue Dec 4 23:42:13 2018 +0330

    Reuse hb_aat_layout_has_* logic in coretext-aat detection logic (#1442)

diff --git a/src/hb-coretext.cc b/src/hb-coretext.cc
index 15b8c62d..108d15f8 100644
--- a/src/hb-coretext.cc
+++ b/src/hb-coretext.cc
@@ -1163,20 +1163,8 @@ struct hb_coretext_aat_face_data_t {};
 hb_coretext_aat_face_data_t *
 _hb_coretext_aat_shaper_face_data_create (hb_face_t *face)
 {
-  static const hb_tag_t tags[] = {HB_CORETEXT_TAG_MORX, HB_CORETEXT_TAG_MORT, 
HB_CORETEXT_TAG_KERX};
-
-  for (unsigned int i = 0; i < ARRAY_LENGTH (tags); i++)
-  {
-    hb_blob_t *blob = face->reference_table (tags[i]);
-    if (hb_blob_get_length (blob))
-    {
-      hb_blob_destroy (blob);
-      return face->data.coretext ? (hb_coretext_aat_face_data_t *) 
HB_SHAPER_DATA_SUCCEEDED : nullptr;
-    }
-    hb_blob_destroy (blob);
-  }
-
-  return nullptr;
+  return hb_aat_layout_has_substitution (face) || 
hb_aat_layout_has_positioning (face) ?
+        (hb_coretext_aat_face_data_t *) HB_SHAPER_DATA_SUCCEEDED : nullptr;
 }
 
 void
commit 803d2f92dca329a84d92c224a73e13906e8b8d56
Merge: 6ce8d10b c775adc1
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 11:01:26 2018 -0800

    Merge branch 'master' into cff-leak

commit 6ce8d10b45598f5f6dade38e65486f793f33d0b6
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 10:39:17 2018 -0800

    add unlikely to error handling

diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh
index 181b0bc3..dcfebe8d 100644
--- a/src/hb-ot-cff1-table.hh
+++ b/src/hb-ot-cff1-table.hh
@@ -1093,7 +1093,7 @@ struct cff1
          CFF1FontDict_Interpreter font_interp;
          font_interp.env.init (fontDictStr);
          font = fontDicts.push ();
-         if (font == &Crap(CFF1FontDictValues)) { fini (); return; }
+         if (unlikely (font == &Crap(CFF1FontDictValues))) { fini (); return; }
          font->init ();
          if (unlikely (!font_interp.interpret (*font))) { fini (); return; }
          PRIVDICTVAL  *priv = &privateDicts[i];
diff --git a/src/hb-ot-cff2-table.hh b/src/hb-ot-cff2-table.hh
index 330c1a3d..178acf0b 100644
--- a/src/hb-ot-cff2-table.hh
+++ b/src/hb-ot-cff2-table.hh
@@ -486,7 +486,7 @@ struct cff2
        CFF2FontDict_Interpreter font_interp;
        font_interp.env.init (fontDictStr);
        font = fontDicts.push ();
-       if (font == &Crap(CFF2FontDictValues)) { fini (); return; }
+       if (unlikely (font == &Crap(CFF2FontDictValues))) { fini (); return; }
        font->init ();
        if (unlikely (!font_interp.interpret (*font))) { fini (); return; }
 
commit b61f74f69a84f427b40deefefed429fbc915981c
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 10:30:35 2018 -0800

    added minimized test case for oss-fuzz issue 11662

diff --git 
a/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5175735354916864
 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5175735354916864
new file mode 100644
index 00000000..72fdfc6b
Binary files /dev/null and 
b/test/fuzzing/fonts/clusterfuzz-testcase-minimized-hb-shape-fuzzer-5175735354916864
 differ
commit 0b952e6026c8be13d16d97f464034ee477e6282f
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 10:22:35 2018 -0800

    more leak fixes

diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh
index 4221bddf..181b0bc3 100644
--- a/src/hb-ot-cff1-table.hh
+++ b/src/hb-ot-cff1-table.hh
@@ -1133,7 +1133,7 @@ struct cff1
     {
       sc.end_processing ();
       topDict.fini ();
-      fontDicts.fini ();
+      fontDicts.fini_deep ();
       privateDicts.fini_deep ();
       hb_blob_destroy (blob);
       blob = nullptr;
diff --git a/src/hb-ot-cff2-table.hh b/src/hb-ot-cff2-table.hh
index 3c4191cd..330c1a3d 100644
--- a/src/hb-ot-cff2-table.hh
+++ b/src/hb-ot-cff2-table.hh
@@ -486,6 +486,7 @@ struct cff2
        CFF2FontDict_Interpreter font_interp;
        font_interp.env.init (fontDictStr);
        font = fontDicts.push ();
+       if (font == &Crap(CFF2FontDictValues)) { fini (); return; }
        font->init ();
        if (unlikely (!font_interp.interpret (*font))) { fini (); return; }
 
@@ -506,7 +507,7 @@ struct cff2
     inline void fini (void)
     {
       sc.end_processing ();
-      fontDicts.fini ();
+      fontDicts.fini_deep ();
       privateDicts.fini_deep ();
       hb_blob_destroy (blob);
       blob = nullptr;
commit c775adc1383f72f02b1329628b3eba1dc377a0f7
Merge: c968869f 04f2ca94
Author: Ebrahim Byagowi <ebra...@gnu.org>
Date:   Tue Dec 4 21:30:07 2018 +0330

    Merge pull request #1444 from harfbuzz/cff-assert
    
    removed assert, fixes https://github.com/harfbuzz/harfbuzz/issues/1443

commit 9473463f5c884fcb1de8a7ba7410da2601e6ffa8
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 09:58:48 2018 -0800

    fix attempt for oss-fuzz 11662 leak

diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh
index 7bed2636..4221bddf 100644
--- a/src/hb-ot-cff1-table.hh
+++ b/src/hb-ot-cff1-table.hh
@@ -1093,6 +1093,7 @@ struct cff1
          CFF1FontDict_Interpreter font_interp;
          font_interp.env.init (fontDictStr);
          font = fontDicts.push ();
+         if (font == &Crap(CFF1FontDictValues)) { fini (); return; }
          font->init ();
          if (unlikely (!font_interp.interpret (*font))) { fini (); return; }
          PRIVDICTVAL  *priv = &privateDicts[i];
commit 04f2ca94212983d675ed2cd36350be23ff2a6e19
Author: Michiharu Ariza <ar...@adobe.com>
Date:   Tue Dec 4 09:24:07 2018 -0800

    removed assert

diff --git a/src/hb-ot-cff1-table.hh b/src/hb-ot-cff1-table.hh
index 7bed2636..01c0e435 100644
--- a/src/hb-ot-cff1-table.hh
+++ b/src/hb-ot-cff1-table.hh
@@ -654,6 +654,7 @@ struct NameDictValues
   static inline enum NameDictValIndex name_op_to_index (OpCode op)
   {
     switch (op) {
+      default:
       case OpCode_version:
        return version;
       case OpCode_Notice:
@@ -670,8 +671,6 @@ struct NameDictValues
        return postscript;
       case OpCode_FontName:
        return fontName;
-      default:
-       assert (0);
       }
   }
 
_______________________________________________
HarfBuzz mailing list
HarfBuzz@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/harfbuzz

Reply via email to