Re: [PATCH] Teach 'git apply' to look at $GIT_DIR/config

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Johannes Schindelin <Johannes.Schindelin@xxxxxx> writes:

> On Sat, 17 Feb 2007, Junio C Hamano wrote:
> ...
>> But I think Jeff is right.  It would make sense to let apply
>> and perhaps 'diff', if we can somehow merge 'diff2' into it,
>> still read from $HOME/.gitconfig if available.
>
> Yes, especially if you are soo used to colours as I grew to be used to 
> them. This was literally one of the reasons I wrote diff2 in the first 
> place. Another was --color-words.

True.  Paches welcome ;-).

> BTW any good ideas how to make diff fall back to diff2, so that no similar 
> case falls back to diff-index?
>
> I am really wondering if you can have a syntax which Does The Right Thing 
> at all times. Maybe we can teach diff that exactly two arguments, which 
> both exist in the filesystem, and at least one of them is not tracked, 
> then please use diff2? I wonder how often you do something like
>
> 	git diff object.c object-refs.c
>
> and how confusing it would be that it could mean two things, diff2 _and_ 
> diff-index?

I _think_ the case I would want to use diff2 are:

 (1) I am totally outside a git repository.

or

 (2) I am inside a git repository but I want to compare two
     specific managed files, say GIT-VERSION-GEN and
     git-gui/GIT-VERSION-GEN.

Now, (1) can be had by moving the RUN_SETUP bit out of entry for
"diff" in git.c, and do it only when we know we are in a repo
(maybe using "setup gently").  If we are outside of a
repository, any of the existing diff-* brothers do not make much
sense --- we can always do diff2.

For (2), I _think_ it may be useful sometimes but not very
often, so how about a specific option that you require upfront?

	git diff --fs --color-words GIT-VERSION-GEN git-gui/GIT-VERSION-GEN

I can do almost that with

	git diff --color-words :GIT-VERSION-GEN :git-gui/GIT-VERSION-GEN

but, it compares indexed ones, not from the working tree, so it
is not exactly the same.  However, the difference may not make
practical difference in this particular example, though.  When I
want to know the differences between two tracked files, it is
usually becausel I want to see if there are similarities to be
consolidated, and I would do that before starting to alter
working tree files.

Also, strictly speaking, there is third one:

 (3) I am inside a git repository but I want to compare files
     that do not have anything to do with the project I am
     currently working on:

	git diff --fs /etc/skel/profile $HOME/.profile

while I do not think this usage makes any sense, an explicit
flag upfront saves you from wondering what the user meant.

-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]