4c33b1
--- freetype-2.8/builds/unix/unix-cc.in.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/builds/unix/unix-cc.in	2018-06-07 19:16:35.881770695 +0200
4c33b1
@@ -109,6 +109,6 @@ CCexe        := $(CCraw_build)	# used to
4c33b1
 LINK_LIBRARY = $(LIBTOOL) --mode=link $(CCraw) -o $@ $(OBJECTS_LIST) \
4c33b1
                           -rpath $(libdir) -version-info $(version_info) \
4c33b1
                           $(LDFLAGS) -no-undefined \
4c33b1
-                          -export-symbols $(EXPORTS_LIST)
4c33b1
+                          # -export-symbols $(EXPORTS_LIST)
4c33b1
 
4c33b1
 # EOF
4c33b1
--- freetype-2.8/ft2demos-2.8/src/ftview.c.api	2017-05-11 18:31:16.000000000 +0200
4c33b1
+++ freetype-2.8/ft2demos-2.8/src/ftview.c	2018-06-04 16:53:29.960331386 +0200
4c33b1
@@ -1531,8 +1531,8 @@
4c33b1
       case FT_ENCODING_SJIS:
4c33b1
         encoding = "SJIS";
4c33b1
         break;
4c33b1
-      case FT_ENCODING_PRC:
4c33b1
-        encoding = "PRC";
4c33b1
+      case FT_ENCODING_GB2312:
4c33b1
+        encoding = "GB2312";
4c33b1
         break;
4c33b1
       case FT_ENCODING_BIG5:
4c33b1
         encoding = "Big5";
4c33b1
--- freetype-2.8/include/freetype/freetype.h.api	2017-05-13 06:28:40.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/freetype.h	2018-06-04 16:53:29.961331388 +0200
4c33b1
@@ -766,15 +766,14 @@ FT_BEGIN_HEADER
4c33b1
     FT_ENC_TAG( FT_ENCODING_UNICODE,   'u', 'n', 'i', 'c' ),
4c33b1
 
4c33b1
     FT_ENC_TAG( FT_ENCODING_SJIS,    's', 'j', 'i', 's' ),
4c33b1
-    FT_ENC_TAG( FT_ENCODING_PRC,     'g', 'b', ' ', ' ' ),
4c33b1
+    FT_ENC_TAG( FT_ENCODING_GB2312,  'g', 'b', ' ', ' ' ),
4c33b1
     FT_ENC_TAG( FT_ENCODING_BIG5,    'b', 'i', 'g', '5' ),
4c33b1
     FT_ENC_TAG( FT_ENCODING_WANSUNG, 'w', 'a', 'n', 's' ),
4c33b1
     FT_ENC_TAG( FT_ENCODING_JOHAB,   'j', 'o', 'h', 'a' ),
4c33b1
 
4c33b1
     /* for backward compatibility */
4c33b1
-    FT_ENCODING_GB2312     = FT_ENCODING_PRC,
4c33b1
     FT_ENCODING_MS_SJIS    = FT_ENCODING_SJIS,
4c33b1
-    FT_ENCODING_MS_GB2312  = FT_ENCODING_PRC,
4c33b1
+    FT_ENCODING_MS_GB2312  = FT_ENCODING_GB2312,
4c33b1
     FT_ENCODING_MS_BIG5    = FT_ENCODING_BIG5,
4c33b1
     FT_ENCODING_MS_WANSUNG = FT_ENCODING_WANSUNG,
4c33b1
     FT_ENCODING_MS_JOHAB   = FT_ENCODING_JOHAB,
1198db
@@ -799,7 +798,7 @@ FT_BEGIN_HEADER
1198db
 #define ft_encoding_latin_1         FT_ENCODING_ADOBE_LATIN_1
1198db
 #define ft_encoding_latin_2         FT_ENCODING_OLD_LATIN_2
1198db
 #define ft_encoding_sjis            FT_ENCODING_SJIS
1198db
-#define ft_encoding_gb2312          FT_ENCODING_PRC
1198db
+#define ft_encoding_gb2312          FT_ENCODING_GB2312
1198db
 #define ft_encoding_big5            FT_ENCODING_BIG5
1198db
 #define ft_encoding_wansung         FT_ENCODING_WANSUNG
1198db
 #define ft_encoding_johab           FT_ENCODING_JOHAB
4c33b1
--- freetype-2.8/include/freetype/ftcache.h.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/ftcache.h	2018-06-04 16:53:29.961331388 +0200
4c33b1
@@ -667,8 +667,8 @@ FT_BEGIN_HEADER
4c33b1
   typedef struct  FTC_ImageTypeRec_
4c33b1
   {
4c33b1
     FTC_FaceID  face_id;
4c33b1
-    FT_UInt     width;
4c33b1
-    FT_UInt     height;
4c33b1
+    FT_Int      width;
4c33b1
+    FT_Int      height;
4c33b1
     FT_Int32    flags;
4c33b1
 
4c33b1
   } FTC_ImageTypeRec;
