"Phillip Wood via GitGitGadget" <gitgitgadget@xxxxxxxxx> writes: > @@ -1240,6 +1241,12 @@ int cmd_rebase(int argc, const char **argv, const char *prefix) > if (options.root) > die(_("options '%s' and '%s' cannot be used together"), "--keep-base", "--root"); > } > + /* > + * --keep-base defaults to --reapply-cherry-picks as it is confusing if > + * commits disappear when using this option. > + */ > + if (options.reapply_cherry_picks < 0) > + options.reapply_cherry_picks = keep_base; Here, we set options.reapply_cherry_picks to 1 if keep_base is 1, but... > @@ -1416,7 +1423,11 @@ int cmd_rebase(int argc, const char **argv, const char *prefix) > if (options.empty != EMPTY_UNSPECIFIED) > imply_merge(&options, "--empty"); > > - if (options.reapply_cherry_picks) > + /* > + * --keep-base implements --reapply-cherry-picks by altering upstream so > + * it works with both backends. > + */ > + if (options.reapply_cherry_picks && !keep_base) > imply_merge(&options, "--reapply-cherry-picks"); ...if we implement --reapply-cherry-picks by altering upstream (and hence not need to rely on the "merge" backend), shouldn't we suppress the setting of options.reapply_cherry_picks too?