mirror of https://github.com/python/cpython.git
bpo-39453: Make list.__contains__ hold strong references to avoid crashes (GH-18181)
This commit is contained in:
parent
a46575a8f2
commit
4dbf2d8c67
|
@ -221,6 +221,11 @@ def __eq__(self, other):
|
|||
with self.assertRaises(ValueError):
|
||||
lst.remove(lst)
|
||||
|
||||
# bpo-39453: list.__contains__ was not holding strong references
|
||||
# to list elements while calling PyObject_RichCompareBool().
|
||||
lst = [X(), X()]
|
||||
3 in lst
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
unittest.main()
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
Fixed a possible crash in :meth:`list.__contains__` when a list is changed
|
||||
during comparing items. Patch by Dong-hee Na.
|
|
@ -445,11 +445,16 @@ list_length(PyListObject *a)
|
|||
static int
|
||||
list_contains(PyListObject *a, PyObject *el)
|
||||
{
|
||||
PyObject *item;
|
||||
Py_ssize_t i;
|
||||
int cmp;
|
||||
|
||||
for (i = 0, cmp = 0 ; cmp == 0 && i < Py_SIZE(a); ++i)
|
||||
for (i = 0, cmp = 0 ; cmp == 0 && i < Py_SIZE(a); ++i) {
|
||||
item = PyList_GET_ITEM(a, i);
|
||||
Py_INCREF(item);
|
||||
cmp = PyObject_RichCompareBool(PyList_GET_ITEM(a, i), el, Py_EQ);
|
||||
Py_DECREF(item);
|
||||
}
|
||||
return cmp;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue