summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorMartin v. Löwis <martin@v.loewis.de>2002-09-22 08:21:45 (GMT)
committerMartin v. Löwis <martin@v.loewis.de>2002-09-22 08:21:45 (GMT)
commit5877bc3dfd77533585dfd341b34897722ba1bf6e (patch)
tree72a1cf9db60d17b25cf082e5bba921d202a0a053 /Modules
parentd412a12fb76234d22e694c09812b8639fd14c7a9 (diff)
downloadcpython-5877bc3dfd77533585dfd341b34897722ba1bf6e.zip
cpython-5877bc3dfd77533585dfd341b34897722ba1bf6e.tar.gz
cpython-5877bc3dfd77533585dfd341b34897722ba1bf6e.tar.bz2
Add recursion limit to pickling. Fixes #576084.
Diffstat (limited to 'Modules')
-rw-r--r--Modules/cPickle.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/Modules/cPickle.c b/Modules/cPickle.c
index 1f8b210..a400dde 100644
--- a/Modules/cPickle.c
+++ b/Modules/cPickle.c
@@ -313,6 +313,7 @@ typedef struct Picklerobject {
PyObject *inst_pers_func;
int bin;
int fast; /* Fast mode doesn't save in memo, don't use if circ ref */
+ int nesting;
int (*write_func)(struct Picklerobject *, char *, int);
char *write_buf;
int buf_size;
@@ -1850,6 +1851,12 @@ save(Picklerobject *self, PyObject *args, int pers_save) {
*callable = 0, *state = 0;
int res = -1, tmp, size;
+ if (self->nesting++ > Py_GetRecursionLimit()){
+ PyErr_SetString(PyExc_RuntimeError,
+ "maximum recursion depth exceeded");
+ goto finally;
+ }
+
if (!pers_save && self->pers_func) {
if ((tmp = save_pers(self, args, self->pers_func)) != 0) {
res = tmp;
@@ -2068,6 +2075,7 @@ save(Picklerobject *self, PyObject *args, int pers_save) {
PyErr_SetObject(UnpickleableError, args);
finally:
+ self->nesting--;
Py_XDECREF(py_ob_id);
Py_XDECREF(__reduce__);
Py_XDECREF(t);
@@ -2287,6 +2295,7 @@ newPicklerobject(PyObject *file, int bin) {
self->write_buf = NULL;
self->bin = bin;
self->fast = 0;
+ self->nesting = 0;
self->fast_container = 0;
self->fast_memo = NULL;
self->buf_size = 0;