From: Junio C Hamano <junkio@cox.net>
To: Linus Torvalds <torvalds@osdl.org>
Cc: git@vger.kernel.org
Subject: [PATCH] diff-tree-helper: do not report unmerged path outside specification.
Date: Wed, 27 Apr 2005 19:22:39 -0700 [thread overview]
Message-ID: <7vwtqnbpxs.fsf@assigned-by-dhcp.cox.net> (raw)
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>
---
diff-tree-helper.c | 110 ++++++++++++++++++++++++-----------------------------
1 files changed, 50 insertions(+), 60 deletions(-)
# - [PATCH] diff-tree -p implies diff-tree -p -r
# + 04/27 19:18 Fix diff-tree-helper for unmerged path with path specification
--- k/diff-tree-helper.c
+++ l/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 ch
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;
}
reply other threads:[~2005-04-28 2:17 UTC|newest]
Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7vwtqnbpxs.fsf@assigned-by-dhcp.cox.net \
--to=junkio@cox.net \
--cc=git@vger.kernel.org \
--cc=torvalds@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox