diff options
author | Thomas Wouters <thomas@python.org> | 2006-04-15 23:27:28 +0000 |
---|---|---|
committer | Thomas Wouters <thomas@python.org> | 2006-04-15 23:27:28 +0000 |
commit | b8f81d48634ccee8a8a4089d04b81e1aadbc04fe (patch) | |
tree | 7fb3fe9a004e165a0847388d893a380522cc23a0 /Python/errors.c | |
parent | 81b092d0e60db093c8ed2637deea545cb1de471a (diff) | |
download | cpython-git-b8f81d48634ccee8a8a4089d04b81e1aadbc04fe.tar.gz |
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.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/Python/errors.c b/Python/errors.c index 25deaa6919..275a0656f6 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); |