Skip to content

Commit 4effc5b

Browse files
Denton-Lgitster
authored andcommitted
rebase: fast-forward --fork-point in more cases
Before, when we rebased with a --fork-point invocation where the fork-point wasn't empty, we would be setting options.restrict_revision. The fast-forward logic would automatically declare that the rebase was not fast-forwardable if it was set. However, this was painting with a very broad brush. Refine the logic so that we can fast-forward in the case where the restricted revision is equal to the merge base, since we stop rebasing at the merge base anyway. Helped-by: Ævar Arnfjörð Bjarmason <[email protected]> Signed-off-by: Denton Liu <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent c0efb4c commit 4effc5b

File tree

2 files changed

+17
-13
lines changed

2 files changed

+17
-13
lines changed

builtin/rebase.c

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1261,6 +1261,7 @@ static int is_linear_history(struct commit *from, struct commit *to)
12611261
}
12621262

12631263
static int can_fast_forward(struct commit *onto, struct commit *upstream,
1264+
struct commit *restrict_revision,
12641265
struct object_id *head_oid, struct object_id *merge_base)
12651266
{
12661267
struct commit *head = lookup_commit(the_repository, head_oid);
@@ -1280,6 +1281,9 @@ static int can_fast_forward(struct commit *onto, struct commit *upstream,
12801281
if (!oideq(merge_base, &onto->object.oid))
12811282
goto done;
12821283

1284+
if (restrict_revision && !oideq(&restrict_revision->object.oid, merge_base))
1285+
goto done;
1286+
12831287
if (!upstream)
12841288
goto done;
12851289

@@ -2042,9 +2046,9 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
20422046
* with new commits recreated by replaying their changes. This
20432047
* optimization must not be done if this is an interactive rebase.
20442048
*/
2045-
if (can_fast_forward(options.onto, options.upstream, &options.orig_head,
2046-
&merge_base) &&
2047-
!is_interactive(&options) && !options.restrict_revision) {
2049+
if (can_fast_forward(options.onto, options.upstream, options.restrict_revision,
2050+
&options.orig_head, &merge_base) &&
2051+
!is_interactive(&options)) {
20482052
int flag;
20492053

20502054
if (!(options.flags & REBASE_FORCE)) {

t/t3432-rebase-fast-forward.sh

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -70,32 +70,32 @@ test_rebase_same_head_ () {
7070
}
7171

7272
changes='no changes'
73-
test_rebase_same_head success work same success work same
73+
test_rebase_same_head success noop same success work same
7474
test_rebase_same_head success noop same success noop-force same master
7575
test_rebase_same_head success noop same success noop-force diff --onto B B
7676
test_rebase_same_head success noop same success noop-force diff --onto B... B
7777
test_rebase_same_head success noop same success noop-force same --onto master... master
7878
test_rebase_same_head success noop same success noop-force same --no-fork-point
79-
test_rebase_same_head success work same success work same --fork-point master
80-
test_rebase_same_head failure noop same success work diff --fork-point --onto B B
81-
test_rebase_same_head failure work same success work diff --fork-point --onto B... B
82-
test_rebase_same_head success work same success work same --fork-point --onto master... master
79+
test_rebase_same_head success noop same success work same --fork-point master
80+
test_rebase_same_head success noop same success work diff --fork-point --onto B B
81+
test_rebase_same_head success noop same success work diff --fork-point --onto B... B
82+
test_rebase_same_head success noop same success work same --fork-point --onto master... master
8383

8484
test_expect_success 'add work same to side' '
8585
test_commit E
8686
'
8787

8888
changes='our changes'
89-
test_rebase_same_head success work same success work same
89+
test_rebase_same_head success noop same success work same
9090
test_rebase_same_head success noop same success noop-force same master
9191
test_rebase_same_head success noop same success noop-force diff --onto B B
9292
test_rebase_same_head success noop same success noop-force diff --onto B... B
9393
test_rebase_same_head success noop same success noop-force same --onto master... master
9494
test_rebase_same_head success noop same success noop-force same --no-fork-point
95-
test_rebase_same_head success work same success work same --fork-point master
96-
test_rebase_same_head failure work same success work diff --fork-point --onto B B
97-
test_rebase_same_head failure work same success work diff --fork-point --onto B... B
98-
test_rebase_same_head success work same success work same --fork-point --onto master... master
95+
test_rebase_same_head success noop same success work same --fork-point master
96+
test_rebase_same_head success noop same success work diff --fork-point --onto B B
97+
test_rebase_same_head success noop same success work diff --fork-point --onto B... B
98+
test_rebase_same_head success noop same success work same --fork-point --onto master... master
9999

100100
test_expect_success 'add work same to upstream' '
101101
git checkout master &&

0 commit comments

Comments
 (0)