summaryrefslogtreecommitdiffstats
path: root/Python/errors.c
diff options
context:
space:
mode:
authorThomas Wouters <thomas@python.org>2006-04-15 23:27:28 (GMT)
committerThomas Wouters <thomas@python.org>2006-04-15 23:27:28 (GMT)
commitb8f81d48634ccee8a8a4089d04b81e1aadbc04fe (patch)
tree7fb3fe9a004e165a0847388d893a380522cc23a0 /Python/errors.c
parent81b092d0e60db093c8ed2637deea545cb1de471a (diff)
downloadcpython-b8f81d48634ccee8a8a4089d04b81e1aadbc04fe.zip
cpython-b8f81d48634ccee8a8a4089d04b81e1aadbc04fe.tar.gz
cpython-b8f81d48634ccee8a8a4089d04b81e1aadbc04fe.tar.bz2
Add missing DECREF to PyErr_WriteUnraisable(). That function reports
exceptions that can't be raised any further, because (for instance) they occur in __del__ methods. The coroutine tests in test_generators was triggering this leak. Remove the leakers' testcase, and add a simpler testcase that explicitly tests this leak to test_generators. test_generators now no longer leaks at all, on my machine. This fix may also solve other leaks, but my full refleakhunting run is still busy, so who knows?
Diffstat (limited to 'Python/errors.c')
-rw-r--r--Python/errors.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/Python/errors.c b/Python/errors.c
index 25deaa6..275a065 100644
--- a/Python/errors.c
+++ b/Python/errors.c
@@ -604,6 +604,7 @@ PyErr_WriteUnraisable(PyObject *obj)
PyFile_WriteString(": ", f);
PyFile_WriteObject(v, f, 0);
}
+ Py_DECREF(moduleName);
}
PyFile_WriteString(" in ", f);
PyFile_WriteObject(obj, f, 0);