diff options
author | Raymond Hettinger <rhettinger@users.noreply.github.com> | 2018-01-28 17:40:24 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-28 17:40:24 (GMT) |
commit | a4d00012565d716db6e6abe1b8f33eaaa4de416e (patch) | |
tree | 81da58a66bc351914cb94760250b66968bc3f185 | |
parent | 059f58ce938d9c3f0286412a4efb1b9131339421 (diff) | |
download | cpython-a4d00012565d716db6e6abe1b8f33eaaa4de416e.zip cpython-a4d00012565d716db6e6abe1b8f33eaaa4de416e.tar.gz cpython-a4d00012565d716db6e6abe1b8f33eaaa4de416e.tar.bz2 |
bpo-32690: Preserve order of locals() (#5379)
-rw-r--r-- | Misc/NEWS.d/next/Core and Builtins/2018-01-28-09-26-07.bpo-32690.8i9g5P.rst | 2 | ||||
-rw-r--r-- | Objects/frameobject.c | 4 |
2 files changed, 4 insertions, 2 deletions
diff --git a/Misc/NEWS.d/next/Core and Builtins/2018-01-28-09-26-07.bpo-32690.8i9g5P.rst b/Misc/NEWS.d/next/Core and Builtins/2018-01-28-09-26-07.bpo-32690.8i9g5P.rst new file mode 100644 index 0000000..1663b96 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/2018-01-28-09-26-07.bpo-32690.8i9g5P.rst @@ -0,0 +1,2 @@ +The locals() dictionary now displays in the lexical order that variables +were defined. Previously, the order was reversed. diff --git a/Objects/frameobject.c b/Objects/frameobject.c index 1ac3d75..3083e5b 100644 --- a/Objects/frameobject.c +++ b/Objects/frameobject.c @@ -791,7 +791,7 @@ map_to_dict(PyObject *map, Py_ssize_t nmap, PyObject *dict, PyObject **values, assert(PyTuple_Check(map)); assert(PyDict_Check(dict)); assert(PyTuple_Size(map) >= nmap); - for (j = nmap; --j >= 0; ) { + for (j=0; j < nmap; j++) { PyObject *key = PyTuple_GET_ITEM(map, j); PyObject *value = values[j]; assert(PyUnicode_Check(key)); @@ -844,7 +844,7 @@ dict_to_map(PyObject *map, Py_ssize_t nmap, PyObject *dict, PyObject **values, assert(PyTuple_Check(map)); assert(PyDict_Check(dict)); assert(PyTuple_Size(map) >= nmap); - for (j = nmap; --j >= 0; ) { + for (j=0; j < nmap; j++) { PyObject *key = PyTuple_GET_ITEM(map, j); PyObject *value = PyObject_GetItem(dict, key); assert(PyUnicode_Check(key)); |