X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=tests%2Ftest-frexp.c;h=0cd08230bed925c422f12704c8b0848b306ffcc8;hb=4754ac9d681d36e16e92a1b08efb1d334d7b3829;hp=47db2bec4545d461cf5858cb0014f50ec09ee098;hpb=b17d7ac7df62c7c7f56fe857ed28151d8b0e4e28;p=gnulib.git diff --git a/tests/test-frexp.c b/tests/test-frexp.c index 47db2bec4..0cd08230b 100644 --- a/tests/test-frexp.c +++ b/tests/test-frexp.c @@ -24,7 +24,13 @@ #include #include -#include "isnand.h" +#include "isnand-nolibm.h" +#include "nan.h" + +/* Avoid some warnings from "gcc -Wshadow". + This file doesn't use the exp() function. */ +#undef exp +#define exp exponent #define ASSERT(expr) \ do \ @@ -32,22 +38,15 @@ if (!(expr)) \ { \ fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \ + fflush (stderr); \ abort (); \ } \ } \ while (0) -/* The Compaq (ex-DEC) C 6.4 compiler chokes on the expression 0.0 / 0.0. */ -#ifdef __DECC -static double -NaN () -{ - static double zero = 0.0; - return zero / zero; -} -#else -# define NaN() (0.0 / 0.0) -#endif +/* HP cc on HP-UX 10.20 has a bug with the constant expression -0.0. + So we use -zero instead. */ +double zero = 0.0; static double my_ldexp (double x, int d) @@ -73,7 +72,7 @@ main () { /* NaN. */ int exp = -9999; double mantissa; - x = NaN (); + x = NaNd (); mantissa = frexp (x, &exp); ASSERT (isnand (mantissa)); } @@ -107,7 +106,7 @@ main () { /* Negative zero. */ int exp = -9999; double mantissa; - x = -0.0; + x = -zero; mantissa = frexp (x, &exp); ASSERT (exp == 0); ASSERT (mantissa == x);