Skip to content

Commit

Permalink
diff-index.c: unify handling of command line paths
Browse files Browse the repository at this point in the history
Regardless of where in the directory hierarchy you are, "-" on the
command line means the standard input.  The old code knew too much
about how the low level machinery uses paths to read from the
working tree and did not bother to have the same check for "-" when
the command is run from the top-level.

Unify the codepaths for subdirectory case and toplevel case into one
and make it clearer.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Junio C Hamano committed Jun 28, 2012
1 parent c20f592 commit 3b069b1
Showing 1 changed file with 11 additions and 16 deletions.
27 changes: 11 additions & 16 deletions diff-no-index.c
Original file line number Diff line number Diff line change
Expand Up @@ -170,7 +170,7 @@ void diff_no_index(struct rev_info *revs,
int argc, const char **argv,
int nongit, const char *prefix)
{
int i;
int i, prefixlen;
int no_index = 0;
unsigned options = 0;
const char *paths[2];
Expand Down Expand Up @@ -230,23 +230,18 @@ void diff_no_index(struct rev_info *revs,
if (!DIFF_OPT_TST(&revs->diffopt, EXIT_WITH_STATUS))
setup_pager();

if (prefix) {
int len = strlen(prefix);

for (i = 0; i < 2; i++) {
const char *p = argv[argc - 2 + i];
prefixlen = prefix ? strlen(prefix) : 0;
for (i = 0; i < 2; i++) {
const char *p = argv[argc - 2 + i];
if (!strcmp(p, "-"))
/*
* stdin should be spelled as '-'; if you have
* path that is '-', spell it as ./-.
* stdin should be spelled as "-"; if you have
* path that is "-", spell it as "./-".
*/
p = (strcmp(p, "-")
? xstrdup(prefix_filename(prefix, len, p))
: p);
paths[i] = p;
}
} else {
for (i = 0; i < 2; i++)
paths[i] = argv[argc - 2 + i];
p = p;
else if (prefixlen)
p = xstrdup(prefix_filename(prefix, prefixlen, p));
paths[i] = p;
}
revs->diffopt.skip_stat_unmatch = 1;
if (!revs->diffopt.output_format)
Expand Down

0 comments on commit 3b069b1

Please sign in to comment.