From: Junio C Hamano <gitster@pobox.com>
To: Phil Hord <phil.hord@gmail.com>
Cc: git@vger.kernel.org, Denton Liu <liu.denton@gmail.com>,
Phillip Wood <phillip.wood123@gmail.com>
Subject: Re: [PATCH/RFC 0/2] rebase: add switches to control todo-list setup
Date: Mon, 22 Apr 2019 10:13:13 +0900 [thread overview]
Message-ID: <xmqqk1fm9712.fsf@gitster-ct.c.googlers.com> (raw)
In-Reply-To: <20190422000712.13584-1-phil.hord@gmail.com> (Phil Hord's message of "Sun, 21 Apr 2019 17:07:10 -0700")
Phil Hord <phil.hord@gmail.com> writes:
> Currently it supports these switches:
>
> usage: git rebase [-i] [options] [--exec <cmd>] ...
> :
> --break <revision> stop before the mentioned ref
> --drop <revision> drop the mentioned ref from the todo list
> --edit <revision> edit the mentioned ref instead of picking it
> --reword <revision> reword the mentioned ref instead of picking it
>
> I have plans to add these, but I don't like how their "onto" will be
> controlled. More thinking is needed here.
>
> --fixup <revision> fixup the mentioned ref instead of picking it
> --squash <revision> squash the mentioned ref instead of picking it
> --pick <revision> pick the mentioned ref onto the start of the list
Yeah, I can see that it may be very useful to shorten the sequence
to (1) learn what commits there are and think what you want to do
with each of them by looking at "git log --oneline master.." output
and then to (2) look at and edit todo in "git rebase -i master".
I personally would be fine without the step (1), as what "rebase -i"
gives me in step (2) essentially is "log --oneline master..". So I
am not quite getting in what way these command line options would be
more useful than without them, though, especially since I do not see
how well an option to reorder commits would fit with the way you
structured your UI.
Having already said that, if I were to get in the habit of looking
at "log" first to decide and then running "rebase -i" after I made
up my mind, using a tweaked "log --oneline" output that looks
perhaps like this:
$ git log --oneline master.. | tac | cat -n
1 xxxxxx prelim cleanly
2 xxxxxx implement the feature
3 xxxxxx document and test the feature
4 xxxxxx the final step
5 xxxxxx fixup! implement the feature
I think I may appreciate such a feature in "rebase -i" even more, if
the UI were done a bit differently, e.g.
$ git rebase -i --edit="1 3 2 b f5 b r4" master..
to mean "pick the first (i.e. bottommost) one, pick the third one
for testing, pick the second one, then break so that I can test,
fixup the fifth one, break to test, and finally pick the fourth
one but reword its log message", to come up with:
pick xxxxxx prelim cleanly
pick xxxxxx document and test the feature
pick xxxxxx implement the feature
break
fixup xxxxxx oops, the second one needs fixing
break
reword xxxxxx the final step
I am guessing that the way you did it, the above would be impossible
(as it requires reordering) but given that you would leave most of
the 'pick's intact and only tweak them in-place into drop, edit,
reword, etc., that may not be too bad, but I suspect that it would
become very verbose.
$ git rebase -i \
--pick HEAD~4 --pick HEAD~3 --break --fixup HEAD \
...
The --edit alternative I threw in in the above would make it
necessary for the user to spell out all the picks, and that would be
more cumbersome given our assumption that most picks will be left
intact, but then we could do something like
--edit="1-4 5e 6 8-" master..
to say "pick 1 thru 4, edit 5, pick 6, drop 7 and pick 8 thru the
end".
I dunno.
next prev parent reply other threads:[~2019-04-22 1:13 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-04-22 0:07 [PATCH/RFC 0/2] rebase: add switches to control todo-list setup Phil Hord
2019-04-22 0:07 ` [PATCH/RFC 1/2] rebase: add switches for drop, edit and reword Phil Hord
2019-04-22 0:07 ` [PATCH/RFC 2/2] rebase: add --break switch Phil Hord
2019-04-22 1:13 ` Junio C Hamano [this message]
2019-04-22 14:44 ` [PATCH/RFC 0/2] rebase: add switches to control todo-list setup Phillip Wood
2019-04-22 19:16 ` Phil Hord
2019-04-22 19:20 ` Phil Hord
2019-04-22 19:49 ` Denton Liu
2019-04-23 1:21 ` Junio C Hamano
2019-04-23 2:20 ` Phil Hord
2019-04-22 17:50 ` Phil Hord
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
List information: http://vger.kernel.org/majordomo-info.html
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=xmqqk1fm9712.fsf@gitster-ct.c.googlers.com \
--to=gitster@pobox.com \
--cc=git@vger.kernel.org \
--cc=liu.denton@gmail.com \
--cc=phil.hord@gmail.com \
--cc=phillip.wood123@gmail.com \
/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.
Code repositories for project(s) associated with this public inbox
https://80x24.org/mirrors/git.git
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 read-only IMAP folder(s) and NNTP newsgroup(s).