summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKirill Podoprigora <kirill.bast9@mail.ru>2024-08-06 05:57:36 (GMT)
committerGitHub <noreply@github.com>2024-08-06 05:57:36 (GMT)
commit94a4bd79a7ab7b0ff5f216782d6fdaff6ed348fc (patch)
treecdbb27f9f571829402239b5d534863f05ea158e6
parentb0c48b8fd88f26b31ec2f743358091073277dcde (diff)
downloadcpython-94a4bd79a7ab7b0ff5f216782d6fdaff6ed348fc.zip
cpython-94a4bd79a7ab7b0ff5f216782d6fdaff6ed348fc.tar.gz
cpython-94a4bd79a7ab7b0ff5f216782d6fdaff6ed348fc.tar.bz2
gh-122704: Fix reference leak in Modules/_pickle.c (GH-122705)
-rw-r--r--Modules/_pickle.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/Modules/_pickle.c b/Modules/_pickle.c
index 5d9ee8c..dc0ef0a 100644
--- a/Modules/_pickle.c
+++ b/Modules/_pickle.c
@@ -1962,9 +1962,11 @@ whichmodule(PickleState *st, PyObject *global, PyObject *global_name, PyObject *
PyErr_Format(st->PicklingError,
"Can't pickle %R: import of module %R failed",
global, module_name);
+ Py_DECREF(module_name);
return NULL;
}
if (check_dotted_path(module, global_name, dotted_path) < 0) {
+ Py_DECREF(module_name);
Py_DECREF(module);
return NULL;
}
@@ -1974,6 +1976,7 @@ whichmodule(PickleState *st, PyObject *global, PyObject *global_name, PyObject *
PyErr_Format(st->PicklingError,
"Can't pickle %R: attribute lookup %S on %S failed",
global, global_name, module_name);
+ Py_DECREF(module_name);
return NULL;
}
if (actual != global) {
@@ -1981,6 +1984,7 @@ whichmodule(PickleState *st, PyObject *global, PyObject *global_name, PyObject *
PyErr_Format(st->PicklingError,
"Can't pickle %R: it's not the same object as %S.%S",
global, module_name, global_name);
+ Py_DECREF(module_name);
return NULL;
}
Py_DECREF(actual);