Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
[PATCH] diff-cache/tree compatible output for show-diff (take 2).
author
Junio C Hamano
<junkio@cox.net>
Wed, 27 Apr 2005 00:39:01 +0000
(17:39 -0700)
committer
Linus Torvalds
<torvalds@ppc970.osdl.org>
Wed, 27 Apr 2005 00:39:01 +0000
(17:39 -0700)
This makes diff-tree-helper handle ("warn about") unmerged path entries
U <path> <record-terminator>
This is emitted once per unmerged path, no matter how many unmerged
stages there are.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
diff-tree-helper.c
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
b8a55ce
)
diff --git
a/diff-tree-helper.c
b/diff-tree-helper.c
index bcf89a57892ac3601ac268b08c7f28d443c75108..4167d11e0081f59d6839811e99c01fe76cc9137c 100644
(file)
--- a/
diff-tree-helper.c
+++ b/
diff-tree-helper.c
@@
-44,6
+44,9
@@
static int parse_oneside_change(const char *cp, struct diff_spec *one,
return 0;
}
return 0;
}
+#define PLEASE_WARN -1
+#define WARNED_OURSELVES -2
+
static int parse_diff_tree_output(const char *buf,
struct diff_spec *old,
struct diff_spec *new,
static int parse_diff_tree_output(const char *buf,
struct diff_spec *old,
struct diff_spec *new,
@@
-52,6
+55,9
@@
static int parse_diff_tree_output(const char *buf,
int ch;
switch (*cp++) {
int ch;
switch (*cp++) {
+ case 'U':
+ fprintf(stderr, "warning: unmerged path %s\n", cp+1);
+ return WARNED_OURSELVES;
case '+':
old->file_valid = 0;
return parse_oneside_change(cp, new, path);
case '+':
old->file_valid = 0;
return parse_oneside_change(cp, new, path);
@@
-61,7
+67,7
@@
static int parse_diff_tree_output(const char *buf,
case '*':
break;
default:
case '*':
break;
default:
- return
-1
;
+ return
PLEASE_WARN
;
}
/* This is for '*' entries */
}
/* This is for '*' entries */
@@
-74,26
+80,26
@@
static int parse_diff_tree_output(const char *buf,
cp++;
}
if (strncmp(cp, "->", 2))
cp++;
}
if (strncmp(cp, "->", 2))
- return
-1
;
+ return
PLEASE_WARN
;
cp += 2;
while ((ch = *cp) && ('0' <= ch && ch <= '7')) {
new->mode = (new->mode << 3) | (ch - '0');
cp++;
}
if (strncmp(cp, "\tblob\t", 6))
cp += 2;
while ((ch = *cp) && ('0' <= ch && ch <= '7')) {
new->mode = (new->mode << 3) | (ch - '0');
cp++;
}
if (strncmp(cp, "\tblob\t", 6))
- return
-1
;
+ return
PLEASE_WARN
;
cp += 6;
if (get_sha1_hex(cp, old->u.sha1))
cp += 6;
if (get_sha1_hex(cp, old->u.sha1))
- return
-1
;
+ return
PLEASE_WARN
;
cp += 40;
if (strncmp(cp, "->", 2))
cp += 40;
if (strncmp(cp, "->", 2))
- return
-1
;
+ return
PLEASE_WARN
;
cp += 2;
if (get_sha1_hex(cp, new->u.sha1))
cp += 2;
if (get_sha1_hex(cp, new->u.sha1))
- return
-1
;
+ return
PLEASE_WARN
;
cp += 40;
if (*cp++ != '\t')
cp += 40;
if (*cp++ != '\t')
- return
-1
;
+ return
PLEASE_WARN
;
strcpy(path, cp);
return 0;
}
strcpy(path, cp);
return 0;
}
@@
-120,13
+126,16
@@
int main(int ac, char **av) {
/* the remaining parameters are paths patterns */
while (1) {
/* the remaining parameters are paths patterns */
while (1) {
+ int status;
struct diff_spec old, new;
char path[PATH_MAX];
read_line(&sb, stdin, line_termination);
if (sb.eof)
break;
struct diff_spec old, new;
char path[PATH_MAX];
read_line(&sb, stdin, line_termination);
if (sb.eof)
break;
- if (parse_diff_tree_output(sb.buf, &old, &new, path)) {
- fprintf(stderr, "cannot parse %s\n", sb.buf);
+ status = parse_diff_tree_output(sb.buf, &old, &new, path);
+ if (status) {
+ if (status == PLEASE_WARN)
+ fprintf(stderr, "cannot parse %s\n", sb.buf);
continue;
}
if (1 < ac && !matches_pathspec(path, av+1, ac-1))
continue;
}
if (1 < ac && !matches_pathspec(path, av+1, ac-1))