]> granicus.if.org Git - python/commitdiff
Fix for SF bug 516727: MyInt(2) + "3" -> NotImplemented
authorJeremy Hylton <jeremy@alum.mit.edu>
Fri, 8 Mar 2002 21:11:37 +0000 (21:11 +0000)
committerJeremy Hylton <jeremy@alum.mit.edu>
Fri, 8 Mar 2002 21:11:37 +0000 (21:11 +0000)
PyNumber_Add() tries the nb_add slot first, then falls back to
sq_concat.  However, tt didn't check the return value of sq_concat.
If sq_concat returns NotImplemented, raise the standard TypeError.

Objects/abstract.c

index 2acfd0865cecec9b75e025dfd04f2adc97c8d65a..2207602550ce98f6ea3f8b04ce2cc166940bd157 100644 (file)
@@ -605,11 +605,10 @@ PyNumber_Add(PyObject *v, PyObject *w)
        PyObject *result = binary_op1(v, w, NB_SLOT(nb_add));
        if (result == Py_NotImplemented) {
                PySequenceMethods *m = v->ob_type->tp_as_sequence;
-               Py_DECREF(Py_NotImplemented);
-               if (m && m->sq_concat) {
+               Py_DECREF(result);
+               if (m && m->sq_concat)
                        result = (*m->sq_concat)(v, w);
-               }
-                else {
+               if (result == Py_NotImplemented) {
                     PyErr_Format(
                            PyExc_TypeError,
                            "unsupported operand types for +: '%s' and '%s'",