4c33b1
--- freetype-2.8/include/freetype/ftimage.h.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/ftimage.h	2018-06-04 16:53:29.962331389 +0200
4c33b1
@@ -260,13 +260,13 @@ FT_BEGIN_HEADER
4c33b1
   /*                                                                       */
4c33b1
   typedef struct  FT_Bitmap_
4c33b1
   {
4c33b1
-    unsigned int    rows;
4c33b1
-    unsigned int    width;
4c33b1
+    int             rows;
4c33b1
+    int             width;
4c33b1
     int             pitch;
4c33b1
     unsigned char*  buffer;
4c33b1
-    unsigned short  num_grays;
4c33b1
-    unsigned char   pixel_mode;
4c33b1
-    unsigned char   palette_mode;
4c33b1
+    short           num_grays;
4c33b1
+    char            pixel_mode;
4c33b1
+    char            palette_mode;
4c33b1
     void*           palette;
4c33b1
 
4c33b1
   } FT_Bitmap;
4c33b1
--- freetype-2.8/include/freetype/ftmm.h.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/ftmm.h	2018-06-04 16:53:29.962331389 +0200
4c33b1
@@ -177,14 +177,10 @@ FT_BEGIN_HEADER
4c33b1
   /*                                                                       */
4c33b1
   /*    strid  :: The entry in `name' table identifying this instance.     */
4c33b1
   /*                                                                       */
4c33b1
-  /*    psid   :: The entry in `name' table identifying a PostScript name  */
4c33b1
-  /*              for this instance.                                       */
4c33b1
-  /*                                                                       */
4c33b1
   typedef struct  FT_Var_Named_Style_
4c33b1
   {
4c33b1
     FT_Fixed*  coords;
4c33b1
     FT_UInt    strid;
4c33b1
-    FT_UInt    psid;   /* since 2.7.1 */
4c33b1
 
4c33b1
   } FT_Var_Named_Style;
4c33b1
 
4c33b1
--- freetype-2.8/include/freetype/ttnameid.h.api	2017-05-03 23:26:45.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/ttnameid.h	2018-06-04 16:53:29.963331391 +0200
4c33b1
@@ -1217,9 +1217,9 @@ FT_BEGIN_HEADER
4c33b1
   /* */
4c33b1
 
4c33b1
   /* for backward compatibility with older FreeType versions */
4c33b1
-#define TT_UCR_ARABIC_PRESENTATION_A         \
4c33b1
+#define TT_UCR_ARABIC_PRESENTATIONS_A         \
4c33b1
           TT_UCR_ARABIC_PRESENTATION_FORMS_A
4c33b1
-#define TT_UCR_ARABIC_PRESENTATION_B         \
4c33b1
+#define TT_UCR_ARABIC_PRESENTATIONS_B         \
4c33b1
           TT_UCR_ARABIC_PRESENTATION_FORMS_B
4c33b1
 
4c33b1
 #define TT_UCR_COMBINING_DIACRITICS          \
4c33b1
--- freetype-2.8/include/freetype/tttables.h.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/tttables.h	2018-06-04 17:18:26.699449088 +0200
4c33b1
@@ -383,7 +383,7 @@ FT_BEGIN_HEADER
4c33b1
     FT_Short   xAvgCharWidth;
4c33b1
     FT_UShort  usWeightClass;
4c33b1
     FT_UShort  usWidthClass;
4c33b1
-    FT_UShort  fsType;
4c33b1
+    FT_Short   fsType;
4c33b1
     FT_Short   ySubscriptXSize;
4c33b1
     FT_Short   ySubscriptYSize;
4c33b1
     FT_Short   ySubscriptXOffset;
4c33b1
@@ -427,11 +427,6 @@ FT_BEGIN_HEADER
4c33b1
     FT_UShort  usBreakChar;
4c33b1
     FT_UShort  usMaxContext;
4c33b1
 
4c33b1
-    /* only version 5 and higher: */
4c33b1
-
4c33b1
-    FT_UShort  usLowerOpticalPointSize;       /* in twips (1/20th points) */
4c33b1
-    FT_UShort  usUpperOpticalPointSize;       /* in twips (1/20th points) */
4c33b1
-
4c33b1
   } TT_OS2;
4c33b1
 
4c33b1
 
4c33b1
@@ -596,43 +591,41 @@ FT_BEGIN_HEADER
4c33b1
   /*    @FT_Get_Sfnt_Table API function.                                   */
4c33b1
   /*                                                                       */
4c33b1
   /* <Values>                                                              */
4c33b1
-  /*    FT_SFNT_HEAD :: To access the font's @TT_Header structure.         */
4c33b1
+  /*    ft_sfnt_head :: To access the font's @TT_Header structure.         */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_MAXP :: To access the font's @TT_MaxProfile structure.     */
4c33b1
+  /*    ft_sfnt_maxp :: To access the font's @TT_MaxProfile structure.     */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_OS2  :: To access the font's @TT_OS2 structure.            */
4c33b1
+  /*    ft_sfnt_os2  :: To access the font's @TT_OS2 structure.            */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_HHEA :: To access the font's @TT_HoriHeader structure.     */
4c33b1
+  /*    ft_sfnt_hhea :: To access the font's @TT_HoriHeader structure.     */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_VHEA :: To access the font's @TT_VertHeader structure.     */
4c33b1
+  /*    ft_sfnt_vhea :: To access the font's @TT_VertHeader structure.     */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_POST :: To access the font's @TT_Postscript structure.     */
4c33b1
+  /*    ft_sfnt_post :: To access the font's @TT_Postscript structure.     */
4c33b1
   /*                                                                       */
