]> git.ipfire.org Git - thirdparty/libarchive.git/commitdiff
Fix the following -Werror warning from clang 3.5.0, while building cpio.c on amd64... 94/head
authorDimitry Andric <dimitry@andric.com>
Sat, 22 Nov 2014 12:01:08 +0000 (13:01 +0100)
committerDimitry Andric <dimitry@andric.com>
Sat, 22 Nov 2014 12:01:08 +0000 (13:01 +0100)
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)
            ^
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.

Obtained from: https://reviews.freebsd.org/D1198

cpio/cpio.c

index c2f6f20decaa0f6e518bcb2c8e42fa1206f0b46e..0acde11975bd2f8a81c8748b53d63ccb60b36500 100644 (file)
@@ -1162,7 +1162,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";