diff options
author | Mark Dickinson <dickinsm@gmail.com> | 2010-09-23 20:16:03 (GMT) |
---|---|---|
committer | Mark Dickinson <dickinsm@gmail.com> | 2010-09-23 20:16:03 (GMT) |
commit | a67c70d4a945e9fc5f37165d1c61e6955e0dc8c8 (patch) | |
tree | 2c6e02c4f8a2b6059ce9e971f880102055f8d7d5 | |
parent | 9227508dec49240d3e528d0a319048a3a2cb02c6 (diff) | |
download | cpython-a67c70d4a945e9fc5f37165d1c61e6955e0dc8c8.zip cpython-a67c70d4a945e9fc5f37165d1c61e6955e0dc8c8.tar.gz cpython-a67c70d4a945e9fc5f37165d1c61e6955e0dc8c8.tar.bz2 |
Merged revisions 84984 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r84984 | mark.dickinson | 2010-09-23 21:11:19 +0100 (Thu, 23 Sep 2010) | 5 lines
Issue #9930: Remove an unnecessary type check in wrap_binaryfunc_r;
this was causing reversed method calls like float.__radd__(3.0, 1) to
return NotImplemented instead of the expected numeric value.
........
-rw-r--r-- | Lib/test/test_descr.py | 5 | ||||
-rw-r--r-- | Misc/NEWS | 4 | ||||
-rw-r--r-- | Objects/typeobject.c | 4 |
3 files changed, 9 insertions, 4 deletions
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py index 82dcc2c..320a7a7 100644 --- a/Lib/test/test_descr.py +++ b/Lib/test/test_descr.py @@ -289,6 +289,11 @@ class OperatorsTest(unittest.TestCase): self.assertEqual(repr(a), "234.5") self.assertEqual(a.prec, 12) + def test_explicit_reverse_methods(self): + # see issue 9930 + self.assertEqual(complex.__radd__(3j, 4.0), complex(4.0, 3.0)) + self.assertEqual(float.__rsub__(3.0, 1), -2.0) + @support.impl_detail("the module 'xxsubtype' is internal") def test_spam_lists(self): # Testing spamlist operations... @@ -12,6 +12,10 @@ What's New in Python 3.1.3? Core and Builtins ----------------- +- Issue #9930: Remove bogus subtype check that was causing (e.g.) + float.__rdiv__(2.0, 3) to return NotImplemented instead of the + expected 1.5. + - Issue #9804: ascii() now always represents unicode surrogate pairs as a single ``\UXXXXXXXX``, regardless of whether the character is printable or not. Also, the "backslashreplace" error handler now joins surrogate diff --git a/Objects/typeobject.c b/Objects/typeobject.c index d2124f1..ab942c0 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -4049,10 +4049,6 @@ wrap_binaryfunc_r(PyObject *self, PyObject *args, void *wrapped) if (!check_num_args(args, 1)) return NULL; other = PyTuple_GET_ITEM(args, 0); - if (!PyType_IsSubtype(Py_TYPE(other), Py_TYPE(self))) { - Py_INCREF(Py_NotImplemented); - return Py_NotImplemented; - } return (*func)(other, self); } |