From c7fb0b92185d393914931d0e1c48de3dc8bb91a7 Mon Sep 17 00:00:00 2001 From: Hans Boehm Date: Wed, 17 Jan 2001 01:00:53 +0000 Subject: [PATCH] BigInteger.java (setShiftRight): Only do negative shift if count != 0. 2001-01-16 Hans Boehm * java/math/BigInteger.java (setShiftRight): Only do negative shift if count != 0. From-SVN: r39080 --- libjava/ChangeLog | 5 +++++ libjava/java/math/BigInteger.java | 10 ++++++---- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 3ed758f29207..5b13ec04c9c8 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2001-01-16 Hans Boehm + + * java/math/BigInteger.java (setShiftRight): Only do negative shift + if count != 0. + 2001-01-14 Mark Wielaard * java/net/URLDecoder.java: Thanks Edgar Villanueva (edgarvil@home.com) (decode): Merge comments with Classpath, don't throw Exception diff --git a/libjava/java/math/BigInteger.java b/libjava/java/math/BigInteger.java index ed1f4f044cbe..d3fcb023475c 100644 --- a/libjava/java/math/BigInteger.java +++ b/libjava/java/math/BigInteger.java @@ -1401,11 +1401,13 @@ public class BigInteger extends Number implements Comparable realloc(d_len); if (count == 0) System.arraycopy(x.words, word_count, words, 0, d_len); - else - MPN.rshift(words, x.words, word_count, d_len, count); + else + { + MPN.rshift(words, x.words, word_count, d_len, count); + if (neg) + words[d_len-1] |= -1 << (32 - count); + } ival = d_len; - if (neg) - words[ival-1] |= -1 << (32 - count); } } }