Re: [PATCH] Teach git-stash to "apply --index"

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

 



Hi,

On Mon, 2 Jul 2007, Junio C Hamano wrote:

> Johannes Schindelin <Johannes.Schindelin@xxxxxx> writes:
> 
> > 	I am not quite sure if this should not be the default, with
> > 	--skip-index to turn it off if the trivial index merge fails,
> > 	and the user might be interested only in the working directory
> > 	changes anyway.
> >
> > 	Comments?
> 
> There is a bit of impedance mismatch between a rename-aware
> three-way merge (aka merge-recursive) used to update the working
> tree and a patch that updates the index.  The "rename-aware"
> thing can be fixed by doing the diff with -M, though.

Ah yes, I did not think about renames. But like you said, adding -M to the 
diff should help that.

> It might be easier to explain (1) not have --index option, but attempt 
> to do this always, and (2) even if the index cannot be updated, keep 
> going, without worrying about losing the difference between I and W, 
> probably with a message to the end user.

Okay, in this case I propose to make this the default, with an option 
"--skip-index" to only try re-apply the changes to the working directory.

> Suppose you are the user who gets "perhaps you would want to run without 
> --index?" hint.  What can you do?  Run without --index, or forget about 
> unstashing.  But the latter does not sound like an option.  So it feels 
> to me that --index is an unnecessary option.

It is very much like the choice you have with "git checkout" vs "git 
checkout -f". Either you change your index accordingly, or you say "I 
don't care about the index. What changes I had there, I will reconstruct 
myself."

> The potential confusion problem I mentioned in two of my earlier 
> messages due to the program doing one thing sometimes and another thing 
> some other times still applies, though.

Yes, that's why I would suggest not going ahead when the index could not 
be easily merged. Rather give the user enough information to decide.

Of course, this means that in complicated cases, the user mustn't run and 
hide when she hears "index!", but I guess that complicated cases always 
need you to know your tools better than easy problems.

Ciao,
Dscho

-
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]

  Powered by Linux