diff options
author | Bryce McKinlay <bryce@waitaki.otago.ac.nz> | 2002-02-15 05:53:29 +0000 |
---|---|---|
committer | Bryce McKinlay <bryce@gcc.gnu.org> | 2002-02-15 05:53:29 +0000 |
commit | 15b28697de9a1f3ca0cbfb7cfb7fba09e13c8bec (patch) | |
tree | a355ada9dc8bbf6435c3cbc6f0d523b7655a99ce /libjava/java/lang/natMath.cc | |
parent | 2f999d0fe7641fe5c77fcfe90c65c3a6edbce6a7 (diff) | |
download | gcc-15b28697de9a1f3ca0cbfb7cfb7fba09e13c8bec.zip gcc-15b28697de9a1f3ca0cbfb7cfb7fba09e13c8bec.tar.gz gcc-15b28697de9a1f3ca0cbfb7cfb7fba09e13c8bec.tar.bz2 |
Makefile.in: Rebuilt with Eric's change below.
* Makefile.in: Rebuilt with Eric's change below.
* java/lang/natMath.cc (abs(jdouble), abs(jfloat), round(jfloat),
round(jdouble), min(jfloat), max(jfloat), min(jdouble), min(jfloat)):
Removed functions which are now implemented in Math.java.
From-SVN: r49782
Diffstat (limited to 'libjava/java/lang/natMath.cc')
-rw-r--r-- | libjava/java/lang/natMath.cc | 123 |
1 files changed, 1 insertions, 122 deletions
diff --git a/libjava/java/lang/natMath.cc b/libjava/java/lang/natMath.cc index a802a94..1903e27 100644 --- a/libjava/java/lang/natMath.cc +++ b/libjava/java/lang/natMath.cc @@ -1,4 +1,4 @@ -/* Copyright (C) 1998, 1999, 2000 Free Software Foundation +/* Copyright (C) 1998, 1999, 2000, 2002 Free Software Foundation This file is part of libgcj. @@ -27,8 +27,6 @@ details. */ #include "fdlibm.h" -extern "C" float fabsf (float); - jdouble java::lang::Math::cos(jdouble x) { return (jdouble)::cos((double)x); @@ -89,45 +87,11 @@ jdouble java::lang::Math::IEEEremainder(jdouble y, jdouble x) return (jdouble)::__ieee754_remainder((double)y, (double)x); } -jdouble java::lang::Math::abs(jdouble x) -{ - return (jdouble)::fabs((double)x); -} - -jfloat java::lang::Math::abs(jfloat x) -{ - return (jfloat)::fabsf((float)x); -} - jdouble java::lang::Math::rint(jdouble x) { return (jdouble)::rint((double)x); } -jint java::lang::Math::round(jfloat x) -{ - if (x != x) - return 0; - if (x <= (jfloat)java::lang::Integer::MIN_VALUE) - return java::lang::Integer::MIN_VALUE; - if (x >= (jfloat)java::lang::Integer::MAX_VALUE) - return java::lang::Integer::MAX_VALUE; - - return (jint)::rintf((float)x); -} - -jlong java::lang::Math::round(jdouble x) -{ - if (x != x) - return 0; - if (x <= (jdouble)java::lang::Long::MIN_VALUE) - return java::lang::Long::MIN_VALUE; - if (x >= (jdouble)java::lang::Long::MAX_VALUE) - return java::lang::Long::MAX_VALUE; - - return (jlong)::rint((double)x); -} - jdouble java::lang::Math::floor(jdouble x) { return (jdouble)::floor((double)x); @@ -158,48 +122,6 @@ isNaN (jint bits) return e == 0x7f800000 && f != 0; } -jfloat -java::lang::Math::min(jfloat a, jfloat b) -{ - jint abits = floatToIntBits (a); - jint bbits = floatToIntBits (b); - - if (isNaN (abits) || isNaN (bbits)) - return java::lang::Float::NaN; - - if (abits >= 0) // a is +ve - return bbits < 0 ? b // a is +ve, b is -ve. - // a and b are both +ve, so compare magnitudes: the number with - // the smallest magnitude is the smallest - : (abits < bbits ? a : b); - else // a is -ve - return bbits >= 0 ? a // a is -ve, b is +ve. - // a and b are both -ve, so compare magnitudes: the number with - // the biggest magnitude is the smallest - : (abits > bbits ? a : b); -} - -jfloat -java::lang::Math::max(jfloat a, jfloat b) -{ - jint abits = floatToIntBits (a); - jint bbits = floatToIntBits (b); - - if (isNaN (abits) || isNaN (bbits)) - return java::lang::Float::NaN; - - if (abits >= 0) // a is +ve - return bbits < 0 ? a // a is +ve, b is -ve. - // a and b are both +ve, so compare magnitudes: the number with - // the smallest magnitude is the smallest - : (abits > bbits ? a : b); - else // a is -ve - return bbits >= 0 ? b // a is -ve, b is +ve. - // a and b are both -ve, so compare magnitudes: the number with - // the biggest magnitude is the smallest - : (abits < bbits ? a : b); -} - static inline jlong doubleToLongBits (jdouble value) { @@ -220,46 +142,3 @@ isNaN (jlong bits) return e == 0x7ff0000000000000LL && f != 0LL; } - -jdouble -java::lang::Math::min(jdouble a, jdouble b) -{ - jlong abits = doubleToLongBits (a); - jlong bbits = doubleToLongBits (b); - - if (isNaN (abits) || isNaN (bbits)) - return java::lang::Double::NaN; - - if (abits >= 0LL) // a is +ve - return bbits < 0LL ? b // a is +ve, b is -ve. - // a and b are both +ve, so compare magnitudes: the number with - // the smallest magnitude is the smallest - : (abits < bbits ? a : b); - else // a is -ve - return bbits >= 0LL ? a // a is -ve, b is +ve. - // a and b are both -ve, so compare magnitudes: the number with - // the biggest magnitude is the smallest - : (abits > bbits ? a : b); -} - -jdouble -java::lang::Math::max(jdouble a, jdouble b) -{ - jlong abits = doubleToLongBits (a); - jlong bbits = doubleToLongBits (b); - - if (isNaN (abits) || isNaN (bbits)) - return java::lang::Double::NaN; - - if (abits >= 0LL) // a is +ve - return bbits < 0LL ? a // a is +ve, b is -ve. - // a and b are both +ve, so compare magnitudes: the number with - // the smallest magnitude is the smallest - : (abits > bbits ? a : b); - else // a is -ve - return bbits >= 0LL ? b // a is -ve, b is +ve. - // a and b are both -ve, so compare magnitudes: the number with - // the biggest magnitude is the smallest - : (abits < bbits ? a : b); -} - |