Make the gc.collect() function respect the collection lock. This fixes
SF bug 476129: "gc.collect sometimes hangs".
This commit is contained in:
parent
67050d2d64
commit
e8c40cb722
@ -548,10 +548,17 @@ gc_collect(PyObject *self, PyObject *args)
|
|||||||
if (!PyArg_ParseTuple(args, ":collect")) /* check no args */
|
if (!PyArg_ParseTuple(args, ":collect")) /* check no args */
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
generation = 2;
|
if (collecting) {
|
||||||
gc_list_merge(&_PyGC_generation0, &generation2);
|
n = 0; /* already collecting, don't do anything */
|
||||||
gc_list_merge(&generation1, &generation2);
|
}
|
||||||
n = collect(&generation2, &generation2);
|
else {
|
||||||
|
collecting = 1;
|
||||||
|
generation = 2;
|
||||||
|
gc_list_merge(&_PyGC_generation0, &generation2);
|
||||||
|
gc_list_merge(&generation1, &generation2);
|
||||||
|
n = collect(&generation2, &generation2);
|
||||||
|
collecting = 0;
|
||||||
|
}
|
||||||
|
|
||||||
return Py_BuildValue("l", n);
|
return Py_BuildValue("l", n);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user