From 300c7307eb7943ba7416b672345506be1e27c6ba Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Mon, 30 Jul 2012 19:37:44 -0400 Subject: [PATCH] [OT] Don't crash if no GDEF available --- src/hb-ot-layout-gsubgpos-private.hh | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/hb-ot-layout-gsubgpos-private.hh b/src/hb-ot-layout-gsubgpos-private.hh index 00c64d5f7..4324d6d18 100644 --- a/src/hb-ot-layout-gsubgpos-private.hh +++ b/src/hb-ot-layout-gsubgpos-private.hh @@ -183,8 +183,8 @@ struct hb_apply_context_t unsigned int lookup_props; unsigned int property; /* propety of first glyph */ unsigned int debug_depth; - bool has_glyph_classes; const GDEF &gdef; + bool has_glyph_classes; hb_apply_context_t (hb_font_t *font_, @@ -196,8 +196,10 @@ struct hb_apply_context_t lookup_mask (lookup_mask_), nesting_level_left (MAX_NESTING_LEVEL), lookup_props (0), property (0), debug_depth (0), - has_glyph_classes (hb_ot_layout_has_glyph_classes (face_)), - gdef (*hb_ot_layout_from_face (face_)->gdef /* XXX Unsafe dereference */) {} + gdef (hb_ot_layout_from_face (face_) && + !HB_SHAPER_DATA_IS_INVALID (hb_ot_layout_from_face (face_)) ? + *hb_ot_layout_from_face (face_)->gdef : Null(GDEF)), + has_glyph_classes (gdef.has_glyph_classes ()) {} void set_lookup (const Lookup &l) { lookup_props = l.get_props ();