ae68a7
From 55bbb98f5c5a89230127d6b998a6e23e634b5d0e Mon Sep 17 00:00:00 2001
ae68a7
From: Behdad Esfahbod <behdad@behdad.org>
ae68a7
Date: Tue, 1 Aug 2017 09:17:02 +0200
ae68a7
Subject: [PATCH 077/132] [truetype] Fix loading of named instances.
ae68a7
ae68a7
* src/truetype/ttgxvar.c (TT_Get_MM_Var): Preserve file position
ae68a7
while loading the `avar' table.
ae68a7
---
ae68a7
 ChangeLog               |  7 +++++++
ae68a7
 include/freetype/ftmm.h |  2 +-
ae68a7
 src/truetype/ttgxvar.c  | 11 ++++++++++-
ae68a7
 3 files changed, 18 insertions(+), 2 deletions(-)
ae68a7
ae68a7
diff --git a/src/truetype/ttgxvar.c b/src/truetype/ttgxvar.c
ae68a7
index 68458362e..df42b3bfd 100644
ae68a7
--- a/src/truetype/ttgxvar.c
ae68a7
+++ b/src/truetype/ttgxvar.c
ae68a7
@@ -2136,8 +2136,16 @@
ae68a7
         goto Exit;
ae68a7
 
ae68a7
       if ( fvar_head.instanceCount && !face->blend->avar_loaded )
ae68a7
+      {
ae68a7
+        FT_ULong  offset = FT_STREAM_POS();
ae68a7
+
ae68a7
+
ae68a7
         ft_var_load_avar( face );
ae68a7
 
ae68a7
+        if ( FT_STREAM_SEEK( offset ) )
ae68a7
+          goto Exit;
ae68a7
+      }
ae68a7
+
ae68a7
       ns  = mmvar->namedstyle;
ae68a7
       nsc = face->blend->normalized_stylecoords;
ae68a7
       for ( i = 0; i < fvar_head.instanceCount; i++, ns++ )
ae68a7
@@ -2171,7 +2179,7 @@
ae68a7
         SFNT_Service  sfnt = (SFNT_Service)face->sfnt;
ae68a7
 
ae68a7
         FT_Int   found, dummy1, dummy2;
ae68a7
-        FT_UInt  strid = 0xFFFFFFFFUL;
ae68a7
+        FT_UInt  strid = ~0U;
ae68a7
 
ae68a7
 
ae68a7
         /* the default instance is missing in array the   */
ae68a7
-- 
ae68a7
2.13.5
ae68a7