4c33b1
-  /*    FT_SFNT_PCLT :: To access the font's @TT_PCLT structure.           */
4c33b1
+  /*    ft_sfnt_pclt :: To access the font's @TT_PCLT structure.           */
4c33b1
   /*                                                                       */
4c33b1
   typedef enum  FT_Sfnt_Tag_
4c33b1
   {
4c33b1
-    FT_SFNT_HEAD,
4c33b1
-    FT_SFNT_MAXP,
4c33b1
-    FT_SFNT_OS2,
4c33b1
-    FT_SFNT_HHEA,
4c33b1
-    FT_SFNT_VHEA,
4c33b1
-    FT_SFNT_POST,
4c33b1
-    FT_SFNT_PCLT,
4c33b1
+    ft_sfnt_head = 0,
4c33b1
+    ft_sfnt_maxp = 1,
4c33b1
+    ft_sfnt_os2  = 2,
4c33b1
+    ft_sfnt_hhea = 3,
4c33b1
+    ft_sfnt_vhea = 4,
4c33b1
+    ft_sfnt_post = 5,
4c33b1
+    ft_sfnt_pclt = 6,
4c33b1
 
4c33b1
-    FT_SFNT_MAX
4c33b1
+    sfnt_max
4c33b1
 
4c33b1
   } FT_Sfnt_Tag;
4c33b1
 
4c33b1
-  /* these constants are deprecated; use the corresponding `FT_Sfnt_Tag' */
4c33b1
-  /* values instead                                                      */
4c33b1
-#define ft_sfnt_head  FT_SFNT_HEAD
4c33b1
-#define ft_sfnt_maxp  FT_SFNT_MAXP
4c33b1
-#define ft_sfnt_os2   FT_SFNT_OS2
4c33b1
-#define ft_sfnt_hhea  FT_SFNT_HHEA
4c33b1
-#define ft_sfnt_vhea  FT_SFNT_VHEA
4c33b1
-#define ft_sfnt_post  FT_SFNT_POST
4c33b1
-#define ft_sfnt_pclt  FT_SFNT_PCLT
4c33b1
+#define FT_SFNT_HEAD ft_sfnt_head
4c33b1
+#define FT_SFNT_MAXP ft_sfnt_maxp
4c33b1
+#define FT_SFNT_OS2  ft_sfnt_os2 
4c33b1
+#define FT_SFNT_HHEA ft_sfnt_hhea
4c33b1
+#define FT_SFNT_VHEA ft_sfnt_vhea
4c33b1
+#define FT_SFNT_POST ft_sfnt_post
4c33b1
+#define FT_SFNT_PCLT ft_sfnt_pclt
4c33b1
 
4c33b1
 
4c33b1
   /*************************************************************************/
4c33b1
--- freetype-2.8/src/sfnt/sfdriver.c.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/sfnt/sfdriver.c	2018-06-04 16:53:29.964331392 +0200
4c33b1
@@ -867,16 +867,9 @@
4c33b1
       SFNT_Service  sfnt = (SFNT_Service)face->sfnt;
4c33b1
 
4c33b1
       FT_Long  instance = ( ( face->root.face_index & 0x7FFF0000L ) >> 16 ) - 1;
4c33b1
-      FT_UInt  psid     = mm_var->namedstyle[instance].psid;
4c33b1
 
4c33b1
       char*  ps_name = NULL;
4c33b1
 
4c33b1
-
4c33b1
-      /* try first to load the name string with index `postScriptNameID' */
4c33b1
-      if ( psid == 6                      ||
4c33b1
-           ( psid > 255 && psid < 32768 ) )
4c33b1
-        (void)sfnt->get_name( face, (FT_UShort)psid, &ps_name );
4c33b1
-
4c33b1
       if ( ps_name )
4c33b1
       {
4c33b1
         result = ps_name;
4c33b1
--- freetype-2.8/src/sfnt/sfobjs.c.api	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/sfnt/sfobjs.c	2018-06-04 16:53:29.964331392 +0200
4c33b1
@@ -311,7 +311,7 @@
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_UCS_4,      FT_ENCODING_UNICODE },
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_UNICODE_CS, FT_ENCODING_UNICODE },
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_SJIS,       FT_ENCODING_SJIS },
4c33b1
-      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_PRC,        FT_ENCODING_PRC },
4c33b1
+      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_GB2312,     FT_ENCODING_GB2312 },
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_BIG_5,      FT_ENCODING_BIG5 },
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_WANSUNG,    FT_ENCODING_WANSUNG },
4c33b1
       { TT_PLATFORM_MICROSOFT,     TT_MS_ID_JOHAB,      FT_ENCODING_JOHAB }
4c33b1
--- freetype-2.8/src/sfnt/ttload.c.api	2017-04-22 07:39:36.000000000 +0200
4c33b1
+++ freetype-2.8/src/sfnt/ttload.c	2018-06-04 16:53:29.965331393 +0200
4c33b1
@@ -1164,15 +1164,6 @@
4c33b1
       FT_FRAME_END
4c33b1
     };
4c33b1
 
4c33b1
-    /* `OS/2' version 5 and newer */
4c33b1
-    static const FT_Frame_Field  os2_fields_extra5[] =
4c33b1
-    {
4c33b1
-      FT_FRAME_START( 4 ),
4c33b1
-        FT_FRAME_USHORT( usLowerOpticalPointSize ),
4c33b1
-        FT_FRAME_USHORT( usUpperOpticalPointSize ),
4c33b1
-      FT_FRAME_END
4c33b1
-    };
4c33b1
-
4c33b1
 
4c33b1
     /* We now support old Mac fonts where the OS/2 table doesn't  */
4c33b1
     /* exist.  Simply put, we set the `version' field to 0xFFFF   */
4c33b1
@@ -1193,8 +1184,6 @@
4c33b1
     os2->usDefaultChar           = 0;
4c33b1
     os2->usBreakChar             = 0;
4c33b1
     os2->usMaxContext            = 0;
4c33b1
-    os2->usLowerOpticalPointSize = 0;
4c33b1
-    os2->usUpperOpticalPointSize = 0xFFFF;
4c33b1
 
4c33b1
     if ( os2->version >= 0x0001 )
4c33b1
     {
4c33b1
@@ -1207,13 +1196,6 @@
4c33b1
         /* only version 2 tables */
4c33b1
         if ( FT_STREAM_READ_FIELDS( os2_fields_extra2, os2 ) )
4c33b1
           goto Exit;
4c33b1
-
4c33b1
-        if ( os2->version >= 0x0005 )
4c33b1
-        {
4c33b1
-          /* only version 5 tables */
4c33b1
-          if ( FT_STREAM_READ_FIELDS( os2_fields_extra5, os2 ) )
4c33b1
-            goto Exit;
4c33b1
-        }
4c33b1
       }
4c33b1
     }
4c33b1
 
4c33b1
--- freetype-2.8/src/truetype/ttgxvar.c.api	2017-05-02 14:37:55.000000000 +0200
4c33b1
+++ freetype-2.8/src/truetype/ttgxvar.c	2018-06-04 16:53:29.966331395 +0200
4c33b1
@@ -2155,7 +2155,7 @@
4c33b1
           *c = FT_GET_LONG();
4c33b1
 
4c33b1
         if ( usePsName )
4c33b1
-          ns->psid = FT_GET_USHORT();
4c33b1
+          (void) FT_GET_USHORT();
4c33b1
 
