diff options
author | Guido van Rossum <guido@python.org> | 2001-01-18 23:46:31 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2001-01-18 23:46:31 (GMT) |
commit | 65e8bd7fd5af5de8e6354832d5c00e7cc9dff7ab (patch) | |
tree | c53ffaf4c3ab69635351466bb1847a6e024e63da | |
parent | 0c6614c78904b6ad0a92033a3224b95d182f1b17 (diff) | |
download | cpython-65e8bd7fd5af5de8e6354832d5c00e7cc9dff7ab.zip cpython-65e8bd7fd5af5de8e6354832d5c00e7cc9dff7ab.tar.gz cpython-65e8bd7fd5af5de8e6354832d5c00e7cc9dff7ab.tar.bz2 |
Rich comparisons fallout: instance_hash() should check for both
__cmp__ and __eq__ absent before deciding to do a quickie
based on the object address. (Tim Peters discovered this.)
-rw-r--r-- | Objects/classobject.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/Objects/classobject.c b/Objects/classobject.c index 5e987ff..40ff983 100644 --- a/Objects/classobject.c +++ b/Objects/classobject.c @@ -762,21 +762,28 @@ instance_hash(PyInstanceObject *inst) PyObject *func; PyObject *res; long outcome; - static PyObject *hashstr, *cmpstr; + static PyObject *hashstr, *eqstr, *cmpstr; if (hashstr == NULL) hashstr = PyString_InternFromString("__hash__"); func = instance_getattr(inst, hashstr); if (func == NULL) { - /* If there is no __cmp__ method, we hash on the address. - If a __cmp__ method exists, there must be a __hash__. */ + /* If there is no __eq__ and no __cmp__ method, we hash on the + address. If an __eq__ or __cmp__ method exists, there must + be a __hash__. */ PyErr_Clear(); - if (cmpstr == NULL) - cmpstr = PyString_InternFromString("__cmp__"); - func = instance_getattr(inst, cmpstr); + if (eqstr == NULL) + eqstr = PyString_InternFromString("__eq__"); + func = instance_getattr(inst, eqstr); if (func == NULL) { PyErr_Clear(); - return _Py_HashPointer(inst); + if (cmpstr == NULL) + cmpstr = PyString_InternFromString("__cmp__"); + func = instance_getattr(inst, cmpstr); + if (func == NULL) { + PyErr_Clear(); + return _Py_HashPointer(inst); + } } PyErr_SetString(PyExc_TypeError, "unhashable instance"); return -1; |