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.
--- 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 ) );