diff options
author | Junio C Hamano <junkio@cox.net> | 2005-06-01 11:38:07 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-01 13:24:03 -0700 |
commit | 67574c403f1e27660bbd0348b81b31adc9889b20 (patch) | |
tree | 5511c5cab33437edbee94e6fbe5a62d3d5827ae5 /diff-tree.c | |
parent | 81bb573ed882523e345f0923b88db2aac8f4b93c (diff) | |
download | git-67574c403f1e27660bbd0348b81b31adc9889b20.tar.gz git-67574c403f1e27660bbd0348b81b31adc9889b20.tar.xz |
[PATCH] diff: mode bits fixes
The core GIT repository has trees that record regular file mode
in 0664 instead of normalized 0644 pattern. Comparing such a
tree with another tree that records the same file in 0644
pattern without content changes with git-diff-tree causes it to
feed otherwise unmodified pairs to the diff_change() routine,
which triggers a sanity check routine and barfs. This patch
fixes the problem, along with the fix to another caller that
uses unnormalized mode bits to call diff_change() routine in a
similar way.
Without this patch, you will see "fatal error" from diff-tree
when you run git-deltafy-script on the core GIT repository
itself.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'diff-tree.c')
-rw-r--r-- | diff-tree.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/diff-tree.c b/diff-tree.c index db37aa714..a6d358fb3 100644 --- a/diff-tree.c +++ b/diff-tree.c @@ -44,10 +44,12 @@ static const unsigned char *extract(void *tree, unsigned long size, const char * int len = strlen(tree)+1; const unsigned char *sha1 = tree + len; const char *path = strchr(tree, ' '); + unsigned int mode; - if (!path || size < len + 20 || sscanf(tree, "%o", modep) != 1) + if (!path || size < len + 20 || sscanf(tree, "%o", &mode) != 1) die("corrupt tree file"); *pathp = path+1; + *modep = DIFF_FILE_CANON_MODE(mode); return sha1; } |