diff options
author | Junio C Hamano <junkio@cox.net> | 2007-02-17 07:43:48 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2007-02-17 07:56:06 +0100 |
commit | 185c975faaa790a98a4e00f124461473283500d6 (patch) | |
tree | 093c04e201a8bbddfbe2e22b734a458a9505a0ec /cache.h | |
parent | git-blame: prevent argument parsing segfault (diff) | |
download | git-185c975faaa790a98a4e00f124461473283500d6.tar.xz git-185c975faaa790a98a4e00f124461473283500d6.zip |
Do not take mode bits from index after type change.
When we do not trust executable bit from lstat(2), we copied
existing ce_mode bits without checking if the filesystem object
is a regular file (which is the only thing we apply the "trust
executable bit" business) nor if the blob in the index is a
regular file (otherwise, we should do the same as registering a
new regular file, which is to default non-executable).
Noticed by Johannes Sixt.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'cache.h')
-rw-r--r-- | cache.h | 10 |
1 files changed, 10 insertions, 0 deletions
@@ -106,6 +106,16 @@ static inline unsigned int create_ce_mode(unsigned int mode) return htonl(S_IFLNK); return htonl(S_IFREG | ce_permissions(mode)); } +static inline unsigned int ce_mode_from_stat(struct cache_entry *ce, unsigned int mode) +{ + extern int trust_executable_bit; + if (!trust_executable_bit && S_ISREG(mode)) { + if (ce && S_ISREG(ntohl(ce->ce_mode))) + return ce->ce_mode; + return create_ce_mode(0666); + } + return create_ce_mode(mode); +} #define canon_mode(mode) \ (S_ISREG(mode) ? (S_IFREG | ce_permissions(mode)) : \ S_ISLNK(mode) ? S_IFLNK : S_IFDIR) |