summaryrefslogtreecommitdiffstats
path: root/contrib/libarchive
diff options
context:
space:
mode:
authordim <dim@FreeBSD.org>2014-11-22 12:10:09 +0000
committerdim <dim@FreeBSD.org>2014-11-22 12:10:09 +0000
commitf3c5cded787fe5809335d5009e4e2012d3e3829b (patch)
tree821a1126fabc8451bbe711320e797fba7f1959f5 /contrib/libarchive
parent31183242f066ae36f29f018862c7c8c2d3b90c1d (diff)
downloadFreeBSD-src-f3c5cded787fe5809335d5009e4e2012d3e3829b.zip
FreeBSD-src-f3c5cded787fe5809335d5009e4e2012d3e3829b.tar.gz
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
Diffstat (limited to 'contrib/libarchive')
-rw-r--r--contrib/libarchive/cpio/cpio.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/contrib/libarchive/cpio/cpio.c b/contrib/libarchive/cpio/cpio.c
index 4918138..7a34b80 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";
OpenPOWER on IntegriCloud