From: Peter Baumann <waste.manager@gmx.de>
To: Junio C Hamano <junkio@cox.net>
Cc: git@vger.kernel.org
Subject: Re: [RFC/PATCH] Fix git-diff --cached to not error out if HEAD points to a nonexistant branch
Date: Sat, 24 Feb 2007 23:16:22 +0100 [thread overview]
Message-ID: <20070224221622.GA3897@xp.machine.xx> (raw)
In-Reply-To: <7vvehrw9mz.fsf@assigned-by-dhcp.cox.net>
On Sat, Feb 24, 2007 at 01:03:48PM -0800, Junio C Hamano wrote:
> Peter Baumann <waste.manager@gmx.de> writes:
>
> > The documentation mentions "git-diff --cached" to see what is staged for
> > the next commit. But this failes if you haven't done any commits yet.
> > So lets fix it.
> > ...
> > ... I am
> > not sure if this is the right fix and/or if git-diff-index
> > should also be fixed. I decided against it and let the core
> > cmd git-diff-index stay as it is now.
>
> I think you decision here is a correct one. The plumbing level
> command git-diff-index should error out if you do not give a
> tree to compare against.
>
> My preference for 'git-diff --cached' issue is to fix the
> explanation. Clearly document that --cached is to review the
> difference between any commit (we could even be more precise to
> say any tree, but I think we should say commit here, as the
> description is at the end-user level) and what is staged for the
> commit that will be created with your next 'git-commit'. For
> convenience it defaults to 'HEAD', the latest commit on your
> current branch, because that is what people would do most often.
>
I tend to agree, but I'd like to also have somethin in the spirit of
"log.showroot = true" which handles the diff of the first commit like
diffing against an empty tree. Why should diff --cached differ from
this? At least it is easier to explain, just mention that diff --cached
shows everything which would become the next commit.
> Until you have a commit at HEAD, there really is nothing to diff
> against. I think "foo is a new entry, no comparison available."
> is one of the very few things that CVS got right.
>
Hm. But a diff against nothing should show you what you have added :-)
> The bug in the current code is that we do not check if that HEAD
> is sensible when we add it as the default commit to compare
> with. The error message coming out of the low-level diff-index
> code might be sensible if that 'HEAD' were what the user
> actually gave us, but clearly not the right error message in
> this case.
>
Here I agree with you. But I guess you know what I would prefere.
-Peter
> ---
>
> builtin-diff.c | 2 ++
> 1 files changed, 2 insertions(+), 0 deletions(-)
>
> diff --git a/builtin-diff.c b/builtin-diff.c
> index c387ebb..67f4932 100644
> --- a/builtin-diff.c
> +++ b/builtin-diff.c
> @@ -261,6 +261,8 @@ int cmd_diff(int argc, const char **argv, const char *prefix)
> break;
> else if (!strcmp(arg, "--cached")) {
> add_head(&rev);
> + if (!rev.pending.nr)
> + die("No HEAD commit to compare with (yet)");
> break;
> }
> }
>
next prev parent reply other threads:[~2007-02-24 22:13 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-02-24 17:20 [RFC/PATCH] Fix git-diff --cached to not error out if HEAD points to a nonexistant branch Peter Baumann
2007-02-24 21:03 ` Junio C Hamano
2007-02-24 22:16 ` Peter Baumann [this message]
2007-02-25 8:22 ` Junio C Hamano
2007-02-25 9:13 ` Peter Baumann
2007-02-25 9:45 ` Junio C Hamano
2007-02-25 10:24 ` Peter Baumann
2007-02-25 10:28 ` Peter Baumann
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=20070224221622.GA3897@xp.machine.xx \
--to=waste.manager@gmx.de \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
/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;
as well as URLs for NNTP newsgroup(s).