When comparing objects, always check that tp_compare is not NULL

before calling it.  This check was there when the objects were of the
same type *before* coercion, but not if they initially differed but
became the same *after* coercion.
This commit is contained in:
Guido van Rossum 1998-07-21 21:56:41 +00:00
parent 052969a602
commit b4db1944c4
1 changed files with 7 additions and 3 deletions

View File

@ -312,14 +312,18 @@ PyObject_Compare(v, w)
if ((vtp = v->ob_type) != (wtp = w->ob_type)) {
char *vname = vtp->tp_name;
char *wname = wtp->tp_name;
if (vtp->tp_as_number != NULL &&
wtp->tp_as_number != NULL) {
if (vtp->tp_as_number != NULL && wtp->tp_as_number != NULL) {
int err;
err = PyNumber_CoerceEx(&v, &w);
if (err < 0)
return -1;
else if (err == 0) {
int cmp = (*v->ob_type->tp_compare)(v, w);
int cmp;
vtp = v->ob_type;
if (vtp->tp_compare == NULL)
cmp = (v < w) ? -1 : 1;
else
cmp = (*vtp->tp_compare)(v, w);
Py_DECREF(v);
Py_DECREF(w);
return cmp;