diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2014-11-22 12:10:09 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2014-11-22 12:10:09 +0000 |
commit | fdaadf20c42b27bb07dae3a6fae4cf56742c8727 (patch) | |
tree | 821a1126fabc8451bbe711320e797fba7f1959f5 /contrib | |
parent | 73e2e95d943707312f9ad20c1d95bc323943b6b2 (diff) | |
download | src-fdaadf20c42b27bb07dae3a6fae4cf56742c8727.tar.gz src-fdaadf20c42b27bb07dae3a6fae4cf56742c8727.zip |
Fix the following -Werror warning from clang 3.5.0, while building
usr.bin/cpio on amd64 (or any arch with 64-bit time_t):
contrib/libarchive/cpio/cpio.c:1143:6: error: absolute value function 'abs' given an argument of type 'long' but has parameter of type 'int' which may cause truncation of value [-Werror,-Wabsolute-value]
if (abs(mtime - now) > (365/2)*86400)
^
contrib/libarchive/cpio/cpio.c:1143:6: note: use function 'labs' instead
if (abs(mtime - now) > (365/2)*86400)
^~~
labs
1 error generated.
This is because time_t is a long on amd64. To avoid the warning, just
copy the equivalent test from a few lines before, which is used in the
Windows case, and which is type safe.
Reviewed by: emaste
MFC after: 3 days
Differential Revision: https://reviews.freebsd.org/D1198
Notes
Notes:
svn path=/head/; revision=274846
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/libarchive/cpio/cpio.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/contrib/libarchive/cpio/cpio.c b/contrib/libarchive/cpio/cpio.c index 4918138042fd..7a34b8084809 100644 --- a/contrib/libarchive/cpio/cpio.c +++ b/contrib/libarchive/cpio/cpio.c @@ -1140,7 +1140,8 @@ list_item_verbose(struct cpio *cpio, struct archive_entry *entry) else fmt = cpio->day_first ? "%d %b %H:%M" : "%b %d %H:%M"; #else - if (abs(mtime - now) > (365/2)*86400) + if (mtime - now > 365*86400/2 + || mtime - now < -365*86400/2) fmt = cpio->day_first ? "%e %b %Y" : "%b %e %Y"; else fmt = cpio->day_first ? "%e %b %H:%M" : "%b %e %H:%M"; |