From: Bruno Haible Date: Sun, 9 Oct 2011 23:05:53 +0000 (+0200) Subject: truncl: Simplify for platforms where 'long double' == 'double'. X-Git-Tag: v0.1~1600 X-Git-Url: http://erislabs.org.uk/gitweb/?a=commitdiff_plain;h=3d57d93ced65ddec292e320e35fb648dff34cd83;p=gnulib.git truncl: Simplify for platforms where 'long double' == 'double'. * lib/truncl.c: Include . (truncl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New function. * lib/trunc.c [!USE_LONG_DOUBLE]: Don't include a second time. * m4/truncl.m4 (gl_FUNC_TRUNCL): Require gl_LONG_DOUBLE_VS_DOUBLE. Determine TRUNCL_LIBM according to HAVE_SAME_LONG_DOUBLE_AS_DOUBLE. * modules/truncl (Depends-on): Add trunc. Update conditions. --- diff --git a/ChangeLog b/ChangeLog index 909a202b5..64549f443 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,16 @@ 2011-10-09 Bruno Haible + truncl: Simplify for platforms where 'long double' == 'double'. + * lib/truncl.c: Include . + (truncl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New function. + * lib/trunc.c [!USE_LONG_DOUBLE]: Don't include a second + time. + * m4/truncl.m4 (gl_FUNC_TRUNCL): Require gl_LONG_DOUBLE_VS_DOUBLE. + Determine TRUNCL_LIBM according to HAVE_SAME_LONG_DOUBLE_AS_DOUBLE. + * modules/truncl (Depends-on): Add trunc. Update conditions. + +2011-10-09 Bruno Haible + ceill: Simplify for platforms where 'long double' == 'double'. * lib/ceill.c: Include . (ceill) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New function. diff --git a/lib/trunc.c b/lib/trunc.c index 16403f79b..73a334561 100644 --- a/lib/trunc.c +++ b/lib/trunc.c @@ -16,7 +16,9 @@ /* Written by Bruno Haible , 2007. */ -#include +#if ! defined USE_LONG_DOUBLE +# include +#endif /* Specification. */ #include diff --git a/lib/truncl.c b/lib/truncl.c index aa0d40549..8af2c5c6e 100644 --- a/lib/truncl.c +++ b/lib/truncl.c @@ -16,5 +16,22 @@ /* Written by Bruno Haible , 2007. */ -#define USE_LONG_DOUBLE -#include "trunc.c" +#include + +#if HAVE_SAME_LONG_DOUBLE_AS_DOUBLE + +/* Specification. */ +# include + +long double +truncl (long double x) +{ + return trunc (x); +} + +#else + +# define USE_LONG_DOUBLE +# include "trunc.c" + +#endif diff --git a/m4/truncl.m4 b/m4/truncl.m4 index e6110c33f..c4a99719a 100644 --- a/m4/truncl.m4 +++ b/m4/truncl.m4 @@ -1,4 +1,4 @@ -# truncl.m4 serial 9 +# truncl.m4 serial 10 dnl Copyright (C) 2007-2008, 2010-2011 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, @@ -8,9 +8,12 @@ AC_DEFUN([gl_FUNC_TRUNCL], [ m4_divert_text([DEFAULTS], [gl_truncl_required=plain]) AC_REQUIRE([gl_MATH_H_DEFAULTS]) + AC_REQUIRE([gl_LONG_DOUBLE_VS_DOUBLE]) AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles + dnl Persuade glibc to declare truncl(). AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS]) + dnl Test whether truncl() is declared. AC_CHECK_DECLS([truncl], , , [[#include ]]) if test "$ac_cv_have_decl_truncl" = yes; then @@ -109,8 +112,13 @@ int main (int argc, char *argv[]) HAVE_DECL_TRUNCL=0 fi if test $HAVE_DECL_TRUNCL = 0 || test $REPLACE_TRUNCL = 1; then - dnl No libraries are needed to link lib/truncl.c. - TRUNCL_LIBM= + dnl Find libraries needed to link lib/truncl.c. + if test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1; then + AC_REQUIRE([gl_FUNC_TRUNC]) + TRUNCL_LIBM="$TRUNC_LIBM" + else + TRUNCL_LIBM= + fi fi AC_SUBST([TRUNCL_LIBM]) ]) diff --git a/modules/truncl b/modules/truncl index 8dbb75280..f02d61e0c 100644 --- a/modules/truncl +++ b/modules/truncl @@ -9,7 +9,8 @@ m4/truncl.m4 Depends-on: math extensions -float [test $HAVE_DECL_TRUNCL = 0 || test $REPLACE_TRUNCL = 1] +trunc [{ test $HAVE_DECL_TRUNCL = 0 || test $REPLACE_TRUNCL = 1; } && test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1] +float [{ test $HAVE_DECL_TRUNCL = 0 || test $REPLACE_TRUNCL = 1; } && test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 0] configure.ac: gl_FUNC_TRUNCL