]> granicus.if.org Git - python/commitdiff
SF bug 544647.
authorGuido van Rossum <guido@python.org>
Tue, 16 Apr 2002 16:44:51 +0000 (16:44 +0000)
committerGuido van Rossum <guido@python.org>
Tue, 16 Apr 2002 16:44:51 +0000 (16:44 +0000)
PyNumber_InPlaceMultiply insisted on calling sq_inplace_repeat if it
existed, even if nb_inplace_multiply also existed and the arguments
weren't right for sq_inplace_repeat.  Change this to only use
sq_inplace_repeat if nb_inplace_multiply isn't defined.

Bugfix candidate.

Lib/test/test_descr.py
Objects/abstract.c

index 3e3424a7f41219754eb12d0a44966a8d497a904c..fc5f2eabee694f006cfd23d4a86847c36fced69e 100644 (file)
@@ -2929,6 +2929,32 @@ def funnynew():
     vereq(isinstance(d, D), True)
     vereq(d.foo, 1)
 
+def imulbug():
+    # SF bug 544647
+    if verbose: print "Testing for __imul__ problems..."
+    class C(object):
+        def __imul__(self, other):
+            return (self, other)
+    x = C()
+    y = x
+    y *= 1.0
+    vereq(y, (x, 1.0))
+    y = x
+    y *= 2
+    vereq(y, (x, 2))
+    y = x
+    y *= 3L
+    vereq(y, (x, 3L))
+    y = x
+    y *= 1L<<100
+    vereq(y, (x, 1L<<100))
+    y = x
+    y *= None
+    vereq(y, (x, None))
+    y = x
+    y *= "foo"
+    vereq(y, (x, "foo"))
+
 def test_main():
     class_docstrings()
     lists()
@@ -2992,6 +3018,7 @@ def test_main():
     dictproxyiteritems()
     pickleslots()
     funnynew()
+    imulbug()
     if verbose: print "All OK"
 
 if __name__ == "__main__":
index cb2807da5c76db25fda95eb5ca2e3de252b53b26..622e8191d813d78c9bf4bed816bf4f2a87deed2c 100644 (file)
@@ -742,8 +742,12 @@ PyObject *
 PyNumber_InPlaceMultiply(PyObject *v, PyObject *w)
 {
        PyObject * (*g)(PyObject *, int) = NULL;
-       if (HASINPLACE(v) && v->ob_type->tp_as_sequence &&
-               (g = v->ob_type->tp_as_sequence->sq_inplace_repeat)) {
+       if (HASINPLACE(v) &&
+           v->ob_type->tp_as_sequence &&
+           (g = v->ob_type->tp_as_sequence->sq_inplace_repeat) &&
+           !(v->ob_type->tp_as_number &&
+             v->ob_type->tp_as_number->nb_inplace_multiply))
+       {
                long n;
                if (PyInt_Check(w)) {
                        n  = PyInt_AsLong(w);