work around buggy S_ISxxx(m) implementations
commitb90d9b889588ca1cfd5667d1fa703d976edd71ee
authorRené Scharfe <rene.scharfe@lsrfire.ath.cx>
Mon, 4 Oct 2010 10:53:11 +0000 (4 12:53 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 6 Oct 2010 17:51:14 +0000 (6 10:51 -0700)
treee41d27db561471ca6f95d3630b5c6a23fe4c373a
parent349362cc207c96bbf31f503db989f0289c13c05d
work around buggy S_ISxxx(m) implementations

There are buggy implementations of S_ISxxx(m) macros on some platforms
(e.g. NetBSD).  The issue is that NetBSD doesn't take care to wrap its
macro arguments in parentheses, so on Linux and sane systems we have
S_ISREG(m) defined as something like:

    (((m) & S_IFMT) == S_IFREG)

But on NetBSD:

    ((m & _S_IFMT) == _S_IFREG)

Since a caller in builtin/diff.c called our macro as `S_IFREG | 0644'
this bug introduced a logic error on NetBSD, since the precedence of
bit-wise & is higher than | in C.

[jc: took change description from Ævar Arnfjörð Bjarmason's patch]

Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
cache.h