diff options
author | Christian Heimes <christian@cheimes.de> | 2013-07-01 15:17:45 +0200 |
---|---|---|
committer | Christian Heimes <christian@cheimes.de> | 2013-07-01 15:17:45 +0200 |
commit | a24b4d260beafb5b45450ff46d7740bea8eaa4a9 (patch) | |
tree | 377a84158bbfeeb2b38e6714b40fb460a56f8310 /Modules | |
parent | 8a0b7756e28f9374a8a316ca9a81613cc6b6e022 (diff) | |
download | cpython-git-a24b4d260beafb5b45450ff46d7740bea8eaa4a9.tar.gz |
Issue #18339: Negative ints keys in unpickler.memo dict no longer cause a
segfault inside the _pickle C extension.
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_pickle.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/Modules/_pickle.c b/Modules/_pickle.c index a8d6684b7c..195ee5d790 100644 --- a/Modules/_pickle.c +++ b/Modules/_pickle.c @@ -5931,6 +5931,11 @@ Unpickler_set_memo(UnpicklerObject *self, PyObject *obj) idx = PyLong_AsSsize_t(key); if (idx == -1 && PyErr_Occurred()) goto error; + if (idx < 0) { + PyErr_SetString(PyExc_ValueError, + "memos key must be positive integers."); + goto error; + } if (_Unpickler_MemoPut(self, idx, value) < 0) goto error; } |