Skip to content

Commit 18633e1

Browse files
dschogitster
authored andcommitted
rebase -i: use the rebase--helper builtin
Now that the sequencer learned to process a "normal" interactive rebase, we use it. The original shell script is still used for "non-normal" interactive rebases, i.e. when --root or --preserve-merges was passed. Please note that the --root option (via the $squash_onto variable) needs special handling only for the very first command, hence it is still okay to use the helper upon continue/skip. Also please note that the --no-ff setting is volatile, i.e. when the interactive rebase is interrupted at any stage, there is no record of it. Therefore, we have to pass it from the shell script to the rebase--helper. Note: the test t3404 had to be adjusted because the the error messages produced by the sequencer comply with our current convention to start with a lower-case letter. Signed-off-by: Johannes Schindelin <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 4557f1a commit 18633e1

File tree

2 files changed

+14
-1
lines changed

2 files changed

+14
-1
lines changed

git-rebase--interactive.sh

+13
Original file line numberDiff line numberDiff line change
@@ -1069,6 +1069,10 @@ git_rebase__interactive () {
10691069

10701070
case "$action" in
10711071
continue)
1072+
if test ! -d "$rewritten"
1073+
then
1074+
exec git rebase--helper ${force_rebase:+--no-ff} --continue
1075+
fi
10721076
# do we have anything to commit?
10731077
if git diff-index --cached --quiet HEAD --
10741078
then
@@ -1128,6 +1132,10 @@ first and then run 'git rebase --continue' again.")"
11281132
skip)
11291133
git rerere clear
11301134

1135+
if test ! -d "$rewritten"
1136+
then
1137+
exec git rebase--helper ${force_rebase:+--no-ff} --continue
1138+
fi
11311139
do_rest
11321140
return 0
11331141
;;
@@ -1314,6 +1322,11 @@ expand_todo_ids
13141322
test -d "$rewritten" || test -n "$force_rebase" || skip_unnecessary_picks
13151323

13161324
checkout_onto
1325+
if test -z "$rebase_root" && test ! -d "$rewritten"
1326+
then
1327+
require_clean_work_tree "rebase"
1328+
exec git rebase--helper ${force_rebase:+--no-ff} --continue
1329+
fi
13171330
do_rest
13181331

13191332
}

t/t3404-rebase-interactive.sh

+1-1
Original file line numberDiff line numberDiff line change
@@ -556,7 +556,7 @@ test_expect_success 'clean error after failed "exec"' '
556556
echo "edited again" > file7 &&
557557
git add file7 &&
558558
test_must_fail git rebase --continue 2>error &&
559-
test_i18ngrep "You have staged changes in your working tree." error
559+
test_i18ngrep "you have staged changes in your working tree" error
560560
'
561561

562562
test_expect_success 'rebase a detached HEAD' '

0 commit comments

Comments
 (0)