开发者

git: getting rid of previous commit so that you can amend the one before

what happened: change1, git commit, git push, change2, git commit

开发者_JS百科

what should have happened: change1, git commit, git push, change2, git commit --amend

It's not important that I retain change2, but it is important that I am able to amend the original commit. How do I do this?


Since you have pushed it, be aware that this is tricky and you are rewriting history.

You can git rebase -i to before the first commit and choose edit for the commit in the text that is presented to you. This way, you will be brought to the first commit state where you change / amend and then git will apply the next commit over it.

Or you can git reset --soft first to go to first commit and amend it along with change2.

Or git reset --hard first to go to the first commit and amend it without the change2


[I assume you know that Linus thinks this is evil]

$ git reset --hard HEAD^  # remove last commit
$ git commit --amend
$ git push --force <remote> <branch>

If you want the last commit to be applied afterward, then do

$ SHA1=`git rev-parse master`
$ git branch temp
# now the three commands above
$ git cherry-pick $SHA1
$ git branch -d temp
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