标签:
下面在教两个平时用到的Git技巧。
情景:
你建了自己的分支,如zhc
git branch -b zhc
然后你做了很多次的commit。
你想把这些很多个commit作为一个commit到mainline branch上,该怎么做呢?
方法:
首先更新mainline到最新
git checkout mainline
git pull --rebase
然后将zhc分支的多个commit变成一次commit
git merge --squash zhc
再次更新确认是最新的
git pull --rebase
git diff origin mainline
最后push
git push origin mainline
情景二:
另外,如果你在mainline上commit了,然后你发现别人也在mainline上做了改动并且push到了远程仓库上,你该怎么办呢?
方法:
很多人也许会先将此次提交保存起来(cherry-pick到另一个分支,或者是reset后stash起来),然后在pull最新的,最后在提交到最顶端。其实没有必要,git已经想到了此情景,并且实现了这种操作。命令就是:
git pull --rebase
把所有的remote变化都拉下来,并且将你最新的commit置于最顶上,这非常的方便。
原文:http://blog.csdn.net/hongchangfirst/article/details/44671231
作者:hongchangfirst
hongchangfirst的主页:http://blog.csdn.net/hongchangfirst
标签:
原文地址:http://blog.csdn.net/hongchangfirst/article/details/44671231