Merge branch 'jk/rebase-am-fork-point'
"git rebase --fork-point" did not filter out patch-identical commits correctly. * jk/rebase-am-fork-point: rebase: omit patch-identical commits with --fork-point rebase--am: use --cherry-pick instead of --ignore-if-in-upstream
This commit is contained in:
commit
3dcacd7797
@ -29,7 +29,13 @@ skip)
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
test -n "$rebase_root" && root_flag=--root
|
if test -z "$rebase_root"
|
||||||
|
# this is now equivalent to ! -z "$upstream"
|
||||||
|
then
|
||||||
|
revisions=$upstream...$orig_head
|
||||||
|
else
|
||||||
|
revisions=$onto...$orig_head
|
||||||
|
fi
|
||||||
|
|
||||||
ret=0
|
ret=0
|
||||||
if test -n "$keep_empty"
|
if test -n "$keep_empty"
|
||||||
@ -38,14 +44,17 @@ then
|
|||||||
# empty commits and even if it didn't the format doesn't really lend
|
# empty commits and even if it didn't the format doesn't really lend
|
||||||
# itself well to recording empty patches. fortunately, cherry-pick
|
# itself well to recording empty patches. fortunately, cherry-pick
|
||||||
# makes this easy
|
# makes this easy
|
||||||
git cherry-pick ${gpg_sign_opt:+"$gpg_sign_opt"} --allow-empty "$revisions"
|
git cherry-pick ${gpg_sign_opt:+"$gpg_sign_opt"} --allow-empty \
|
||||||
|
--right-only "$revisions" \
|
||||||
|
${restrict_revision+^$restrict_revision}
|
||||||
ret=$?
|
ret=$?
|
||||||
else
|
else
|
||||||
rm -f "$GIT_DIR/rebased-patches"
|
rm -f "$GIT_DIR/rebased-patches"
|
||||||
|
|
||||||
git format-patch -k --stdout --full-index --ignore-if-in-upstream \
|
git format-patch -k --stdout --full-index --cherry-pick --right-only \
|
||||||
--src-prefix=a/ --dst-prefix=b/ --no-renames --no-cover-letter \
|
--src-prefix=a/ --dst-prefix=b/ --no-renames --no-cover-letter \
|
||||||
$root_flag "$revisions" >"$GIT_DIR/rebased-patches"
|
"$revisions" ${restrict_revision+^$restrict_revision} \
|
||||||
|
>"$GIT_DIR/rebased-patches"
|
||||||
ret=$?
|
ret=$?
|
||||||
|
|
||||||
if test 0 != $ret
|
if test 0 != $ret
|
||||||
|
@ -963,7 +963,7 @@ else
|
|||||||
fi
|
fi
|
||||||
git rev-list $merges_option --pretty=oneline --abbrev-commit \
|
git rev-list $merges_option --pretty=oneline --abbrev-commit \
|
||||||
--abbrev=7 --reverse --left-right --topo-order \
|
--abbrev=7 --reverse --left-right --topo-order \
|
||||||
$revisions | \
|
$revisions ${restrict_revision+^$restrict_revision} | \
|
||||||
sed -n "s/^>//p" |
|
sed -n "s/^>//p" |
|
||||||
while read -r shortsha1 rest
|
while read -r shortsha1 rest
|
||||||
do
|
do
|
||||||
|
@ -59,6 +59,7 @@ If you prefer to skip this patch, run "git rebase --skip" instead.
|
|||||||
To check out the original branch and stop rebasing, run "git rebase --abort".')
|
To check out the original branch and stop rebasing, run "git rebase --abort".')
|
||||||
"
|
"
|
||||||
unset onto
|
unset onto
|
||||||
|
unset restrict_revision
|
||||||
cmd=
|
cmd=
|
||||||
strategy=
|
strategy=
|
||||||
strategy_opts=
|
strategy_opts=
|
||||||
@ -546,7 +547,7 @@ then
|
|||||||
"${switch_to:-HEAD}")
|
"${switch_to:-HEAD}")
|
||||||
if test -n "$new_upstream"
|
if test -n "$new_upstream"
|
||||||
then
|
then
|
||||||
upstream=$new_upstream
|
restrict_revision=$new_upstream
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -572,7 +573,7 @@ require_clean_work_tree "rebase" "$(gettext "Please commit or stash them.")"
|
|||||||
# and if this is not an interactive rebase.
|
# and if this is not an interactive rebase.
|
||||||
mb=$(git merge-base "$onto" "$orig_head")
|
mb=$(git merge-base "$onto" "$orig_head")
|
||||||
if test "$type" != interactive && test "$upstream" = "$onto" &&
|
if test "$type" != interactive && test "$upstream" = "$onto" &&
|
||||||
test "$mb" = "$onto" &&
|
test "$mb" = "$onto" && test -z "$restrict_revision" &&
|
||||||
# linear history?
|
# linear history?
|
||||||
! (git rev-list --parents "$onto".."$orig_head" | sane_grep " .* ") > /dev/null
|
! (git rev-list --parents "$onto".."$orig_head" | sane_grep " .* ") > /dev/null
|
||||||
then
|
then
|
||||||
@ -626,7 +627,7 @@ if test -n "$rebase_root"
|
|||||||
then
|
then
|
||||||
revisions="$onto..$orig_head"
|
revisions="$onto..$orig_head"
|
||||||
else
|
else
|
||||||
revisions="$upstream..$orig_head"
|
revisions="${restrict_revision-$upstream}..$orig_head"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
run_specific_rebase
|
run_specific_rebase
|
||||||
|
@ -169,6 +169,29 @@ test_expect_success 'default to common base in @{upstream}s reflog if no upstrea
|
|||||||
test_cmp expect actual
|
test_cmp expect actual
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success 'cherry-picked commits and fork-point work together' '
|
||||||
|
git checkout default-base &&
|
||||||
|
echo Amended >A &&
|
||||||
|
git commit -a --no-edit --amend &&
|
||||||
|
test_commit B B &&
|
||||||
|
test_commit new_B B "New B" &&
|
||||||
|
test_commit C C &&
|
||||||
|
git checkout default &&
|
||||||
|
git reset --hard default-base@{4} &&
|
||||||
|
test_commit D D &&
|
||||||
|
git cherry-pick -2 default-base^ &&
|
||||||
|
test_commit final_B B "Final B" &&
|
||||||
|
git rebase &&
|
||||||
|
echo Amended >expect &&
|
||||||
|
test_cmp A expect &&
|
||||||
|
echo "Final B" >expect &&
|
||||||
|
test_cmp B expect &&
|
||||||
|
echo C >expect &&
|
||||||
|
test_cmp C expect &&
|
||||||
|
echo D >expect &&
|
||||||
|
test_cmp D expect
|
||||||
|
'
|
||||||
|
|
||||||
test_expect_success 'rebase -q is quiet' '
|
test_expect_success 'rebase -q is quiet' '
|
||||||
git checkout -b quiet topic &&
|
git checkout -b quiet topic &&
|
||||||
git rebase -q master >output.out 2>&1 &&
|
git rebase -q master >output.out 2>&1 &&
|
||||||
|
Loading…
Reference in New Issue
Block a user