Commit 37b1a26c authored by Jeremy Hylton's avatar Jeremy Hylton

add list_contains and tuplecontains: efficient implementations of tp_contains

parent 035a07e2
......@@ -306,6 +306,26 @@ list_length(a)
return a->ob_size;
}
static int
list_contains(a, el)
PyListObject *a;
PyObject *el;
{
int i, cmp;
for (i = 0; i < a->ob_size; ++i) {
cmp = PyObject_Compare(el, PyList_GET_ITEM(a, i));
if (cmp == 0)
return 1;
if (PyErr_Occurred())
return -1;
}
return 0;
}
static PyObject *
list_item(a, i)
PyListObject *a;
......@@ -1447,6 +1467,7 @@ static PySequenceMethods list_as_sequence = {
(intintargfunc)list_slice, /*sq_slice*/
(intobjargproc)list_ass_item, /*sq_ass_item*/
(intintobjargproc)list_ass_slice, /*sq_ass_slice*/
(objobjproc)list_contains, /*sq_contains*/
};
PyTypeObject PyList_Type = {
......
......@@ -281,6 +281,23 @@ tuplelength(a)
return a->ob_size;
}
static int
tuplecontains(a, el)
PyTupleObject *a;
PyObject *el;
{
int i, cmp;
for (i = 0; i < a->ob_size; ++i) {
cmp = PyObject_Compare(el, PyTuple_GET_ITEM(a, i));
if (cmp == 0)
return 1;
if (PyErr_Occurred())
return -1;
}
return 0;
}
static PyObject *
tupleitem(a, i)
register PyTupleObject *a;
......@@ -409,6 +426,7 @@ static PySequenceMethods tuple_as_sequence = {
(intintargfunc)tupleslice, /*sq_slice*/
0, /*sq_ass_item*/
0, /*sq_ass_slice*/
(objobjproc)tuplecontains, /*sq_contains*/
};
PyTypeObject PyTuple_Type = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment