]> git.ipfire.org Git - thirdparty/git.git/commit - Documentation/git-rebase.txt
rebase: add --quit to cleanup rebase, leave everything else untouched
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>
Sat, 12 Nov 2016 02:00:41 +0000 (09:00 +0700)
committerJunio C Hamano <gitster@pobox.com>
Sun, 11 Dec 2016 21:51:41 +0000 (13:51 -0800)
commit9512177b68263085fef84cdbd45ecdee7bfe2377
tree669bb556ed96ba389a0f7c3bfe83d663bf21ee96
parent0b65a8dbdb38962e700ee16776a3042beb489060
rebase: add --quit to cleanup rebase, leave everything else untouched

There are occasions when you decide to abort an in-progress rebase and
move on to do something else but you forget to do "git rebase --abort"
first. Or the rebase has been in progress for so long you forgot about
it. By the time you realize that (e.g. by starting another rebase)
it's already too late to retrace your steps. The solution is normally

    rm -r .git/<some rebase dir>

and continue with your life. But there could be two different
directories for <some rebase dir> (and it obviously requires some
knowledge of how rebase works), and the ".git" part could be much
longer if you are not at top-dir, or in a linked worktree. And
"rm -r" is very dangerous to do in .git, a mistake in there could
destroy object database or other important data.

Provide "git rebase --quit" for this use case, mimicking a precedent
that is "git cherry-pick --quit".

Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/git-rebase.txt
contrib/completion/git-completion.bash
git-rebase.sh
t/t3407-rebase-abort.sh