diff options
author | Eric Snow <ericsnowcurrently@gmail.com> | 2015-06-02 05:35:40 (GMT) |
---|---|---|
committer | Eric Snow <ericsnowcurrently@gmail.com> | 2015-06-02 05:35:40 (GMT) |
commit | ec6cd162de1b67c817a6d60856988e796db8c5dd (patch) | |
tree | 1b41b161827a5d679c7bd9e1ec94e4e7406c0fae /Objects | |
parent | e9dd08d08c587377fd28ce8839e77eca76daf9c0 (diff) | |
parent | b952ab43f281bafd8d4fce4e84b41e655a3e7c23 (diff) | |
download | cpython-ec6cd162de1b67c817a6d60856988e796db8c5dd.zip cpython-ec6cd162de1b67c817a6d60856988e796db8c5dd.tar.gz cpython-ec6cd162de1b67c817a6d60856988e796db8c5dd.tar.bz2 |
Merge from 3.5.
Diffstat (limited to 'Objects')
-rw-r--r-- | Objects/odictobject.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Objects/odictobject.c b/Objects/odictobject.c index b91bd68..b44a61e 100644 --- a/Objects/odictobject.c +++ b/Objects/odictobject.c @@ -1796,6 +1796,7 @@ typedef struct { PyObject_HEAD int kind; PyODictObject *di_odict; + Py_ssize_t di_size; PyObject *di_current; PyObject *di_result; /* reusable result tuple for iteritems */ } odictiterobject; @@ -1835,6 +1836,14 @@ odictiter_nextkey(odictiterobject *di) if (di->di_current == NULL) goto done; /* We're already done. */ + /* Check for unsupported changes. */ + if (di->di_size != PyODict_SIZE(di->di_odict)) { + PyErr_SetString(PyExc_RuntimeError, + "OrderedDict changed size during iteration"); + di->di_size = -1; /* Make this state sticky */ + return NULL; + } + /* Get the key. */ node = _odict_find_node(di->di_odict, di->di_current); if (node == NULL) { @@ -2033,6 +2042,7 @@ odictiter_new(PyODictObject *od, int kind) node = reversed ? _odict_LAST(od) : _odict_FIRST(od); di->di_current = node ? _odictnode_KEY(node) : NULL; Py_XINCREF(di->di_current); + di->di_size = PyODict_SIZE(od); di->di_odict = od; Py_INCREF(od); |