[prev in list] [next in list] [prev in thread] [next in thread]
List: git
Subject: Re: bug: git-diff silently fails when run outside of a repository
From: Johannes Schindelin <Johannes.Schindelin () gmx ! de>
Date: 2008-04-30 8:34:51
Message-ID: alpine.DEB.1.00.0804300933570.17469 () eeepc-johanness
[Download RAW message or body]
Hi,
On Tue, 29 Apr 2008, Junio C Hamano wrote:
> Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
>
> >> > Even so, this seems like a bug. If I do this:
> >> >
> >> > $ cd /
> >> > $ git-diff
> >> >
> >> > there is no error message and no error status. A diagnostic would be
> >> > very helpful.
> >>
> >> Ah, that indeed is not very helpful.
> >>
> >> Unfortunately, every time I look at this hack, I seem to find an unrelated
> >> bug in it. Here is today's.
> >>
> >> $ for i in 1 2 3; do >/var/tmp/$i; done
> >> $ cd /
> >> $ git diff /var/tmp/1
> >> Segmentation Fault
> >>
> >> When nongit is true, we know the user has to be asking --no-index diff, so
> >> perhaps we can fix it by doing something like this?
> >>
> >> diff --git a/diff-lib.c b/diff-lib.c
> >> index 069e450..cfd629d 100644
> >> --- a/diff-lib.c
> >> +++ b/diff-lib.c
> >> @@ -264,6 +264,9 @@ int setup_diff_no_index(struct rev_info *revs,
> >> DIFF_OPT_SET(&revs->diffopt, EXIT_WITH_STATUS);
> >> break;
> >> }
> >> + if (nongit && argc != i + 2)
> >> + die("git diff [--no-index] takes two paths");
> >> +
> >> if (argc != i + 2 || (!is_outside_repo(argv[i + 1], nongit, prefix) &&
> >> !is_outside_repo(argv[i], nongit, prefix)))
> >> return -1;
> >
> > That looks to me as if the second if() should have triggered, and the
> > caller of setup_diff_no_index() should have errored out.
>
> I think the above three-liner fix is something we should have done when we
> added --no-index codepath. Before the --no-index hack was introduced, we
> did not even got this far to the place the caller of this function is, if
> we are outside a repository. By returning -1 from here instead of dying,
> this code is driving the codepath that has always expected to already be
> in a repository into a nonrepository, causing them to segfault because
> there is no git-dir or work-tree set up done yet as they expect.
Fair enough.
Ciao,
Dscho
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic