diff options
author | Junio C Hamano <junkio@cox.net> | 2005-05-12 16:51:08 -0700 |
---|---|---|
committer | Petr Baudis <xpasky@machine.sinus.cz> | 2005-05-14 00:27:49 +0200 |
commit | 95649d6cf9ec68f05d1dc57ec1b989b8d263a7ae (patch) | |
tree | 71452301db9f0e49c458332bdeb72bbc6d2639ea /diff-files.c | |
parent | f77b100ada80e9d149bf763ae64d563352ebb577 (diff) | |
download | git-95649d6cf9ec68f05d1dc57ec1b989b8d263a7ae.tar.gz |
[PATCH] Fix git-diff-files for symlinks.
Again I am not sure why this was missed during the last round,
but git-diff-files mishandles symlinks on the filesystem. This
patch fixes it.
Signed-off-by: Junio C Hamano <junkio@cox.net>
And I'm not sure why did I miss this patch before. Sorry.
Signed-off-by: Petr Baudis <pasky@ucw.cz>
Diffstat (limited to 'diff-files.c')
-rw-r--r-- | diff-files.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/diff-files.c b/diff-files.c index c51edc3315..28f1b13b38 100644 --- a/diff-files.c +++ b/diff-files.c @@ -126,7 +126,8 @@ int main(int argc, char **argv) continue; oldmode = ntohl(ce->ce_mode); - mode = S_IFREG | ce_permissions(st.st_mode); + mode = (S_ISLNK(st.st_mode) ? S_IFLNK : + S_IFREG | ce_permissions(st.st_mode)); show_modified(oldmode, mode, ce->sha1, null_sha1, ce->name); |