]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
backport gvanrossum's checkin of
authorMichael W. Hudson <mwh@python.net>
Tue, 5 Mar 2002 15:37:18 +0000 (15:37 +0000)
committerMichael W. Hudson <mwh@python.net>
Tue, 5 Mar 2002 15:37:18 +0000 (15:37 +0000)
    revision 1.115 of test_descr.py

SF patch 514641 (Naofumi Honda) - Negative ob_size of LongObjects

Due to the bizarre definition of _PyLong_Copy(), creating an instance
of a subclass of long with a negative value could cause core dumps
later on.  Unfortunately it looks like the behavior of _PyLong_Copy()
is quite intentional, so the fix is more work than feels comfortable.

This fix is almost, but not quite, the code that Naofumi Honda added;
in addition, I added a test case.

I haven't quite worked out how to port the fix yet, but the test cases
can go straight over.

Lib/test/test_descr.py

index dd95ddeb91e2ef9b153154ee1ade3188daf69f14..e667efb18af72c6f4e8bb75a5e9e2d84e14a0228 100644 (file)
@@ -1748,6 +1748,10 @@ def inherits():
     verify((a + 0).__class__ is long)
     verify((0 + a).__class__ is long)
 
+    # Check that negative clones don't segfault
+    a = longclone(-1)
+    vereq(a.__dict__, {})
+
     class precfloat(float):
         __slots__ = ['prec']
         def __init__(self, value=0.0, prec=12):