* 'git checkout -p' is a bit confusing...
@ 2011-05-09 10:05 John Szakmeister
2011-05-09 10:57 ` Jeff King
0 siblings, 1 reply; 2+ messages in thread
From: John Szakmeister @ 2011-05-09 10:05 UTC (permalink / raw)
To: Git mailing list
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. :-)
Thank you!
-John
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: 'git checkout -p' is a bit confusing...
2011-05-09 10:05 'git checkout -p' is a bit confusing John Szakmeister
@ 2011-05-09 10:57 ` Jeff King
0 siblings, 0 replies; 2+ messages in thread
From: Jeff King @ 2011-05-09 10:57 UTC (permalink / raw)
To: John Szakmeister; +Cc: Thomas Rast, Git mailing list
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
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-05-09 10:57 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-05-09 10:05 'git checkout -p' is a bit confusing John Szakmeister
2011-05-09 10:57 ` Jeff King
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).