diff options
author | jilles <jilles@FreeBSD.org> | 2015-02-17 13:12:54 +0000 |
---|---|---|
committer | jilles <jilles@FreeBSD.org> | 2015-02-17 13:12:54 +0000 |
commit | b98f732ce74d7ae47e2fc0373f850cec1a8c2ce8 (patch) | |
tree | d989f5cf52fa60de20029a0d631f3107bc5d494a /usr.bin | |
parent | 5b8b9e9db4c50f8207dd451869a9bd9606470db7 (diff) | |
download | FreeBSD-src-b98f732ce74d7ae47e2fc0373f850cec1a8c2ce8.zip FreeBSD-src-b98f732ce74d7ae47e2fc0373f850cec1a8c2ce8.tar.gz |
compress,gzip,xz: Preserve timestamps with nanosecond precision.
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/compress/compress.c | 11 | ||||
-rw-r--r-- | usr.bin/gzip/gzip.c | 10 |
2 files changed, 11 insertions, 10 deletions
diff --git a/usr.bin/compress/compress.c b/usr.bin/compress/compress.c index 1f458e5..2d2efb3 100644 --- a/usr.bin/compress/compress.c +++ b/usr.bin/compress/compress.c @@ -48,6 +48,7 @@ __FBSDID("$FreeBSD$"); #include <err.h> #include <errno.h> +#include <fcntl.h> #include <stdarg.h> #include <stdio.h> #include <stdlib.h> @@ -360,14 +361,14 @@ err: if (ofp) { static void setfile(const char *name, struct stat *fs) { - static struct timeval tv[2]; + static struct timespec tspec[2]; fs->st_mode &= S_ISUID|S_ISGID|S_IRWXU|S_IRWXG|S_IRWXO; - TIMESPEC_TO_TIMEVAL(&tv[0], &fs->st_atim); - TIMESPEC_TO_TIMEVAL(&tv[1], &fs->st_mtim); - if (utimes(name, tv)) - cwarn("utimes: %s", name); + tspec[0] = fs->st_atim; + tspec[1] = fs->st_mtim; + if (utimensat(AT_FDCWD, name, tspec, 0)) + cwarn("utimensat: %s", name); /* * Changing the ownership probably won't succeed, unless we're root diff --git a/usr.bin/gzip/gzip.c b/usr.bin/gzip/gzip.c index 9f92b6a..f197f18 100644 --- a/usr.bin/gzip/gzip.c +++ b/usr.bin/gzip/gzip.c @@ -1070,7 +1070,7 @@ out2: static void copymodes(int fd, const struct stat *sbp, const char *file) { - struct timeval times[2]; + struct timespec times[2]; struct stat sb; /* @@ -1098,10 +1098,10 @@ copymodes(int fd, const struct stat *sbp, const char *file) if (fchmod(fd, sb.st_mode) < 0) maybe_warn("couldn't fchmod: %s", file); - TIMESPEC_TO_TIMEVAL(×[0], &sb.st_atim); - TIMESPEC_TO_TIMEVAL(×[1], &sb.st_mtim); - if (futimes(fd, times) < 0) - maybe_warn("couldn't utimes: %s", file); + times[0] = sb.st_atim; + times[1] = sb.st_mtim; + if (futimens(fd, times) < 0) + maybe_warn("couldn't futimens: %s", file); /* only try flags if they exist already */ if (sb.st_flags != 0 && fchflags(fd, sb.st_flags) < 0) |