summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1997-01-18 02:46:13 (GMT)
committerGuido van Rossum <guido@python.org>1997-01-18 02:46:13 (GMT)
commit3dfd53b4c83cc42e694a7c6e66678f2e7b0b1613 (patch)
treee669c605397711929baec5d04388d2e9b1296264
parent04f2b453bbc282be83529b6fb726dc92dbbdbfc3 (diff)
downloadcpython-3dfd53b4c83cc42e694a7c6e66678f2e7b0b1613.zip
cpython-3dfd53b4c83cc42e694a7c6e66678f2e7b0b1613.tar.gz
cpython-3dfd53b4c83cc42e694a7c6e66678f2e7b0b1613.tar.bz2
Add "if (x != NULL) continue;" (or similar for err==0) before the
break to most cases, as suggested by Tim Peters. This gives another 8-10% speedup.
-rw-r--r--Python/ceval.c78
1 files changed, 60 insertions, 18 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index dbfaf7d..a959e34 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -649,14 +649,14 @@ eval_code2(co, globals, locals,
case POP_TOP:
v = POP();
DECREF(v);
- break;
+ continue;
case ROT_TWO:
v = POP();
w = POP();
PUSH(v);
PUSH(w);
- break;
+ continue;
case ROT_THREE:
v = POP();
@@ -665,19 +665,20 @@ eval_code2(co, globals, locals,
PUSH(v);
PUSH(x);
PUSH(w);
- break;
+ continue;
case DUP_TOP:
v = TOP();
INCREF(v);
PUSH(v);
- break;
+ continue;
case UNARY_POSITIVE:
v = POP();
x = pos(v);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case UNARY_NEGATIVE:
@@ -685,6 +686,7 @@ eval_code2(co, globals, locals,
x = neg(v);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case UNARY_NOT:
@@ -692,6 +694,7 @@ eval_code2(co, globals, locals,
x = not(v);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case UNARY_CONVERT:
@@ -699,6 +702,7 @@ eval_code2(co, globals, locals,
x = reprobject(v);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case UNARY_INVERT:
@@ -706,6 +710,7 @@ eval_code2(co, globals, locals,
x = invert(v);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_POWER:
@@ -715,6 +720,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_MULTIPLY:
@@ -724,6 +730,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_DIVIDE:
@@ -733,6 +740,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_MODULO:
@@ -742,6 +750,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_ADD:
@@ -751,6 +760,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_SUBTRACT:
@@ -760,6 +770,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_SUBSCR:
@@ -769,6 +780,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_LSHIFT:
@@ -778,6 +790,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_RSHIFT:
@@ -787,6 +800,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_AND:
@@ -796,6 +810,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_XOR:
@@ -805,6 +820,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case BINARY_OR:
@@ -814,6 +830,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case SLICE+0:
@@ -834,6 +851,7 @@ eval_code2(co, globals, locals,
XDECREF(v);
XDECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case STORE_SLICE+0:
@@ -855,6 +873,7 @@ eval_code2(co, globals, locals,
DECREF(u);
XDECREF(v);
XDECREF(w);
+ if (err == 0) continue;
break;
case DELETE_SLICE+0:
@@ -875,6 +894,7 @@ eval_code2(co, globals, locals,
DECREF(u);
XDECREF(v);
XDECREF(w);
+ if (err == 0) continue;
break;
case STORE_SUBSCR:
@@ -886,6 +906,7 @@ eval_code2(co, globals, locals,
DECREF(u);
DECREF(v);
DECREF(w);
+ if (err == 0) continue;
break;
case DELETE_SUBSCR:
@@ -895,6 +916,7 @@ eval_code2(co, globals, locals,
err = assign_subscript(v, w, (object *)NULL);
DECREF(v);
DECREF(w);
+ if (err == 0) continue;
break;
case PRINT_EXPR:
@@ -929,6 +951,7 @@ eval_code2(co, globals, locals,
softspace(w, 0);
}
DECREF(v);
+ if (err == 0) continue;
break;
case PRINT_NEWLINE:
@@ -1294,6 +1317,7 @@ eval_code2(co, globals, locals,
#endif
INCREF(x);
PUSH(x);
+ if (x != NULL) continue;
break;
case STORE_FAST:
@@ -1307,7 +1331,7 @@ eval_code2(co, globals, locals,
}
#endif
SETLOCAL(oparg, v);
- break;
+ continue;
case DELETE_FAST:
#ifdef SUPPORT_OBSOLETE_ACCESS
@@ -1325,7 +1349,7 @@ eval_code2(co, globals, locals,
}
#endif
SETLOCAL(oparg, NULL);
- break;
+ continue;
case BUILD_TUPLE:
x = newtupleobject(oparg);
@@ -1335,6 +1359,7 @@ eval_code2(co, globals, locals,
SETTUPLEITEM(x, oparg, w);
}
PUSH(x);
+ continue;
}
break;
@@ -1348,12 +1373,14 @@ eval_code2(co, globals, locals,
break;
}
PUSH(x);
+ continue;
}
break;
case BUILD_MAP:
x = newdictobject();
PUSH(x);
+ if (x != NULL) continue;
break;
case LOAD_ATTR:
@@ -1362,6 +1389,7 @@ eval_code2(co, globals, locals,
x = getattro(v, w);
DECREF(v);
PUSH(x);
+ if (x != NULL) continue;
break;
case COMPARE_OP:
@@ -1371,6 +1399,7 @@ eval_code2(co, globals, locals,
DECREF(v);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case IMPORT_NAME:
@@ -1405,6 +1434,7 @@ eval_code2(co, globals, locals,
x = call_object(x, w);
DECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;
case IMPORT_FROM:
@@ -1417,6 +1447,7 @@ eval_code2(co, globals, locals,
}
err = import_from(x, v, w);
locals_2_fast(f, 0);
+ if (err == 0) continue;
break;
#ifdef SUPPORT_OBSOLETE_ACCESS
@@ -1433,7 +1464,7 @@ eval_code2(co, globals, locals,
case JUMP_FORWARD:
JUMPBY(oparg);
- break;
+ continue;
case JUMP_IF_FALSE:
err = testbool(TOP());
@@ -1441,7 +1472,9 @@ eval_code2(co, globals, locals,
err = 0;
else if (err == 0)
JUMPBY(oparg);
- break;
+ else
+ break;
+ continue;
case JUMP_IF_TRUE:
err = testbool(TOP());
@@ -1449,11 +1482,15 @@ eval_code2(co, globals, locals,
err = 0;
JUMPBY(oparg);
}
- break;
+ else if (err == 0)
+ ;
+ else
+ break;
+ continue;
case JUMP_ABSOLUTE:
JUMPTO(oparg);
- break;
+ continue;
case FOR_LOOP:
/* for v in s: ...
@@ -1470,6 +1507,7 @@ eval_code2(co, globals, locals,
PUSH(x);
DECREF(w);
PUSH(u);
+ if (x != NULL) continue;
}
else {
DECREF(v);
@@ -1478,8 +1516,10 @@ eval_code2(co, globals, locals,
but also an error: */
if (err_occurred())
why = WHY_EXCEPTION;
- else
+ else {
JUMPBY(oparg);
+ continue;
+ }
}
break;
@@ -1488,7 +1528,7 @@ eval_code2(co, globals, locals,
case SETUP_FINALLY:
setup_block(f, opcode, INSTR_OFFSET() + oparg,
STACK_LEVEL());
- break;
+ continue;
case SET_LINENO:
#ifdef LLTRACE
@@ -1496,12 +1536,12 @@ eval_code2(co, globals, locals,
printf("--- %s:%d \n", filename, oparg);
#endif
f->f_lineno = oparg;
- if (f->f_trace != NULL) {
- /* Trace each line of code reached */
- f->f_lasti = INSTR_OFFSET();
- err = call_trace(&f->f_trace, &f->f_trace,
- f, "line", None);
- }
+ if (f->f_trace == NULL)
+ continue;
+ /* Trace each line of code reached */
+ f->f_lasti = INSTR_OFFSET();
+ err = call_trace(&f->f_trace, &f->f_trace,
+ f, "line", None);
break;
case CALL_FUNCTION:
@@ -1619,6 +1659,7 @@ eval_code2(co, globals, locals,
DECREF(w);
}
PUSH(x);
+ if (x != NULL) continue;
break;
}
@@ -1656,6 +1697,7 @@ eval_code2(co, globals, locals,
DECREF(v);
XDECREF(w);
PUSH(x);
+ if (x != NULL) continue;
break;