shithub: freetype+ttf2subf

Download patch

ref: 999a75b6dbfd24349b720fe6f600c37e8406f49e
parent: 0e53cf6d67d0022c2bcd62370d8ce1d90e9117b9
author: Ewald Hew <[email protected]>
date: Mon Sep 25 04:16:59 EDT 2017

Minor fixes.

* src/psaux/psintrp.c (cf2_interpT2CharString): Fix check for pop
results.
s/font->decoder/decoder/ where necessary.
<cf2_cmdHSTEM, cf2_cmdVSTEM, cf2_escHSTEM3, cf2_escVSTEM3>: Use
offset parameter in `cf2_doStems' instead of doing correction for
left-sidebearing.

git/fs: mount .git/fs: mount/attach disallowed
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,16 @@
 2017-09-25  Ewald Hew  <[email protected]>
 
+	[psaux] Minor fixes.
+
+	* src/psaux/psintrp.c (cf2_interpT2CharString): Fix check for pop
+	results.
+	s/font->decoder/decoder/ where necessary.
+	<cf2_cmdHSTEM, cf2_cmdVSTEM, cf2_escHSTEM3, cf2_escVSTEM3>: Use
+	offset parameter in `cf2_doStems' instead of doing correction for
+	left-sidebearing.
+
+2017-09-25  Ewald Hew  <[email protected]>
+
 	[cid] Use the new engine.
 
 	* src/cid/cidgload.c: Update includes.
--- a/src/psaux/psintrp.c
+++ b/src/psaux/psintrp.c
@@ -653,7 +653,7 @@
         if ( result_cnt > 0 &&
              !( op1 == cf2_cmdCALLSUBR ||
                 op1 == cf2_cmdRETURN   ||
-                op1 == cf2_escPOP      ||
+                op1 == cf2_cmdESC      ||
                 op1 >= 32 /* Numbers */ ) )
         {
           /* all operands have been transferred by previous pops */
@@ -771,27 +771,16 @@
             break;
           }
         }
-        else
-        {
-          /* Do lsb correction */
-          CF2_F16Dot16  hint_pos;
 
-          FT_ASSERT( ( cf2_stack_count( opStack ) == 2 ) );
-
-          hint_pos = ADD_INT32( cf2_stack_getReal( opStack, 0 ),
-                                decoder->builder.left_bearing->y );
-
-          cf2_stack_setReal( opStack, 0, hint_pos );
-        }
-
         cf2_doStems( font,
                      opStack,
                      &hStemHintArray,
                      width,
                      &haveWidth,
-                     0 );
+                     font->isT1 ? decoder->builder.left_bearing->y
+                                : 0 );
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         break;
@@ -811,27 +800,16 @@
             break;
           }
         }
-        else
-        {
-          /* Do lsb correction */
-          CF2_F16Dot16  hint_pos;
 
-          FT_ASSERT( ( cf2_stack_count( opStack ) == 2 ) );
-
-          hint_pos = ADD_INT32( cf2_stack_getReal( opStack, 0 ),
-                                decoder->builder.left_bearing->x );
-
-          cf2_stack_setReal( opStack, 0, hint_pos );
-        }
-
         cf2_doStems( font,
                      opStack,
                      &vStemHintArray,
                      width,
                      &haveWidth,
-                     0 );
+                     font->isT1 ? decoder->builder.left_bearing->x
+                                : 0 );
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         break;
@@ -852,7 +830,7 @@
         /* width is defined or default after this */
         haveWidth = TRUE;
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         curY = ADD_INT32( curY, cf2_stack_popFixed( opStack ) );
@@ -1180,6 +1158,9 @@
             {
               if ( font->isCFF2 || op2 >= cf2_escRESERVED_38 )
                 FT_TRACE4(( " unknown op (12, %d)\n", op2 ));
+              else if ( font->isT1 && result_cnt > 0 && op2 != cf2_escPOP )
+                /* all operands have been transferred by previous pops */
+                result_cnt = 0;
               else
               {
                 /* second switch for 2-byte operators handles CFF and Type 1 */
@@ -1204,23 +1185,19 @@
                     else
                     {
                       CF2_F16Dot16  v0, v1, v2;
-                      CF2_F16Dot16  lsb;
 
-                      FT_TRACE4(( op2 == cf2_escVSTEM3 ? " vstem3\n"
-                                                       : " hstem3\n" ));
+                      FT_Bool isV = FT_BOOL( op2 == cf2_escVSTEM3 );
 
-                      FT_ASSERT( ( cf2_stack_count( opStack ) == 6 ) );
 
-                      lsb = ( op2 == cf2_escVSTEM3 ? decoder->builder.left_bearing->x
-                                                   : decoder->builder.left_bearing->y );
+                      FT_TRACE4(( isV ? " vstem3\n"
+                                      : " hstem3\n" ));
 
+                      FT_ASSERT( ( cf2_stack_count( opStack ) == 6 ) );
+
                       v0 = cf2_stack_getReal( opStack, 0 );
                       v1 = cf2_stack_getReal( opStack, 2 );
                       v2 = cf2_stack_getReal( opStack, 4 );
 
-                      cf2_stack_setReal( opStack, 0,
-                                         ADD_INT32( v0,
-                                                    lsb ) );
                       cf2_stack_setReal( opStack, 2,
                                          SUB_INT32( SUB_INT32( v1, v0 ),
                                                     cf2_stack_getReal( opStack, 1 ) ) );
@@ -1230,10 +1207,11 @@
 
                       cf2_doStems( font,
                                    opStack,
-                                   op2 == cf2_escVSTEM3 ? &vStemHintArray : &hStemHintArray,
+                                   isV ? &vStemHintArray : &hStemHintArray,
                                    width,
                                    &haveWidth,
-                                   0 );
+                                   isV ? decoder->builder.left_bearing->x
+                                       : decoder->builder.left_bearing->y );
 
                       if ( decoder->width_only )
                         goto exit;
@@ -2391,7 +2369,7 @@
         /* width is defined or default after this */
         haveWidth = TRUE;
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         /* close path if still open */
@@ -2479,7 +2457,7 @@
                      &haveWidth,
                      0 );
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         if ( op1 == cf2_cmdHINTMASK )
@@ -2545,7 +2523,7 @@
         /* width is defined or default after this */
         haveWidth = TRUE;
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         curY = ADD_INT32( curY, cf2_stack_popFixed( opStack ) );
@@ -2572,7 +2550,7 @@
         /* width is defined or default after this */
         haveWidth = TRUE;
 
-        if ( font->decoder->width_only )
+        if ( decoder->width_only )
           goto exit;
 
         curX = ADD_INT32( curX, cf2_stack_popFixed( opStack ) );