4c33b1
         ft_var_to_normalized( face,
4c33b1
                               fvar_head.axisCount,
4c33b1
@@ -2206,7 +2206,6 @@
4c33b1
             ns = &mmvar->namedstyle[fvar_head.instanceCount];
4c33b1
 
4c33b1
             ns->strid = strid;
4c33b1
-            ns->psid  = TT_NAME_ID_PS_NAME;
4c33b1
 
4c33b1
             a = mmvar->axis;
4c33b1
             c = ns->coords;
4c33b1
--- freetype-2.8/devel/ftoption.h.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/devel/ftoption.h	2018-06-07 11:30:34.431455285 +0200
4c33b1
@@ -903,7 +903,7 @@ FT_BEGIN_HEADER
4c33b1
    * This macro is obsolete.  Support has been removed in FreeType
4c33b1
    * version 2.5.
4c33b1
    */
4c33b1
-/* #define FT_CONFIG_OPTION_OLD_INTERNALS */
4c33b1
+#define FT_CONFIG_OPTION_OLD_INTERNALS
4c33b1
 
4c33b1
 
4c33b1
   /*
4c33b1
--- freetype-2.8/include/freetype/config/ftoption.h.orig	2017-05-01 09:39:06.000000000 +0200
4c33b1
+++ freetype-2.8/include/freetype/config/ftoption.h	2018-06-07 11:30:53.662506048 +0200
4c33b1
@@ -934,7 +934,7 @@ FT_BEGIN_HEADER
4c33b1
    * This macro is obsolete.  Support has been removed in FreeType
4c33b1
    * version 2.5.
4c33b1
    */
4c33b1
-/* #define FT_CONFIG_OPTION_OLD_INTERNALS */
4c33b1
+#define FT_CONFIG_OPTION_OLD_INTERNALS
4c33b1
 
4c33b1
 
4c33b1
   /*
4c33b1
--- freetype-2.8/include/freetype/ftcache.h.orig	2018-06-07 11:33:07.663882169 +0200
4c33b1
+++ freetype-2.8/include/freetype/ftcache.h	2018-06-07 11:33:23.127947502 +0200
4c33b1
@@ -1049,6 +1049,54 @@ FT_BEGIN_HEADER
4c33b1
   /* */
4c33b1
 
4c33b1
 
4c33b1
+#ifdef FT_CONFIG_OPTION_OLD_INTERNALS
4c33b1
+
4c33b1
+  /*@***********************************************************************/
4c33b1
+  /*                                                                       */
4c33b1
+  /* <Struct>                                                              */
4c33b1
+  /*    FTC_FontRec                                                        */
4c33b1
+  /*                                                                       */
4c33b1
+  /* <Description>                                                         */
4c33b1
+  /*    A simple structure used to describe a given `font' to the cache    */
4c33b1
+  /*    manager.  Note that a `font' is the combination of a given face    */
4c33b1
+  /*    with a given character size.                                       */
4c33b1
+  /*                                                                       */
4c33b1
+  /* <Fields>                                                              */
4c33b1
+  /*    face_id    :: The ID of the face to use.                           */
4c33b1
+  /*                                                                       */
4c33b1
+  /*    pix_width  :: The character width in integer pixels.               */
4c33b1
+  /*                                                                       */
4c33b1
+  /*    pix_height :: The character height in integer pixels.              */
4c33b1
+  /*                                                                       */
4c33b1
+  typedef struct  FTC_FontRec_
4c33b1
+  {
4c33b1
+    FTC_FaceID  face_id;
4c33b1
+    FT_UShort   pix_width;
4c33b1
+    FT_UShort   pix_height;
4c33b1
+
4c33b1
+  } FTC_FontRec;
4c33b1
+
4c33b1
+
4c33b1
+  /* */
4c33b1
+
4c33b1
+
4c33b1
+  typedef FTC_FontRec*  FTC_Font;
4c33b1
+
4c33b1
+
4c33b1
+  FT_EXPORT( FT_Error )
4c33b1
+  FTC_Manager_Lookup_Face( FTC_Manager  manager,
4c33b1
+                           FTC_FaceID   face_id,
4c33b1
+                           FT_Face     *aface );
4c33b1
+
4c33b1
+  FT_EXPORT( FT_Error )
4c33b1
+  FTC_Manager_Lookup_Size( FTC_Manager  manager,
4c33b1
+                           FTC_Font     font,
4c33b1
+                           FT_Face     *aface,
4c33b1
+                           FT_Size     *asize );
4c33b1
+
4c33b1
+#endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
4c33b1
+
4c33b1
+
4c33b1
 FT_END_HEADER
4c33b1
 
4c33b1
 #endif /* FTCACHE_H_ */
4c33b1
--- freetype-2.8/src/cache/ftcmanag.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/cache/ftcmanag.c	2018-06-07 11:28:18.663096906 +0200
4c33b1
@@ -701,4 +701,55 @@
4c33b1
   }
4c33b1
 
4c33b1
 
4c33b1
+#ifdef FT_CONFIG_OPTION_OLD_INTERNALS
4c33b1
+
4c33b1
+  FT_EXPORT_DEF( FT_Error )
4c33b1
+  FTC_Manager_Lookup_Face( FTC_Manager  manager,
4c33b1
+                           FTC_FaceID   face_id,
4c33b1
+                           FT_Face     *aface )
4c33b1
+  {
4c33b1
+    return FTC_Manager_LookupFace( manager, face_id, aface );
4c33b1
+  }
4c33b1
+
4c33b1
+
4c33b1
+  FT_EXPORT( FT_Error )
4c33b1
+  FTC_Manager_Lookup_Size( FTC_Manager  manager,
4c33b1
+                           FTC_Font     font,
4c33b1
+                           FT_Face     *aface,
4c33b1
+                           FT_Size     *asize )
4c33b1
+  {
4c33b1
+    FTC_ScalerRec  scaler;
4c33b1
+    FT_Error       error;
4c33b1
+    FT_Size        size;
4c33b1
+    FT_Face        face;
4c33b1
+
4c33b1
+
4c33b1
+    scaler.face_id = font->face_id;
4c33b1
+    scaler.width   = font->pix_width;
4c33b1
+    scaler.height  = font->pix_height;
4c33b1
+    scaler.pixel   = TRUE;
4c33b1
+    scaler.x_res   = 0;
4c33b1
+    scaler.y_res   = 0;
4c33b1
+
4c33b1
+    error = FTC_Manager_LookupSize( manager, &scaler, &size );
4c33b1
+    if ( error )
4c33b1
+    {
4c33b1
+      face = NULL;
4c33b1
+      size = NULL;
4c33b1
+    }
4c33b1
+    else
4c33b1
+      face = size->face;
4c33b1
+
4c33b1
+    if ( aface )
4c33b1
+      *aface = face;
4c33b1
+
4c33b1
+    if ( asize )
4c33b1
+      *asize = size;
4c33b1
+
4c33b1
+    return error;
4c33b1
+  }
4c33b1
+
4c33b1
+#endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
4c33b1
+
4c33b1
+
4c33b1
 /* END */
