diff options
| author | Christian Heimes <christian@cheimes.de> | 2013-07-01 15:18:49 +0200 | 
|---|---|---|
| committer | Christian Heimes <christian@cheimes.de> | 2013-07-01 15:18:49 +0200 | 
| commit | bfafab1849a1f30ee69474a3d275bcaf17844970 (patch) | |
| tree | b2605aee7c35c25de9b408ca74d9174aa7282fda /Modules/_pickle.c | |
| parent | 04926aeb2f88c39a25505e4a0474c6fb735e0f46 (diff) | |
| parent | a24b4d260beafb5b45450ff46d7740bea8eaa4a9 (diff) | |
| download | cpython-git-bfafab1849a1f30ee69474a3d275bcaf17844970.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/_pickle.c')
| -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 002b37825d..bbae2b1d19 100644 --- a/Modules/_pickle.c +++ b/Modules/_pickle.c @@ -5952,6 +5952,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;          }  | 
