diff options
author | Thomas Wouters <thomas@python.org> | 2006-04-15 23:27:28 (GMT) |
---|---|---|
committer | Thomas Wouters <thomas@python.org> | 2006-04-15 23:27:28 (GMT) |
commit | b8f81d48634ccee8a8a4089d04b81e1aadbc04fe (patch) | |
tree | 7fb3fe9a004e165a0847388d893a380522cc23a0 /Python/errors.c | |
parent | 81b092d0e60db093c8ed2637deea545cb1de471a (diff) | |
download | cpython-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.c | 1 |
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); |