diff options
author | Raymond Hettinger <python@rcn.com> | 2005-08-24 00:24:40 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2005-08-24 00:24:40 (GMT) |
commit | 9c1491f37c4884d72b18a0493c757e7c1f5e2814 (patch) | |
tree | a78a314663ba912ae9c2aca2afb71a616fcc6a03 | |
parent | 26292a3af08927e7a14786dd88dfd48f8ca4bd20 (diff) | |
download | cpython-9c1491f37c4884d72b18a0493c757e7c1f5e2814.zip cpython-9c1491f37c4884d72b18a0493c757e7c1f5e2814.tar.gz cpython-9c1491f37c4884d72b18a0493c757e7c1f5e2814.tar.bz2 |
* Add a fast equality check path for frozensets where the hash value has
already been computed.
* Apply a GET_SIZE macro().
-rw-r--r-- | Objects/setobject.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/Objects/setobject.c b/Objects/setobject.c index 9a54aed..8787347 100644 --- a/Objects/setobject.c +++ b/Objects/setobject.c @@ -1495,12 +1495,15 @@ set_richcompare(PySetObject *v, PyObject *w, int op) case Py_EQ: if (PySet_GET_SIZE(v) != PySet_GET_SIZE(w)) Py_RETURN_FALSE; + if (v->hash != -1 && + ((PySetObject *)w)->hash != -1 && + v->hash != ((PySetObject *)w)->hash) + Py_RETURN_FALSE; return set_issubset(v, w); case Py_NE: - if (PySet_GET_SIZE(v) != PySet_GET_SIZE(w)) - Py_RETURN_TRUE; - r1 = set_issubset(v, w); - assert (r1 != NULL); + r1 = set_richcompare(v, w, Py_EQ); + if (r1 == NULL) + return NULL; r2 = PyBool_FromLong(PyObject_Not(r1)); Py_DECREF(r1); return r2; @@ -1956,7 +1959,7 @@ PySet_Size(PyObject *anyset) PyErr_BadInternalCall(); return -1; } - return ((PySetObject *)anyset)->used; + return PySet_GET_SIZE(anyset); } int |