4c33b1
--- freetype-2.8/ft2demos-2.8/graph/x11/grx11.c.orig	2016-10-19 06:55:23.000000000 +0200
4c33b1
+++ freetype-2.8/ft2demos-2.8/graph/x11/grx11.c	2018-06-07 16:41:52.626432650 +0200
4c33b1
@@ -1404,8 +1404,8 @@ typedef  unsigned long   uint32;
4c33b1
                                     RootWindow( display, screen ),
4c33b1
                                     0,
4c33b1
                                     0,
4c33b1
-                                    (unsigned int)bitmap->width,
4c33b1
-                                    (unsigned int)bitmap->rows,
4c33b1
+                                    bitmap->width,
4c33b1
+                                    bitmap->rows,
4c33b1
                                     10,
4c33b1
                                     format->x_depth,
4c33b1
                                     InputOutput,
4c33b1
--- freetype-2.8/src/base/ftbitmap.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/base/ftbitmap.c	2018-06-07 18:26:08.488060315 +0200
4c33b1
@@ -90,7 +90,7 @@
4c33b1
 
4c33b1
     if ( pitch < 0 )
4c33b1
       pitch = -pitch;
4c33b1
-    size = (FT_ULong)pitch * source->rows;
4c33b1
+    size = (FT_ULong)( pitch * source->rows );
4c33b1
 
4c33b1
     if ( target->buffer )
