From: Guido van Rossum Date: Mon, 6 Jan 1997 22:53:20 +0000 (+0000) Subject: Fix overflow test for multiply to catch some cases it missed. X-Git-Tag: v1.5a1~573 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=541cdd84aceaec11895c31a6f5afe8a60806cee3;p=python Fix overflow test for multiply to catch some cases it missed. Added warning about dependency of float/complex hash on int hash. --- diff --git a/Objects/intobject.c b/Objects/intobject.c index 62649209bf..3598c90e8e 100644 --- a/Objects/intobject.c +++ b/Objects/intobject.c @@ -237,6 +237,8 @@ static long int_hash(v) intobject *v; { + /* XXX If this is changed, you also need to change the way + Python's long, float and complex types are hashed. */ long x = v -> ob_ival; if (x == -1) x = -2; @@ -385,13 +387,13 @@ int_mul(v, w) (NB b == bl in this case, and we make a = al) */ y = ah*b; - if (y >= (1L << (LONG_BIT/2))) + if (y >= (1L << (LONG_BIT/2 - 1))) goto bad; a &= (1L << (LONG_BIT/2)) - 1; x = a*b; if (x < 0) goto bad; - x += y << LONG_BIT/2; + x += y << (LONG_BIT/2); if (x < 0) goto bad; ok: