diff options
author | Raymond Hettinger <python@rcn.com> | 2003-11-25 21:12:14 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2003-11-25 21:12:14 (GMT) |
commit | bc0f2ab9bbe1380a32cc63823258a337a525fb32 (patch) | |
tree | 4e0f76ebe43b74cab10b1e6bd41b1d90fe6f8230 /Objects | |
parent | 3972457de72fa6d95d94df14a3bb402798aa092c (diff) | |
download | cpython-bc0f2ab9bbe1380a32cc63823258a337a525fb32.zip cpython-bc0f2ab9bbe1380a32cc63823258a337a525fb32.tar.gz cpython-bc0f2ab9bbe1380a32cc63823258a337a525fb32.tar.bz2 |
Expose dict_contains() and PyDict_Contains() with is about 10% faster
than PySequence_Contains() and more clearly applicable to dicts.
Apply the new function in setobject.c where __contains__ checking is
ubiquitous.
Diffstat (limited to 'Objects')
-rw-r--r-- | Objects/dictobject.c | 7 | ||||
-rw-r--r-- | Objects/setobject.c | 18 |
2 files changed, 13 insertions, 12 deletions
diff --git a/Objects/dictobject.c b/Objects/dictobject.c index 5d22404..0cf71b5 100644 --- a/Objects/dictobject.c +++ b/Objects/dictobject.c @@ -1814,10 +1814,11 @@ static PyMethodDef mapp_methods[] = { {NULL, NULL} /* sentinel */ }; -static int -dict_contains(dictobject *mp, PyObject *key) +int +PyDict_Contains(PyObject *op, PyObject *key) { long hash; + dictobject *mp = (dictobject *)op; if (!PyString_CheckExact(key) || (hash = ((PyStringObject *) key)->ob_shash) == -1) { @@ -1837,7 +1838,7 @@ static PySequenceMethods dict_as_sequence = { 0, /* sq_slice */ 0, /* sq_ass_item */ 0, /* sq_ass_slice */ - (objobjproc)dict_contains, /* sq_contains */ + (objobjproc)PyDict_Contains, /* sq_contains */ 0, /* sq_inplace_concat */ 0, /* sq_inplace_repeat */ }; diff --git a/Objects/setobject.c b/Objects/setobject.c index ce3f84e..c060077 100644 --- a/Objects/setobject.c +++ b/Objects/setobject.c @@ -143,13 +143,13 @@ set_contains(PySetObject *so, PyObject *key) PyObject *tmp; int result; - result = PySequence_Contains(so->data, key); + result = PyDict_Contains(so->data, key); if (result == -1 && PyAnySet_Check(key)) { PyErr_Clear(); tmp = frozenset_dict_wrapper(((PySetObject *)(key))->data); if (tmp == NULL) return -1; - result = PySequence_Contains(so->data, tmp); + result = PyDict_Contains(so->data, tmp); Py_DECREF(tmp); } return result; @@ -252,7 +252,7 @@ set_intersection(PySetObject *so, PyObject *other) } while ((item = PyIter_Next(it)) != NULL) { - if (PySequence_Contains(selfdata, item)) { + if (PyDict_Contains(selfdata, item)) { if (PyDict_SetItem(tgtdata, item, Py_True) == -1) { Py_DECREF(it); Py_DECREF(result); @@ -292,7 +292,7 @@ set_intersection_update(PySetObject *so, PyObject *other) selfdata = so->data; while ((item = PyIter_Next(it)) != NULL) { - if (PySequence_Contains(selfdata, item)) { + if (PyDict_Contains(selfdata, item)) { if (PyDict_SetItem(newdict, item, Py_True) == -1) { Py_DECREF(newdict); Py_DECREF(it); @@ -375,7 +375,7 @@ set_difference(PySetObject *so, PyObject *other) } while ((item = PyIter_Next(it)) != NULL) { - if (!PySequence_Contains(otherdata, item)) { + if (!PyDict_Contains(otherdata, item)) { if (PyDict_SetItem(tgtdata, item, Py_True) == -1) { Py_XDECREF(otherset); Py_DECREF(it); @@ -481,7 +481,7 @@ set_symmetric_difference_update(PySetObject *so, PyObject *other) return NULL; while ((item = PyIter_Next(it)) != NULL) { - if (PySequence_Contains(selfdata, item)) { + if (PyDict_Contains(selfdata, item)) { if (PyDict_DelItem(selfdata, item) == -1) { Py_XDECREF(otherset); Py_DECREF(it); @@ -541,7 +541,7 @@ set_symmetric_difference(PySetObject *so, PyObject *other) return NULL; } while ((item = PyIter_Next(it)) != NULL) { - if (!PySequence_Contains(selfdata, item)) { + if (!PyDict_Contains(selfdata, item)) { if (PyDict_SetItem(tgtdata, item, Py_True) == -1) { Py_DECREF(it); Py_DECREF(item); @@ -562,7 +562,7 @@ set_symmetric_difference(PySetObject *so, PyObject *other) return NULL; } while ((item = PyIter_Next(it)) != NULL) { - if (!PySequence_Contains(otherdata, item)) { + if (!PyDict_Contains(otherdata, item)) { if (PyDict_SetItem(tgtdata, item, Py_True) == -1) { Py_DECREF(it); Py_DECREF(item); @@ -634,7 +634,7 @@ set_issubset(PySetObject *so, PyObject *other) otherdata = ((PySetObject *)other)->data; while ((item = PyIter_Next(it)) != NULL) { - if (!PySequence_Contains(otherdata, item)) { + if (!PyDict_Contains(otherdata, item)) { Py_DECREF(it); Py_DECREF(item); Py_RETURN_FALSE; |