New module 'ceill'.
authorBruno Haible <bruno@clisp.org>
Fri, 5 Oct 2007 01:54:50 +0000 (03:54 +0200)
committerBruno Haible <bruno@clisp.org>
Fri, 5 Oct 2007 01:54:50 +0000 (03:54 +0200)
ChangeLog
doc/functions/ceill.texi
lib/ceill.c
lib/math.in.h
m4/ceill.m4 [new file with mode: 0644]
m4/math_h.m4
modules/ceill [new file with mode: 0644]
modules/math
modules/mathl

index 6f7bd02..2f226a4 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,17 @@
 2007-10-04  Bruno Haible  <bruno@clisp.org>
 
+       * modules/ceill: New file.
+       * lib/ceill.c: Replace entire file.
+       * m4/ceill.m4: New file.
+       * lib/math.in.h (ceill): Replace declaration.
+       * m4/math_h.m4 (gl_MATH_H_DEFAULTS): Initialize GNULIB_CEILL.
+       * modules/math (Makefile.am): Substitute also GNULIB_CEILL.
+       * doc/functions/ceill.texi: Mention the 'ceill' module.
+       * modules/mathl (Files): Remove lib/ceill.c.
+       (Depends-on): Add ceill.
+
+2007-10-04  Bruno Haible  <bruno@clisp.org>
+
        * modules/ceilf-tests: New file.
        * tests/test-ceilf.c: New file.
 
index ed5006f..eb12db2 100644 (file)
@@ -4,15 +4,15 @@
 
 POSIX specification: @url{http://www.opengroup.org/susv3xsh/ceill.html}
 
-Gnulib module: ---
+Gnulib module: ceill
 
 Portability problems fixed by Gnulib:
 @itemize
+@item
+This function is missing on some platforms:
+FreeBSD 5.2.1, NetBSD 3.0, OpenBSD 3.8, HP-UX 11, IRIX 6.5, Solaris 9, Cygwin, Interix 3.5, BeOS.
 @end itemize
 
 Portability problems not fixed by Gnulib:
 @itemize
-@item
-This function is missing on some platforms:
-FreeBSD 5.2.1, NetBSD 3.0, OpenBSD 3.8, HP-UX 11, IRIX 6.5, Solaris 9, Cygwin, Interix 3.5, BeOS.
 @end itemize
index 9eb1ba0..4c65cd2 100644 (file)
@@ -1,9 +1,5 @@
-/* Emulation for ceill.
-   Contributed by Paolo Bonzini
-
-   Copyright 2002, 2003, 2007 Free Software Foundation, Inc.
-
-   This file is part of gnulib.
+/* Round towards positive infinity.
+   Copyright (C) 2007 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
    with this program; if not, write to the Free Software Foundation,
    Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
 
-#include <config.h>
-
-/* Specification.  */
-#include <math.h>
-
-#include <float.h>
-
-/* To compute the integer part of X, sum a big enough
-   integer so that the precision of the floating point
-   number is exactly 1.  */
-
-long double
-ceill(long double x)
-{
-  long double y;
-  if (x < 0.0L)
-    y = -(1.0L / LDBL_EPSILON - x - 1.0 / LDBL_EPSILON);
-  else
-    y = 1.0L / LDBL_EPSILON + x - 1.0 / LDBL_EPSILON;
+/* Written by Bruno Haible <bruno@clisp.org>, 2007.  */
 
-  if (y < x)
-    return y + 1.0L;
-  else
-    return y;
-}
+#define USE_LONG_DOUBLE
+#include "ceil.c"
index ef0682a..b5dc1ea 100644 (file)
@@ -103,14 +103,16 @@ extern float ceilf (float x);
      ceilf (x))
 #endif
 
-#if @GNULIB_MATHL@ || !@HAVE_DECL_CEILL@
+#if @GNULIB_CEILL@
+# if !@HAVE_DECL_CEILL@
+#  define ceill rpl_ceill
 extern long double ceill (long double x);
-#endif
-#if !@GNULIB_MATHL@ && defined GNULIB_POSIXCHECK
+# endif
+#elif defined GNULIB_POSIXCHECK
 # undef ceill
 # define ceill(x) \
     (GL_LINK_WARNING ("ceill is unportable - " \
-                      "use gnulib module mathl for portability"), \
+                      "use gnulib module ceill for portability"), \
      ceill (x))
 #endif
 
