rebase: fix incompatiblity checks for --[no-]reapply-cherry-picks
--[no-]reapply-cherry-picks was traditionally only supported by the
sequencer. Support was added for the apply backend, when --keep-base is
also specified, in commit ce5238a690
("rebase --keep-base: imply
--reapply-cherry-picks", 2022-10-17). Make the code error out when
--[no-]reapply-cherry-picks is specified AND the apply backend is used
AND --keep-base is not specified. Also, clarify a number of comments
surrounding the interaction of these flags.
Helped-by: Phillip Wood <phillip.wood@dunelm.org.uk>
Signed-off-by: Elijah Newren <newren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
b8ad365640
commit
ffeaca177a
@ -650,7 +650,7 @@ are incompatible with the following options:
|
|||||||
* --exec
|
* --exec
|
||||||
* --no-keep-empty
|
* --no-keep-empty
|
||||||
* --empty=
|
* --empty=
|
||||||
* --reapply-cherry-picks
|
* --[no-]reapply-cherry-picks when used without --keep-base
|
||||||
* --edit-todo
|
* --edit-todo
|
||||||
* --update-refs
|
* --update-refs
|
||||||
* --root when used without --onto
|
* --root when used without --onto
|
||||||
|
@ -1224,13 +1224,6 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
|
|||||||
if (options.fork_point < 0)
|
if (options.fork_point < 0)
|
||||||
options.fork_point = 0;
|
options.fork_point = 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
* --keep-base defaults to --reapply-cherry-picks to avoid losing
|
|
||||||
* commits when using this option.
|
|
||||||
*/
|
|
||||||
if (options.reapply_cherry_picks < 0)
|
|
||||||
options.reapply_cherry_picks = keep_base;
|
|
||||||
|
|
||||||
if (options.root && options.fork_point > 0)
|
if (options.root && options.fork_point > 0)
|
||||||
die(_("options '%s' and '%s' cannot be used together"), "--root", "--fork-point");
|
die(_("options '%s' and '%s' cannot be used together"), "--root", "--fork-point");
|
||||||
|
|
||||||
@ -1406,12 +1399,27 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
|
|||||||
if (options.empty != EMPTY_UNSPECIFIED)
|
if (options.empty != EMPTY_UNSPECIFIED)
|
||||||
imply_merge(&options, "--empty");
|
imply_merge(&options, "--empty");
|
||||||
|
|
||||||
/*
|
if (options.reapply_cherry_picks < 0)
|
||||||
* --keep-base implements --reapply-cherry-picks by altering upstream so
|
/*
|
||||||
* it works with both backends.
|
* We default to --no-reapply-cherry-picks unless
|
||||||
*/
|
* --keep-base is given; when --keep-base is given, we want
|
||||||
if (options.reapply_cherry_picks && !keep_base)
|
* to default to --reapply-cherry-picks.
|
||||||
imply_merge(&options, "--reapply-cherry-picks");
|
*/
|
||||||
|
options.reapply_cherry_picks = keep_base;
|
||||||
|
else if (!keep_base)
|
||||||
|
/*
|
||||||
|
* The apply backend always searches for and drops cherry
|
||||||
|
* picks. This is often not wanted with --keep-base, so
|
||||||
|
* --keep-base allows --reapply-cherry-picks to be
|
||||||
|
* simulated by altering the upstream such that
|
||||||
|
* cherry-picks cannot be detected and thus all commits are
|
||||||
|
* reapplied. Thus, --[no-]reapply-cherry-picks is
|
||||||
|
* supported when --keep-base is specified, but not when
|
||||||
|
* --keep-base is left out.
|
||||||
|
*/
|
||||||
|
imply_merge(&options, options.reapply_cherry_picks ?
|
||||||
|
"--reapply-cherry-picks" :
|
||||||
|
"--no-reapply-cherry-picks");
|
||||||
|
|
||||||
if (gpg_sign)
|
if (gpg_sign)
|
||||||
options.gpg_sign_opt = xstrfmt("-S%s", gpg_sign);
|
options.gpg_sign_opt = xstrfmt("-S%s", gpg_sign);
|
||||||
|
@ -60,6 +60,16 @@ test_rebase_am_only () {
|
|||||||
test_must_fail git rebase $opt --exec 'true' A
|
test_must_fail git rebase $opt --exec 'true' A
|
||||||
"
|
"
|
||||||
|
|
||||||
|
test_expect_success "$opt incompatible with --no-reapply-cherry-picks" "
|
||||||
|
git checkout B^0 &&
|
||||||
|
test_must_fail git rebase $opt --no-reapply-cherry-picks A
|
||||||
|
"
|
||||||
|
|
||||||
|
test_expect_success "$opt incompatible with --reapply-cherry-picks" "
|
||||||
|
git checkout B^0 &&
|
||||||
|
test_must_fail git rebase $opt --reapply-cherry-picks A
|
||||||
|
"
|
||||||
|
|
||||||
test_expect_success "$opt incompatible with --update-refs" "
|
test_expect_success "$opt incompatible with --update-refs" "
|
||||||
git checkout B^0 &&
|
git checkout B^0 &&
|
||||||
test_must_fail git rebase $opt --update-refs A
|
test_must_fail git rebase $opt --update-refs A
|
||||||
|
Loading…
Reference in New Issue
Block a user