4c33b1
     {
4c33b1
@@ -100,7 +100,7 @@
4c33b1
 
4c33b1
       if ( target_pitch < 0 )
4c33b1
         target_pitch = -target_pitch;
4c33b1
-      target_size = (FT_ULong)target_pitch * target->rows;
4c33b1
+      target_size = (FT_ULong)( target_pitch * target->rows );
4c33b1
 
4c33b1
       if ( target_size != size )
4c33b1
         (void)FT_QREALLOC( target->buffer, target_size, size );
4c33b1
@@ -156,7 +156,7 @@
4c33b1
     int             pitch;
4c33b1
     int             new_pitch;
4c33b1
     FT_UInt         bpp;
4c33b1
-    FT_UInt         i, width, height;
4c33b1
+    FT_Int          i, width, height;
4c33b1
     unsigned char*  buffer = NULL;
4c33b1
 
4c33b1
 
4c33b1
@@ -194,17 +194,17 @@
4c33b1
     if ( ypixels == 0 && new_pitch <= pitch )
4c33b1
     {
4c33b1
       /* zero the padding */
4c33b1
-      FT_UInt  bit_width = (FT_UInt)pitch * 8;
4c33b1
-      FT_UInt  bit_last  = ( width + xpixels ) * bpp;
4c33b1
+      FT_Int  bit_width = pitch * 8;
4c33b1
+      FT_Int  bit_last  = ( width + xpixels ) * bpp;
4c33b1
 
4c33b1
 
4c33b1
       if ( bit_last < bit_width )
4c33b1
       {
4c33b1
         FT_Byte*  line  = bitmap->buffer + ( bit_last >> 3 );
4c33b1
         FT_Byte*  end   = bitmap->buffer + pitch;
4c33b1
-        FT_UInt   shift = bit_last & 7;
4c33b1
+        FT_Int    shift = bit_last & 7;
4c33b1
         FT_UInt   mask  = 0xFF00U >> shift;
4c33b1
-        FT_UInt   count = height;
4c33b1
+        FT_Int    count = height;
4c33b1
 
4c33b1
 
4c33b1
         for ( ; count > 0; count--, line += pitch, end += pitch )
4c33b1
@@ -233,7 +233,7 @@
4c33b1
     /* thus take care of the flow direction         */
4c33b1
     if ( bitmap->pitch > 0 )
4c33b1
     {
4c33b1
-      FT_UInt  len = ( width * bpp + 7 ) >> 3;
4c33b1
+      FT_Int  len = ( width * bpp + 7 ) >> 3;
4c33b1
 
4c33b1
 
4c33b1
       for ( i = 0; i < bitmap->rows; i++ )
4c33b1
@@ -243,7 +243,7 @@
4c33b1
     }
4c33b1
     else
4c33b1
     {
4c33b1
-      FT_UInt  len = ( width * bpp + 7 ) >> 3;
4c33b1
+      FT_Int  len = ( width * bpp + 7 ) >> 3;
4c33b1
 
4c33b1
 
4c33b1
       for ( i = 0; i < bitmap->rows; i++ )
4c33b1
@@ -275,8 +275,7 @@
4c33b1
   {
4c33b1
     FT_Error        error;
4c33b1
     unsigned char*  p;
4c33b1
-    FT_Int          i, x, pitch;
4c33b1
-    FT_UInt         y;
4c33b1
+    FT_Int          i, x, y, pitch;
4c33b1
     FT_Int          xstr, ystr;
4c33b1
 
4c33b1
 
4c33b1
@@ -420,8 +419,8 @@
4c33b1
       p += bitmap->pitch;
4c33b1
     }
4c33b1
 
4c33b1
-    bitmap->width += (FT_UInt)xstr;
4c33b1
-    bitmap->rows += (FT_UInt)ystr;
4c33b1
+    bitmap->width += xstr;
4c33b1
+    bitmap->rows += ystr;
4c33b1
 
4c33b1
     return FT_Err_Ok;
4c33b1
   }
4c33b1
@@ -506,8 +505,8 @@
4c33b1
     case FT_PIXEL_MODE_LCD_V:
4c33b1
     case FT_PIXEL_MODE_BGRA:
4c33b1
       {
4c33b1
-        FT_Int    pad, old_target_pitch, target_pitch;
4c33b1
-        FT_ULong  old_size;
4c33b1
+        FT_Int   pad, old_target_pitch, target_pitch;
4c33b1
+        FT_Long  old_size;
4c33b1
 
4c33b1
 
4c33b1
         old_target_pitch = target->pitch;
4c33b1
@@ -617,7 +616,7 @@
4c33b1
     case FT_PIXEL_MODE_LCD:
4c33b1
     case FT_PIXEL_MODE_LCD_V:
4c33b1
       {
4c33b1
-        FT_UInt  width = source->width;
4c33b1
+        FT_Int   width = source->width;
4c33b1
         FT_UInt  i;
4c33b1
 
4c33b1
 
4c33b1
--- freetype-2.8/src/pcf/pcfdrivr.c.orig	2018-06-07 11:42:57.757375204 +0200
4c33b1
+++ freetype-2.8/src/pcf/pcfdrivr.c	2018-06-07 16:59:25.832896549 +0200
4c33b1
@@ -523,10 +523,10 @@ THE SOFTWARE.
4c33b1
 
4c33b1
     metric = face->metrics + glyph_index;
4c33b1
 
4c33b1
-    bitmap->rows       = (unsigned int)( metric->ascent +
4c33b1
-                                         metric->descent );
4c33b1
-    bitmap->width      = (unsigned int)( metric->rightSideBearing -
4c33b1
-                                         metric->leftSideBearing );
4c33b1
+    bitmap->rows       = ( metric->ascent +
4c33b1
+                           metric->descent );
4c33b1
+    bitmap->width      = ( metric->rightSideBearing -
4c33b1
+                           metric->leftSideBearing );
4c33b1
     bitmap->num_grays  = 1;
4c33b1
     bitmap->pixel_mode = FT_PIXEL_MODE_MONO;
4c33b1
 
4c33b1
--- freetype-2.8/src/raster/ftraster.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/raster/ftraster.c	2018-06-07 18:07:14.977278387 +0200
4c33b1
@@ -2479,7 +2479,7 @@
4c33b1
       {
4c33b1
         e1 = TRUNC( e1 );
4c33b1
 
4c33b1
-        if ( e1 >= 0 && (ULong)e1 < ras.target.rows )
4c33b1
+        if ( e1 >= 0 && e1 < ras.target.rows )
4c33b1
         {
4c33b1
           Byte   f1;
4c33b1
           PByte  bits;
4c33b1
@@ -2589,7 +2589,7 @@
4c33b1
         /* bounding box instead                                           */
4c33b1
         if ( pxl < 0 )
4c33b1
           pxl = e1;
4c33b1
-        else if ( (ULong)( TRUNC( pxl ) ) >= ras.target.rows )
4c33b1
+        else if ( ( TRUNC( pxl ) ) >= ras.target.rows )
4c33b1
           pxl = e2;
4c33b1
 
4c33b1
         /* check that the other pixel isn't set */
4c33b1
@@ -2604,9 +2604,9 @@
4c33b1
         if ( ras.target.pitch > 0 )
4c33b1
           bits += (Long)( ras.target.rows - 1 ) * ras.target.pitch;
4c33b1
 
4c33b1
-        if ( e1 >= 0                     &&
4c33b1
-             (ULong)e1 < ras.target.rows &&
4c33b1
-             *bits & f1                  )
4c33b1
+        if ( e1 >= 0              &&
4c33b1
+             e1 < ras.target.rows &&
4c33b1
+             *bits & f1           )
4c33b1
           goto Exit;
4c33b1
       }
4c33b1
       else
4c33b1
@@ -2615,7 +2615,7 @@
4c33b1
 
4c33b1
     e1 = TRUNC( pxl );
4c33b1
 
4c33b1
-    if ( e1 >= 0 && (ULong)e1 < ras.target.rows )
4c33b1
+    if ( e1 >= 0 && e1 < ras.target.rows )
4c33b1
     {
4c33b1
       FT_TRACE7(( " -> y=%d (drop-out)", e1 ));
4c33b1
 
4c33b1
--- freetype-2.8/src/sfnt/pngshim.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/sfnt/pngshim.c	2018-06-07 18:08:07.825359421 +0200
4c33b1
@@ -209,10 +209,10 @@
4c33b1
     }
4c33b1
 
4c33b1
     if ( !populate_map_and_metrics                            &&
4c33b1
-         ( (FT_UInt)x_offset + metrics->width  > map->width ||
4c33b1
-           (FT_UInt)y_offset + metrics->height > map->rows  ||
4c33b1
-           pix_bits != 32                                   ||
4c33b1
-           map->pixel_mode != FT_PIXEL_MODE_BGRA            ) )
4c33b1
+         ( x_offset + metrics->width  > map->width ||
4c33b1
+           y_offset + metrics->height > map->rows  ||
4c33b1
+           pix_bits != 32                          ||
4c33b1
+           map->pixel_mode != FT_PIXEL_MODE_BGRA   ) )
4c33b1
     {
4c33b1
       error = FT_THROW( Invalid_Argument );
4c33b1
       goto Exit;
4c33b1
@@ -270,7 +270,7 @@
4c33b1
       map->num_grays  = 256;
4c33b1
 
4c33b1
       /* reject too large bitmaps similarly to the rasterizer */
4c33b1
-      if ( map->rows > 0x7FFF || map->width > 0x7FFF )
4c33b1
+      if ( map->rows > 0x4FFF || map->width > 0x4FFF )
4c33b1
       {
4c33b1
         error = FT_THROW( Array_Too_Large );
4c33b1
         goto DestroyExit;
4c33b1
@@ -346,7 +346,7 @@
4c33b1
 
4c33b1
     if ( populate_map_and_metrics )
4c33b1
     {
4c33b1
-      /* this doesn't overflow: 0x7FFF * 0x7FFF * 4 < 2^32 */
4c33b1
+      /* this doesn't overflow: 0x4FFF * 0x4FFF * 4 < 2^31 */
4c33b1
       FT_ULong  size = map->rows * (FT_ULong)map->pitch;
4c33b1
 
4c33b1
 
4c33b1
--- freetype-2.8/src/sfnt/ttsbit.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/sfnt/ttsbit.c	2018-06-07 18:31:57.610612501 +0200
4c33b1
@@ -705,7 +705,7 @@
4c33b1
     FT_Error    error = FT_Err_Ok;
4c33b1
     FT_Byte*    line;
4c33b1
     FT_Int      pitch, width, height, line_bits, h;
4c33b1
-    FT_UInt     bit_height, bit_width;
4c33b1
+    FT_Int      bit_height, bit_width;
4c33b1
     FT_Bitmap*  bitmap;
4c33b1
 
4c33b1
     FT_UNUSED( recurse_count );
4c33b1
--- freetype-2.8/src/smooth/ftgrays.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/smooth/ftgrays.c	2018-06-07 17:01:09.008070697 +0200
4c33b1
@@ -1880,7 +1880,7 @@ typedef ptrdiff_t  FT_PtrDist;
4c33b1
         ras.target.origin = target_map->buffer;
4c33b1
       else
4c33b1
         ras.target.origin = target_map->buffer
4c33b1
-              + ( target_map->rows - 1 ) * (unsigned int)target_map->pitch;
4c33b1
+              + (unsigned int) (( target_map->rows - 1 ) * target_map->pitch);
4c33b1
 
4c33b1
       ras.target.pitch = target_map->pitch;
4c33b1
 
4c33b1
--- freetype-2.8/src/smooth/ftsmooth.c.orig	2017-05-01 09:35:12.000000000 +0200
4c33b1
+++ freetype-2.8/src/smooth/ftsmooth.c	2018-06-07 17:01:51.040141641 +0200
4c33b1
@@ -292,8 +292,8 @@
4c33b1
 
4c33b1
     bitmap->pixel_mode = FT_PIXEL_MODE_GRAY;
4c33b1
     bitmap->num_grays  = 256;
4c33b1
-    bitmap->width      = (unsigned int)width;
4c33b1
-    bitmap->rows       = (unsigned int)height;
4c33b1
+    bitmap->width      = width;
4c33b1
+    bitmap->rows       = height;
4c33b1
     bitmap->pitch      = pitch;
4c33b1
 
4c33b1
     /* translate outline to render it into the bitmap */
4c33b1
--- freetype-2.8/src/winfonts/winfnt.c.orig	2017-03-30 12:20:23.000000000 +0200
4c33b1
+++ freetype-2.8/src/winfonts/winfnt.c	2018-06-07 18:21:47.809648016 +0200
4c33b1
@@ -1038,7 +1038,7 @@
4c33b1
 
4c33b1
     p = font->fnt_frame + offset;
4c33b1
 
4c33b1
-    bitmap->width = FT_NEXT_USHORT_LE( p );
4c33b1
+    bitmap->width = FT_NEXT_SHORT_LE( p );
4c33b1
 
4c33b1
     /* jump to glyph entry */
4c33b1
     if ( new_format )
4c33b1
@@ -1079,7 +1079,7 @@
4c33b1
     /* allocate and build bitmap */
4c33b1
     {
4c33b1
       FT_Memory  memory = FT_FACE_MEMORY( slot->face );
4c33b1
-      FT_UInt    pitch  = ( bitmap->width + 7 ) >> 3;
4c33b1
+      FT_Int     pitch  = ( bitmap->width + 7 ) >> 3;
4c33b1
       FT_Byte*   column;
4c33b1
       FT_Byte*   write;
4c33b1