summaryrefslogtreecommitdiff
path: root/diff-tree-helper.c
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-04-28 10:13:01 -0700
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-04-28 10:13:01 -0700
commit91a6eaa05da5627b1238b7168be1d8ae69516383 (patch)
tree14cf4ef6479de36ee48cc38964f7e59c5f26e693 /diff-tree-helper.c
parent2f97813870c73a89b673ea7882f2a078d25c2dcd (diff)
downloadgit-91a6eaa05da5627b1238b7168be1d8ae69516383.tar.gz
[PATCH] diff-tree-helper: do not report unmerged path outside specification.
My bad. diff-tree-helper reports all unmerged paths even when the command line specifies to filter the paths. This patch fixes it. Also reverse-diff option was left out during the last round, which this patch restores as well. Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'diff-tree-helper.c')
-rw-r--r--diff-tree-helper.c110
1 files changed, 50 insertions, 60 deletions
diff --git a/diff-tree-helper.c b/diff-tree-helper.c
index f3efc8a6f2..282b649f31 100644
--- a/diff-tree-helper.c
+++ b/diff-tree-helper.c
@@ -5,7 +5,7 @@
#include "strbuf.h"
#include "diff.h"
-static int matches_pathspec(const char *name, char **spec, int cnt)
+static int matches_pathspec(const char *name, const char **spec, int cnt)
{
int i;
int namelen = strlen(name);
@@ -44,70 +44,69 @@ static int parse_oneside_change(const char *cp, struct diff_spec *one,
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,
- char *path) {
+static int parse_diff_tree_output(const char *buf, const char **spec, int cnt)
+{
+ struct diff_spec old, new;
+ char path[PATH_MAX];
const char *cp = buf;
int ch;
switch (*cp++) {
case 'U':
- diff_unmerge(cp + 1);
- return WARNED_OURSELVES;
+ if (!cnt || matches_pathspec(cp + 1, spec, cnt))
+ diff_unmerge(cp + 1);
+ return 0;
case '+':
- old->file_valid = 0;
- return parse_oneside_change(cp, new, path);
+ old.file_valid = 0;
+ parse_oneside_change(cp, &new, path);
+ break;
case '-':
- new->file_valid = 0;
- return parse_oneside_change(cp, old, path);
+ new.file_valid = 0;
+ parse_oneside_change(cp, &old, path);
+ break;
case '*':
+ old.file_valid = old.sha1_valid =
+ new.file_valid = new.sha1_valid = 1;
+ old.mode = new.mode = 0;
+ while ((ch = *cp) && ('0' <= ch && ch <= '7')) {
+ old.mode = (old.mode << 3) | (ch - '0');
+ cp++;
+ }
+ if (strncmp(cp, "->", 2))
+ return -1;
+ 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;
+ cp += 6;
+ if (get_sha1_hex(cp, old.u.sha1))
+ return -1;
+ cp += 40;
+ if (strncmp(cp, "->", 2))
+ return -1;
+ cp += 2;
+ if (get_sha1_hex(cp, new.u.sha1))
+ return -1;
+ cp += 40;
+ if (*cp++ != '\t')
+ return -1;
+ strcpy(path, cp);
break;
default:
- return PLEASE_WARN;
- }
-
- /* This is for '*' entries */
- old->file_valid = old->sha1_valid = 1;
- new->file_valid = new->sha1_valid = 1;
-
- old->mode = new->mode = 0;
- while ((ch = *cp) && ('0' <= ch && ch <= '7')) {
- old->mode = (old->mode << 3) | (ch - '0');
- cp++;
- }
- if (strncmp(cp, "->", 2))
- return PLEASE_WARN;
- cp += 2;
- while ((ch = *cp) && ('0' <= ch && ch <= '7')) {
- new->mode = (new->mode << 3) | (ch - '0');
- cp++;
+ return -1;
}
- if (strncmp(cp, "\tblob\t", 6))
- return PLEASE_WARN;
- cp += 6;
- if (get_sha1_hex(cp, old->u.sha1))
- return PLEASE_WARN;
- cp += 40;
- if (strncmp(cp, "->", 2))
- return PLEASE_WARN;
- cp += 2;
- if (get_sha1_hex(cp, new->u.sha1))
- return PLEASE_WARN;
- cp += 40;
- if (*cp++ != '\t')
- return PLEASE_WARN;
- strcpy(path, cp);
+ if (!cnt || matches_pathspec(path, spec, cnt))
+ run_external_diff(path, &old, &new);
return 0;
}
static const char *diff_tree_helper_usage =
"diff-tree-helper [-R] [-z] paths...";
-int main(int ac, char **av) {
+int main(int ac, const char **av) {
struct strbuf sb;
int reverse_diff = 0;
int line_termination = '\n';
@@ -127,21 +126,12 @@ int main(int ac, char **av) {
while (1) {
int status;
- struct diff_spec old, new;
- char path[PATH_MAX];
read_line(&sb, stdin, line_termination);
if (sb.eof)
break;
- 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;
-
- run_external_diff(path, &old, &new);
+ status = parse_diff_tree_output(sb.buf, av+1, ac-1);
+ if (status)
+ fprintf(stderr, "cannot parse %s\n", sb.buf);
}
return 0;
}