ceil: Implement result sign according to IEEE 754.
[gnulib.git] / tests / test-ceilf-ieee.c
index 475e4f4..15a9fbf 100644 (file)
@@ -37,9 +37,20 @@ main (int argc, char **argv _GL_UNUSED)
 {
   float (*my_ceilf) (float) = argc ? ceilf : dummy;
 
+  /* 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 (my_ceilf (0.0f)));
   ASSERT (!!signbit (my_ceilf (minus_zerof)) == !!signbit (minus_zerof));
+  /* Positive numbers.  */
+  ASSERT (!signbit (my_ceilf (0.3f)));
+  ASSERT (!signbit (my_ceilf (0.7f)));
+  /* Negative numbers.  */
+  ASSERT (!!signbit (my_ceilf (-0.3f)) == !!signbit (minus_zerof));
+  ASSERT (!!signbit (my_ceilf (-0.7f)) == !!signbit (minus_zerof));
 
   return 0;
 }