summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorPhilip Jenvey <pjenvey@underboss.org>2009-09-29 04:57:18 (GMT)
committerPhilip Jenvey <pjenvey@underboss.org>2009-09-29 04:57:18 (GMT)
commit26713cade1e8e2e2458062c4f0be0b53ae436753 (patch)
treef5c5ce6f2702187ad41cee3e72dbbad28832d707 /Modules
parent12c4bdb0e8d96640423bd6878dac2aecacb2d741 (diff)
downloadcpython-26713cade1e8e2e2458062c4f0be0b53ae436753.zip
cpython-26713cade1e8e2e2458062c4f0be0b53ae436753.tar.gz
cpython-26713cade1e8e2e2458062c4f0be0b53ae436753.tar.bz2
Recorded merge of revisions 75123 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r75123 | philip.jenvey | 2009-09-28 21:32:44 -0700 (Mon, 28 Sep 2009) | 4 lines #6990: clear threading.local's key only after its thread state is removed: fixes local subclasses leaving old state around after a ref cycle GC which could be recycled by new locals ........
Diffstat (limited to 'Modules')
-rw-r--r--Modules/_threadmodule.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/Modules/_threadmodule.c b/Modules/_threadmodule.c
index a031998..744e94d 100644
--- a/Modules/_threadmodule.c
+++ b/Modules/_threadmodule.c
@@ -239,7 +239,6 @@ local_traverse(localobject *self, visitproc visit, void *arg)
static int
local_clear(localobject *self)
{
- Py_CLEAR(self->key);
Py_CLEAR(self->args);
Py_CLEAR(self->kw);
Py_CLEAR(self->dict);
@@ -261,6 +260,7 @@ local_dealloc(localobject *self)
PyDict_DelItem(tstate->dict, self->key);
}
+ Py_XDECREF(self->key);
local_clear(self);
Py_TYPE(self)->tp_free((PyObject*)self);
}