1

私の git ログには、これらの上位 4 つのコミットが表示されます。最初のコミットは、コードをプッシュしようとしたときに形成されたもので、最初にコードをプルしてからプッシュするように求められました。(基本的に合併しました)。

 commit 71c136f44e5bddd358d86277da730229d871f48c
    Merge: d896439 fe59f57
    Author: Ankit Gupta <ankit.gupta8898@gmail.com>
    Date:   Sat Jul 6 21:06:01 2013 +0100

        Merging

    commit d896439d1a33e6c0f3c78f1bf4ad731941c3c0bd
    Author: Ankit Gupta <ankit.gupta8898@gmail.com>
    Date:   Sat Jul 6 21:03:20 2013 +0100

        Message1

    commit fe59f57bec7eb2764c4c4e5cd1f5fdc21001bcc5
    Author: Ankit Gupta <ankit.gupta8898@gmail.com>
    Date:   Sat Jul 6 21:03:20 2013 +0100

        Message 2

    commit caa12dab636587a741ebc97c4e461d1618de55f9
    Author: Ankit Gupta <ankit.gupta8898@gmail.com>
    Date:   Fri Jul 5 16:20:54 2013 +0100

        Message 3

これら 4 つのコミットすべてを最新 (71c136) に押しつぶしたいのですが、実行git rebase -i HEAD~4すると表示されます

   pick 56e3419 Message 4
    pick caa12da Message 3
    pick d896439 Message 2
    pick fe59f57 Message 1
# Rebase ebabdfb..71c136f onto ebabdfb
#
# Commands:
#  p, pick = use commit
#  r, reword = use commit, but edit the commit message
#  e, edit = use commit, but stop for amending
#  s, squash = use commit, but meld into previous commit
#  f, fixup = like "squash", but discard this commit's log message
#  x, exec = run command (the rest of the line) using shell
#

最初のコミットがリストされていないのはなぜですか? また、4 つすべてを押しつぶす方法は?

4

1 に答える 1

1

4 つのコミットすべてを 1 つにマージするには、「git: how to insert a commit as the first, shift all the other?」で説明されている方法と同様の方法に従うことができます。

git symbolic-ref HEAD refs/heads/newroot
git rm --cached -r .
git clean -f -d
# All commits should be listed then: you can squash them
git rebase --interactive --onto newroot --root master
git branch -d newroot
于 2013-07-06T22:57:25.387 に答える