diff options
author | Jim Meyering <jim@meyering.net> | 1997-11-13 14:29:18 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1997-11-13 14:29:18 +0000 |
commit | df29ef2431efcbcdd213a5e215c9323219099f0d (patch) | |
tree | 9a6dba599d2a9e830e0cd4e64875e58fa0d93260 /m4 | |
parent | 3022e9b8065f93e0f40bea79604584fb590f09e6 (diff) | |
download | coreutils-df29ef2431efcbcdd213a5e215c9323219099f0d.tar.xz |
.
Diffstat (limited to 'm4')
-rw-r--r-- | m4/mktime.m4 | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/m4/mktime.m4 b/m4/mktime.m4 new file mode 100644 index 000000000..4be030aa1 --- /dev/null +++ b/m4/mktime.m4 @@ -0,0 +1,75 @@ +#serial 2 + +dnl From Jim Meyering. +dnl FIXME: this should migrate into libit. + +AC_DEFUN(AM_FUNC_MKTIME, +[AC_REQUIRE([AC_HEADER_TIME])dnl + AC_CHECK_HEADERS(sys/time.h) + AC_CACHE_CHECK([for working mktime], am_cv_func_working_mktime, + [AC_TRY_RUN( +changequote(<<, >>)dnl +<</* Test program from Paul Eggert (eggert@twinsun.com) + and Tony Leneis (tony@plaza.ds.adp.com). */ +#if TIME_WITH_SYS_TIME +# include <sys/time.h> +# include <time.h> +#else +# if HAVE_SYS_TIME_H +# include <sys/time.h> +# else +# include <time.h> +# endif +#endif + +static time_t time_t_max; + +/* Values we'll use to set the TZ environment variable. */ +static const char *const tz_strings[] = { + NULL, "GMT0", "JST-9", "EST+3EDT+2,M10.1.0/00:00:00,M2.3.0/00:00:00" +}; +#define N_STRINGS (sizeof (tz_strings) / sizeof (tz_strings[0])) + +static void +mktime_test (now) + time_t now; +{ + if (mktime (localtime (&now)) != now) + exit (1); + now = time_t_max - now; + if (mktime (localtime (&now)) != now) + exit (1); +} + +int +main () +{ + time_t t, delta; + int i; + + for (time_t_max = 1; 0 < time_t_max; time_t_max *= 2) + continue; + time_t_max--; + delta = time_t_max / 997; /* a suitable prime number */ + for (i = 0; i < N_STRINGS; i++) + { + if (tz_strings[i]) + putenv (tz_strings[i]); + + for (t = 0; t <= time_t_max - delta; t += delta) + mktime_test (t); + mktime_test ((time_t) 60 * 60); + mktime_test ((time_t) 60 * 60 * 24); + } + exit (0); +} + >>, +changequote([, ])dnl + am_cv_func_working_mktime=yes, am_cv_func_working_mktime=no, + dnl When crosscompiling, assume mktime is missing or broken. + am_cv_func_working_mktime=no) + ]) + if test $am_cv_func_working_mktime = no; then + LIBOBJS="$LIBOBJS mktime.o" + fi +]) |