* src/truetype/ttinterp.c (Ins_JROT, Ins_JROF): Simplify.

Based on a patch from Behdad.
2.6.5
Werner Lemberg 10 years ago
parent 628578c655
commit ea173c0493
  1. 6
      ChangeLog
  2. 50
      src/truetype/ttinterp.c

@ -1,3 +1,9 @@
2015-01-11 Werner Lemberg <wl@gnu.org>
* src/truetype/ttinterp.c (Ins_JROT, Ins_JROF): Simplify.
Based on a patch from Behdad.
2015-01-11 Werner Lemberg <wl@gnu.org>
* src/truetype/ttinterp.c (Ins_SxVTL): Simplify function call.

@ -3346,30 +3346,6 @@
}
/*************************************************************************/
/* */
/* JROT[]: Jump Relative On True */
/* Opcode range: 0x78 */
/* Stack: StkElt int32 --> */
/* */
static void
Ins_JROT( TT_ExecContext exc,
FT_Long* args )
{
if ( args[1] != 0 )
{
if ( args[0] == 0 && exc->args == 0 )
exc->error = FT_THROW( Bad_Argument );
exc->IP += args[0];
if ( exc->IP < 0 ||
( exc->callTop > 0 &&
exc->IP > exc->callStack[exc->callTop - 1].Def->end ) )
exc->error = FT_THROW( Bad_Argument );
exc->step_ins = FALSE;
}
}
/*************************************************************************/
/* */
/* JMPR[]: JuMP Relative */
@ -3391,6 +3367,21 @@
}
/*************************************************************************/
/* */
/* JROT[]: Jump Relative On True */
/* Opcode range: 0x78 */
/* Stack: StkElt int32 --> */
/* */
static void
Ins_JROT( TT_ExecContext exc,
FT_Long* args )
{
if ( args[1] != 0 )
Ins_JMPR( exc, args );
}
/*************************************************************************/
/* */
/* JROF[]: Jump Relative On False */
@ -3402,16 +3393,7 @@
FT_Long* args )
{
if ( args[1] == 0 )
{
if ( args[0] == 0 && exc->args == 0 )
exc->error = FT_THROW( Bad_Argument );
exc->IP += args[0];
if ( exc->IP < 0 ||
( exc->callTop > 0 &&
exc->IP > exc->callStack[exc->callTop - 1].Def->end ) )
exc->error = FT_THROW( Bad_Argument );
exc->step_ins = FALSE;
}
Ins_JMPR( exc, args );
}

Loading…
Cancel
Save