Re: 'git checkout -p' is a bit confusing...

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

 



On Mon, May 09, 2011 at 06:05:49AM -0400, John Szakmeister wrote:

> I noticed this a little while back, but thought it may have been my
> own misunderstanding.  I wanted to selectively revert part of a file,
> so I used 'git checkout -p filename'.  Then I needed to edit the hunk,
> and got something like this:
> 
>     # Manual hunk edit mode -- see bottom for a quick guide
>     @@ -236,6 +236,12 @@ int run_add_interactive(const char *revision,
> const char *patch_mode,
>             }
>             args[ac] = NULL;
> 
>     +        for (i=0; i < ac; i++)
>     +          {
>     +            fprintf(stderr, "%s ", args[i]);
>     +          }
>     +        fprintf(stderr, "\n");
>     +
>     # ---
>     # To remove '+' lines, make them ' ' lines (context).
>     # To remove '-' lines, delete them.
>     # Lines starting with # will be removed.
>     #
>     # If the patch applies cleanly, the edited hunk will immediately be
>     # marked for discarding. If it does not apply cleanly, you will be given
>     # an opportunity to edit again. If all lines of the hunk are removed,
>     # then the edit is aborted and the hunk is left unchanged.
> 
> Since the diff was showing me the forward direction (from the base to
> modified working tree), I expected that when I left the +'s in there,
> that it was going to leave my hunk.  Unfortunately, it discarded my
> hunk.  I can see the text at the bottom, and now it makes sense, but I
> wonder if there's a way to make it so that you can edit the patch to
> look the way you want, and keep those bits (in much the same way as
> 'git add -p' works)?
> 
> I hope that makes sense. :-)

Your mail does make sense. There are basically two ways of looking at a
diff like this:

  1. Is it a patch you want to apply to the working tree, and you want
     to select the parts you like?

or

  2. Is it a change that is in the working tree versus the index, and
     you want to discard or keep the change?

The interactive patch viewer is capable of doing both directions. In
fact, if you do:

  git checkout -p

then it will show you the diff from the index to the working tree and
say "did you want to discard this hunk?" It does a similar thing for
"git checkout -p HEAD". But if you do:

  git checkout -p some-other-commit

then it will say "did you want to apply this hunk?".

Which seems somewhat inconsistent, but mostly does what people mean. But
as you noticed, when you stop saying "take this hunk" versus "discard
this hunk" and move into "edit this hunk", the "discard" direction seems
more counter-intuitive.

In theory I guess we could flip between the two directions, which is,
after all, more or less what "apply -R" does. So we could be in
"discard" mode, but when somebody wants to "e"dit the patch, it would
always be in "take the parts you _like_" mode. I have a nagging feeling
that there may be some corner case that doesn't reverse properly, but I
haven't thought too long about it.

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