X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=tests%2Ftest-trunc-ieee.c;h=b6b90c10f65c4dffa0a3441b4d40fbaf4fa55440;hb=08998910dd73aad59b78886ab01ab96f7d1e9c38;hp=c0fc0f262bfb62c0668b89d3d849354480561304;hpb=0c5e7922f80eae16b5a89233d5a8c0d1f88c18a7;p=gnulib.git diff --git a/tests/test-trunc-ieee.c b/tests/test-trunc-ieee.c index c0fc0f262..b6b90c10f 100644 --- a/tests/test-trunc-ieee.c +++ b/tests/test-trunc-ieee.c @@ -1,5 +1,5 @@ /* Test of rounding towards zero. - Copyright (C) 2010 Free Software Foundation, Inc. + Copyright (C) 2010-2012 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -18,15 +18,37 @@ #include +#include "isnand-nolibm.h" #include "minus-zero.h" +#include "infinity.h" +#include "nan.h" #include "macros.h" int main () { + /* See IEEE 754, section 6.3: + "the sign of the result of the round floating-point number to + integral value operation is the sign of the operand. These rules + shall apply even when operands or results are zero or infinite." */ + /* Zero. */ ASSERT (!signbit (trunc (0.0))); ASSERT (!!signbit (trunc (minus_zerod)) == !!signbit (minus_zerod)); + /* Positive numbers. */ + ASSERT (!signbit (trunc (0.3))); + ASSERT (!signbit (trunc (0.7))); + /* Negative numbers. */ + ASSERT (!!signbit (trunc (-0.3)) == !!signbit (minus_zerod)); + ASSERT (!!signbit (trunc (-0.7)) == !!signbit (minus_zerod)); + + /* [MX] shaded specification in POSIX. */ + + /* NaN. */ + ASSERT (isnand (trunc (NaNd ()))); + /* Infinity. */ + ASSERT (trunc (Infinityd ()) == Infinityd ()); + ASSERT (trunc (- Infinityd ()) == - Infinityd ()); return 0; }