]> granicus.if.org Git - python/commitdiff
Cancelled checkin, sorry.
authorArmin Rigo <arigo@tunes.org>
Sat, 20 Mar 2004 21:50:13 +0000 (21:50 +0000)
committerArmin Rigo <arigo@tunes.org>
Sat, 20 Mar 2004 21:50:13 +0000 (21:50 +0000)
Python/ceval.c

index 51df60a780daf251c722e48edfe7e0784288fb67..d3a0053f61563b170b81ab981d66766641b6943e 100644 (file)
@@ -627,8 +627,7 @@ eval_frame(PyFrameObject *f)
 
 #define INSTR_OFFSET() (next_instr - first_instr)
 #define NEXTOP()       (*next_instr++)
-#define OPARG()                (next_instr[0] + (next_instr[1]<<8))
-#define OPARG_SIZE     2
+#define NEXTARG()      (next_instr += 2, (next_instr[-1]<<8) + next_instr[-2])
 #define JUMPTO(x)      (next_instr = first_instr + (x))
 #define JUMPBY(x)      (next_instr += (x))
 
@@ -659,7 +658,8 @@ eval_frame(PyFrameObject *f)
 #endif
 
 #define PREDICTED(op)          PRED_##op: next_instr++
-#define PREDICTED_WITH_ARG(op) PRED_##op: next_instr++; oparg = OPARG(); next_instr += OPARG_SIZE
+#define PREDICTED_WITH_ARG(op) PRED_##op: oparg = (next_instr[2]<<8) + \
+                               next_instr[1]; next_instr += 3
 
 /* Stack manipulation macros */
 
@@ -862,11 +862,8 @@ eval_frame(PyFrameObject *f)
                /* Extract opcode and argument */
 
                opcode = NEXTOP();
-               if (HAS_ARG(opcode)) {
-                       oparg = OPARG();
-                       next_instr += OPARG_SIZE;
-               }
-
+               if (HAS_ARG(opcode))
+                       oparg = NEXTARG();
          dispatch_opcode:
 #ifdef DYNAMIC_EXECUTION_PROFILE
 #ifdef DXPAIRS
@@ -2252,8 +2249,7 @@ eval_frame(PyFrameObject *f)
 
                case EXTENDED_ARG:
                        opcode = NEXTOP();
-                       oparg = oparg<<16 | OPARG();
-                       next_instr += OPARG_SIZE;
+                       oparg = oparg<<16 | NEXTARG();
                        goto dispatch_opcode;
 
                default: