aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2005-09-23 19:18:27 +0000
committerPaul Eggert <eggert@cs.ucla.edu>2005-09-23 19:18:27 +0000
commitb9830cafa127d8a3e072bd1abb90feb9181423f7 (patch)
treed685b570d72657296c19a3f628fb2b795b88b231
parentFix typo in comment. (diff)
downloadcoreutils-b9830cafa127d8a3e072bd1abb90feb9181423f7.tar.gz
coreutils-b9830cafa127d8a3e072bd1abb90feb9181423f7.zip
* lib/utimens.c (futimens): Use futimesat if available.
Prefer it to futimes since it doesn't have the futimes bug. * m4/utimens.m4 (gl_UTIMENS): Check for futimesat.
-rw-r--r--lib/utimens.c12
-rw-r--r--m4/utimens.m42
2 files changed, 10 insertions, 4 deletions
diff --git a/lib/utimens.c b/lib/utimens.c
index 3f4d5e616..0b2f3e4d0 100644
--- a/lib/utimens.c
+++ b/lib/utimens.c
@@ -25,6 +25,7 @@
#include "utimens.h"
#include <errno.h>
+#include <fcntl.h>
#if HAVE_UTIME_H
# include <utime.h>
@@ -61,7 +62,7 @@ futimens (int fd ATTRIBUTE_UNUSED,
/* There's currently no interface to set file timestamps with
nanosecond resolution, so do the best we can, discarding any
fractional part of the timestamp. */
-#if HAVE_WORKING_UTIMES
+#if HAVE_FUTIMESAT || HAVE_WORKING_UTIMES
struct timeval timeval[2];
struct timeval const *t;
if (timespec)
@@ -74,7 +75,11 @@ futimens (int fd ATTRIBUTE_UNUSED,
}
else
t = NULL;
-# if HAVE_FUTIMES
+
+# if HAVE_FUTIMESAT
+ return fd < 0 ? futimesat (AT_FDCWD, file, t) : futimesat (fd, NULL, t);
+# else
+# if HAVE_FUTIMES
if (0 <= fd)
{
if (futimes (fd, t) == 0)
@@ -92,8 +97,9 @@ futimens (int fd ATTRIBUTE_UNUSED,
return -1;
}
}
-# endif
+# endif
return utimes (file, t);
+# endif
#else
diff --git a/m4/utimens.m4 b/m4/utimens.m4
index bb446c820..10f682191 100644
--- a/m4/utimens.m4
+++ b/m4/utimens.m4
@@ -13,5 +13,5 @@ AC_DEFUN([gl_UTIMENS],
AC_REQUIRE([gl_FUNC_UTIMES])
AC_REQUIRE([gl_CHECK_TYPE_STRUCT_TIMESPEC])
AC_REQUIRE([gl_CHECK_TYPE_STRUCT_UTIMBUF])
- AC_CHECK_FUNCS_ONCE(futimes)
+ AC_CHECK_FUNCS_ONCE([futimes futimesat])
])