diff --git a/m4/ceill.m4 b/m4/ceill.m4
new file mode 100644 (file)
index 0000000..7413a31
--- /dev/null
@@ -0,0 +1,48 @@
+# ceill.m4 serial 1
+dnl Copyright (C) 2007 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+AC_DEFUN([gl_FUNC_CEILL],
+[
+  AC_REQUIRE([gl_MATH_H_DEFAULTS])
+  dnl Persuade glibc <math.h> to declare ceill().
+  AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
+  dnl Test whether ceill() is declared.
+  AC_CHECK_DECLS([ceill], , , [#include <math.h>])
+  if test "$ac_cv_have_decl_ceill" = yes; then
+    dnl Test whether ceill() can be used without libm.
+    CEILL_LIBM=?
+    AC_TRY_LINK([
+       #ifndef __NO_MATH_INLINES
+       # define __NO_MATH_INLINES 1 /* for glibc */
+       #endif
+       #include <math.h>
+       long double x;],
+      [x = ceill(x);],
+      [CEILL_LIBM=])
+    if test "$CEILL_LIBM" = "?"; then
+      save_LIBS="$LIBS"
+      LIBS="$LIBS -lm"
+      AC_TRY_LINK([
+         #ifndef __NO_MATH_INLINES
+         # define __NO_MATH_INLINES 1 /* for glibc */
+         #endif
+         #include <math.h>
+         long double x;],
+        [x = ceill(x);],
+        [CEILL_LIBM="-lm"])
+      LIBS="$save_LIBS"
+    fi
+    if test "$CEILL_LIBM" = "?"; then
+      CEILL_LIBM=
+    fi
+  else
+    HAVE_DECL_CEILL=0
+    AC_LIBOBJ([ceill])
+    CEILL_LIBM=
+  fi
+  AC_SUBST([HAVE_DECL_CEILL])
+  AC_SUBST([CEILL_LIBM])
+])
index 76d5dbc..5539d79 100644 (file)
@@ -20,6 +20,7 @@ AC_DEFUN([gl_MATH_MODULE_INDICATOR],
 AC_DEFUN([gl_MATH_H_DEFAULTS],
 [
   GNULIB_CEILF=0;   AC_SUBST([GNULIB_CEILF])
+  GNULIB_CEILL=0;   AC_SUBST([GNULIB_CEILL])
   GNULIB_FLOORF=0;  AC_SUBST([GNULIB_FLOORF])
   GNULIB_FLOORL=0;  AC_SUBST([GNULIB_FLOORL])
   GNULIB_FREXP=0;   AC_SUBST([GNULIB_FREXP])
diff --git a/modules/ceill b/modules/ceill
new file mode 100644 (file)
index 0000000..a2365c2
--- /dev/null
@@ -0,0 +1,31 @@
+Description:
+ceill() function: round towards positive infinity.
+
+Files:
+lib/ceill.c
+lib/ceil.c
+m4/ceill.m4
+
+Depends-on:
+math
+extensions
+float
+
+configure.ac:
+gl_FUNC_CEILL
+gl_MATH_MODULE_INDICATOR([ceill])
+
+Makefile.am:
+
+Include:
+<math.h>
+
+Link:
+$(CEILL_LIBM)
+
+License:
+LGPL
+
+Maintainer:
+Bruno Haible
+
index 0a41904..15e16e6 100644 (file)
@@ -23,6 +23,7 @@ math.h: math.in.h
          sed -e 's/@''INCLUDE_NEXT''@/$(INCLUDE_NEXT)/g' \
              -e 's|@''NEXT_MATH_H''@|$(NEXT_MATH_H)|g' \
              -e 's|@''GNULIB_CEILF''@|$(GNULIB_CEILF)|g' \
+             -e 's|@''GNULIB_CEILL''@|$(GNULIB_CEILL)|g' \
              -e 's|@''GNULIB_FLOORF''@|$(GNULIB_FLOORF)|g' \
              -e 's|@''GNULIB_FLOORL''@|$(GNULIB_FLOORL)|g' \
              -e 's|@''GNULIB_FREXP''@|$(GNULIB_FREXP)|g' \
index 1008cba..e8ee822 100644 (file)
@@ -5,7 +5,6 @@ Files:
 lib/acosl.c
 lib/asinl.c
 lib/atanl.c
-lib/ceill.c
 lib/cosl.c
 lib/expl.c
 lib/logl.c
@@ -24,6 +23,7 @@ frexpl
 isnanl
 ldexpl
 floorl
+ceill
 
 configure.ac:
 gl_FUNC_LONG_DOUBLE_MATH