summaryrefslogtreecommitdiff
path: root/Python/ceval.c
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2015-07-05 10:38:05 -0500
committerBenjamin Peterson <benjamin@python.org>2015-07-05 10:38:05 -0500
commit9f71cb0fee510044e7038670b971bf999f3b96d1 (patch)
treea6c1cfcb1daa2a87f640e7e22c2a6e98a291e2f2 /Python/ceval.c
parent3e7f3c032f68d6be5b8f3501ca7c4124394f3a6c (diff)
parentd5d77aac60453694445d1509b51d7514871dbff8 (diff)
downloadcpython-git-9f71cb0fee510044e7038670b971bf999f3b96d1.tar.gz
merge 3.5 (#24569)
Diffstat (limited to 'Python/ceval.c')
-rw-r--r--Python/ceval.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index e68ae33bfd..ac52ad91e2 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -2561,22 +2561,25 @@ PyEval_EvalFrameEx(PyFrameObject *f, int throwflag)
}
TARGET(BUILD_MAP) {
+ int i;
PyObject *map = _PyDict_NewPresized((Py_ssize_t)oparg);
if (map == NULL)
goto error;
- while (--oparg >= 0) {
+ for (i = oparg; i > 0; i--) {
int err;
- PyObject *value = TOP();
- PyObject *key = SECOND();
- STACKADJ(-2);
+ PyObject *key = PEEK(2*i);
+ PyObject *value = PEEK(2*i - 1);
err = PyDict_SetItem(map, key, value);
- Py_DECREF(value);
- Py_DECREF(key);
if (err != 0) {
Py_DECREF(map);
goto error;
}
}
+
+ while (oparg--) {
+ Py_DECREF(POP());
+ Py_DECREF(POP());
+ }
PUSH(map);
DISPATCH();
}