Support lines of the form "fixup! 7a235b" that specify an exact commit in addition to the normal "squash! Old commit message" form. Signed-off-by: Kevin Ballard <kevin@xxxxxx> --- I chose 4 characters as the restriction because that's the minimum number that `git rev-parse --short=<n>` will emit. git-rebase--interactive.sh | 13 +++++++++---- t/t3415-rebase-autosquash.sh | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+), 4 deletions(-) diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh index 379bbac..9121bb6 100755 --- a/git-rebase--interactive.sh +++ b/git-rebase--interactive.sh @@ -693,12 +693,17 @@ rearrange_squash () { case " $used" in *" $squash "*) continue ;; esac - case "$message" in - "$msg"*) + emit=0 + case "$message" in "$msg"*) emit=1;; esac + if test $emit != 1; then + case "$sha1" in "$msg"*) emit=1;; esac + # ensure the message is at least 4 characters long + case "$msg" in ????*);; *) emit=0;; esac + fi + if test $emit = 1; then printf '%s\n' "$action $squash $action! $msg" used="$used$squash " - ;; - esac + fi done <"$1.sq" done >"$1.rearranged" <"$1" cat "$1.rearranged" >"$1" diff --git a/t/t3415-rebase-autosquash.sh b/t/t3415-rebase-autosquash.sh index 712bbe8..14cdbeb 100755 --- a/t/t3415-rebase-autosquash.sh +++ b/t/t3415-rebase-autosquash.sh @@ -136,5 +136,38 @@ test_expect_success 'auto squash that matches a commit after the squash' ' test 1 = $(git cat-file commit HEAD | grep third | wc -l) && test 1 = $(git cat-file commit HEAD^ | grep third | wc -l) ' +test_expect_success 'auto squash that matches a sha1' ' + git reset --hard base && + echo 1 >file1 && + git add -u && + test_tick && + git commit -m "squash! $(git rev-parse --short HEAD^)" && + git tag final-shasquash && + test_tick && + git rebase --autosquash -i HEAD^^^ && + git log --oneline >actual && + test 3 = $(wc -l <actual) && + git diff --exit-code final-shasquash && + test 1 = "$(git cat-file blob HEAD^:file1)" && + test 1 = $(git cat-file commit HEAD^ | grep squash | wc -l) +' + +# this test just ensures that < 4 characters can't match a sha1 +test_expect_success 'auto squash that accidentally matches a sha1' ' + git reset --hard base && + echo 1 >file1 && + git add -u && + test_tick && + git commit -m "squash! $(git rev-parse HEAD^ | cut -c 1-3)" && + git tag final-badshasquash && + test_tick && + git rebase --autosquash -i HEAD^^^ && + git log --oneline >actual && + test 4 = $(wc -l <actual) && + git diff --exit-code final-badshasquash && + test 0 = "$(git cat-file blob HEAD^^:file1)" && + test 0 = $(git cat-file commit HEAD^^ | grep squash | wc -l) && + test 1 = $(git cat-file commit HEAD | grep squash | wc -l) +' test_done -- 1.7.3.2.201.g24941.dirty -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html