1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
# See if we need to work around bugs in glibc's implementation of
# utimes from 2003-07-12 to 2003-09-17.
# First, there was a bug that would make utimes set mtime
# and atime to zero (1970-01-01) unconditionally.
# Then, there was code to round rather than truncate.
# Then, there was an implementation (sparc64, Linux-2.4.28, glibc-2.3.3)
# that didn't honor the NULL-means-set-to-current-time semantics.
#
# From Jim Meyering, with suggestions from Paul Eggert.
AC_DEFUN([gl_FUNC_UTIMES],
[
AC_CACHE_CHECK([determine whether the utimes function works],
gl_cv_func_working_utimes,
[
AC_RUN_IFELSE([AC_LANG_SOURCE([[
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/time.h>
#include <time.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <utime.h>
int
main ()
{
static struct timeval timeval[2] = {{9, 10}, {999999, 999999}};
struct stat sbuf;
char const *file = "conftest.utimes";
FILE *f;
time_t now;
int ok = ((f = fopen (file, "w"))
&& fclose (f) == 0
&& utimes (file, timeval) == 0
&& lstat (file, &sbuf) == 0
&& sbuf.st_atime == timeval[0].tv_sec
&& sbuf.st_mtime == timeval[1].tv_sec);
unlink (file);
if (!ok)
exit (1);
ok =
((f = fopen (file, "w"))
&& fclose (f) == 0
&& time (&now) != (time_t)-1
&& utimes (file, NULL) == 0
&& lstat (file, &sbuf) == 0
&& now - sbuf.st_atime <= 2
&& now - sbuf.st_mtime <= 2);
unlink (file);
exit (!ok);
}
]])],
[gl_cv_func_working_utimes=yes],
[gl_cv_func_working_utimes=no],
[gl_cv_func_working_utimes=no])])
if test $gl_cv_func_working_utimes = yes; then
AC_DEFINE([HAVE_WORKING_UTIMES], 1, [Define if utimes works properly. ])
fi
])
|