diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | m4/ChangeLog | 5 | ||||
-rw-r--r-- | m4/jm-macros.m4 | 1 | ||||
-rw-r--r-- | m4/ullong_max.m4 | 57 | ||||
-rw-r--r-- | src/system.h | 20 |
5 files changed, 73 insertions, 16 deletions
@@ -1,7 +1,11 @@ -2005-01-03 Jim Meyering <jim@meyering.net> +2005-01-03 Paul Eggert <eggert@cs.ucla.edu> * Version 5.3.0. + * src/system.h: Undo previous change; we now use Autoconf. + +2005-01-03 Jim Meyering <jim@meyering.net> + * tests/stty/row-col-1: Don't set rows or columns to zero, to avoid a bug in the TIOCGWINSZ ioctl on at least Solaris5.9 systems. Setting either (or both) to zero would succeed, but subsequent `stty size' diff --git a/m4/ChangeLog b/m4/ChangeLog index e60bf7044..db28abe10 100644 --- a/m4/ChangeLog +++ b/m4/ChangeLog @@ -1,3 +1,8 @@ +2005-01-03 Paul Eggert <eggert@cs.ucla.edu> + + * ullong_max.m4: New file. + * jm-macros.m4 (gl_MACROS): Require gl_ULLONG_MAX. + 2005-01-03 Jim Meyering <jim@meyering.net> * mkstemp.m4 (gl_FUNC_MKSTEMP): Don't `cd' into the temporary diff --git a/m4/jm-macros.m4 b/m4/jm-macros.m4 index e03225c54..fd5a000f5 100644 --- a/m4/jm-macros.m4 +++ b/m4/jm-macros.m4 @@ -64,6 +64,7 @@ AC_DEFUN([gl_MACROS], # This is for od and stat, and any other program that # uses the PRI.MAX macros from inttypes.h. AC_REQUIRE([gt_INTTYPES_PRI]) + AC_REQUIRE([gl_ULLONG_MAX]) AC_REQUIRE([gl_FUNC_GETGROUPS]) diff --git a/m4/ullong_max.m4 b/m4/ullong_max.m4 new file mode 100644 index 000000000..f51e3d66a --- /dev/null +++ b/m4/ullong_max.m4 @@ -0,0 +1,57 @@ +# ullong_max.m4 - define ULLONG_MAX if necessary + +# Copyright (C) 2005 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 +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software Foundation, +# Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +# Written by Paul Eggert. + +AC_DEFUN([gl_ULLONG_MAX], +[ + dnl Avoid _AC_COMPUTE_INT-related macros, as they may not work with + dnl types wider than long int, due to problems with expr. + AC_CACHE_CHECK([for ULLONG_MAX], gl_cv_ullong_max, + [gl_cv_ullong_max=no + AC_EGREP_CPP([ULLONG_MAX is defined], + [ + #include <limits.h> + #ifdef ULLONG_MAX + "ULLONG_MAX is defined" + #endif + ], + [gl_cv_ullong_max=yes]) + case $gl_cv_ullong_max in + no) + for gl_expr in \ + 18446744073709551615ULL \ + 4722366482869645213695ULL \ + 340282366920938463463374607431768211455ULL + do + AC_TRY_COMPILE([], + [char test[$gl_expr == (unsigned long long int) -1 ? 1 : -1]; + static unsigned long long int i = $gl_expr; + return i && test;], + [gl_cv_ullong_max=$gl_expr]) + test $gl_cv_ullong_max != no && break + done + esac]) + case $gl_cv_ullong_max in + yes | no) ;; + *) + AC_DEFINE_UNQUOTED([ULLONG_MAX], [$gl_cv_ullong_max], + [Define as the maximum value of the type 'unsigned long long int', + if the system doesn't define it, and if the system has that type.]);; + esac +]) diff --git a/src/system.h b/src/system.h index 9fd123812..27aff00d7 100644 --- a/src/system.h +++ b/src/system.h @@ -368,38 +368,28 @@ initialize_exit_failure (int status) # include <stdint.h> #endif +#if ULONG_MAX < ULLONG_MAX +# define LONGEST_MODIFIER "ll" +#else +# define LONGEST_MODIFIER "l" +#endif #if PRI_MACROS_BROKEN # undef PRIdMAX # undef PRIoMAX # undef PRIuMAX # undef PRIxMAX #endif - -#if ULONG_MAX < ULLONG_MAX -# define LONGEST_MODIFIER "ll" -#else -# define LONGEST_MODIFIER "l" -#endif - #ifndef PRIdMAX # define PRIdMAX LONGEST_MODIFIER "d" -# defined USED_LONGEST_MODIFIER #endif #ifndef PRIoMAX # define PRIoMAX LONGEST_MODIFIER "o" -# defined USED_LONGEST_MODIFIER #endif #ifndef PRIuMAX # define PRIuMAX LONGEST_MODIFIER "u" -# defined USED_LONGEST_MODIFIER #endif #ifndef PRIxMAX # define PRIxMAX LONGEST_MODIFIER "x" -# defined USED_LONGEST_MODIFIER -#endif - -#if USED_LONGEST_MODIFIER && (!defined ULONG_MAX || !defined ULLONG_MAX) -# error "your PRI.MAX macros are broken and we don't work around it" #endif #include <ctype.h> |