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:
Junio C Hamano 2014-07-27 15:14:21 -07:00
commit 3dcacd7797
4 changed files with 41 additions and 8 deletions

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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 &&