summaryrefslogtreecommitdiffstats
path: root/libjava/java/math
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2002-12-19 06:59:46 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2002-12-19 06:59:46 +0000
commit3d2a8dc42d2d8d41f34e2a51f9114e96ee94ff40 (patch)
treeb20d44b018e021f20e342a2d3bc893edfb37e03c /libjava/java/math
parent80e9733bc9cc4c8fdfb9733be51811c7adf2dd80 (diff)
downloadppe42-gcc-3d2a8dc42d2d8d41f34e2a51f9114e96ee94ff40.tar.gz
ppe42-gcc-3d2a8dc42d2d8d41f34e2a51f9114e96ee94ff40.zip
2002-12-18 Raif Naffah <raif@fl.net.au>
* java/math/BigInteger.java (euclidInv): Make sure quot and rem are in canonical form after divide(). (modInverse): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@60292 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java/math')
-rw-r--r--libjava/java/math/BigInteger.java6
1 files changed, 6 insertions, 0 deletions
diff --git a/libjava/java/math/BigInteger.java b/libjava/java/math/BigInteger.java
index e8c6b1dfdc9..ac21eccc518 100644
--- a/libjava/java/math/BigInteger.java
+++ b/libjava/java/math/BigInteger.java
@@ -1113,6 +1113,9 @@ public class BigInteger extends Number implements Comparable
BigInteger rem = new BigInteger();
BigInteger quot = new BigInteger();
divide(a, b, quot, rem, FLOOR);
+ // quot and rem may not be in canonical form. ensure
+ rem.canonicalize();
+ quot.canonicalize();
xy = euclidInv(b, rem, quot);
}
@@ -1192,6 +1195,9 @@ public class BigInteger extends Number implements Comparable
BigInteger rem = new BigInteger();
BigInteger quot = new BigInteger();
divide(x, y, quot, rem, FLOOR);
+ // quot and rem may not be in canonical form. ensure
+ rem.canonicalize();
+ quot.canonicalize();
result = euclidInv(y, rem, quot)[swapped ? 0 : 1];
// Result can't be negative, so make it positive by adding the
OpenPOWER on IntegriCloud