码迷,mamicode.com
首页 > 其他好文 > 详细

git revert

时间:2017-11-15 22:00:19      阅读:301      评论:0      收藏:0      [点我收藏+]

标签:ast   图片   mit   代码   目标   images   work   参考   logs   

技术分享

技术分享

当前图片所示,master分支上一共有两个merge:e2b447ed与6ae8c0a4。如果我们想要回到e2b447ed那次commit。

只需要输入git revert 6ae8c0a4d4db769c9c260b950908c1bb4b616001(e2b447ed对应的最新commit)-m 1即可。

问题一: -m 选项

-m 选项用于指定本次回滚到哪个祖先commit(由于一次merge会有许多祖先commit)

图二为对应 e2b447ed那个commit的log信息。可以看到本次commit有两个祖先commit:e2b447ed与a46817e5。-m 1指的是本次revert选择的是revert到commit:e2b447ed这个祖先commit。

问题二:本次回滚的目的是回归到e2b447ed那次commit,即revert掉6ae8c0a4的那次merge所带的所有commit,不仅仅回滚6ae8c0a4的那次merge。

一次merge commit指的是合并多次commit为一次commit并merge到目标分支。当我们revert 一次merge commit时,它会revert掉当前merge commit所带有的所有合并过的commit。

就图一而言。我们执行git revert 6ae8c0a4d4db769c9c260b950908c1bb4b616001(e2b447ed对应的最新commit)-m 1。revert掉的commit如下图所示:

技术分享

merge操作不会关心commit。merge操作会合并多个分支上的head commit。

参考:https://stackoverflow.com/questions/10330970/revert-pushed-branch-to-a-concrete-commit

安利一波批量revert

git revert HEAD~3

回滚到指定的第四次commit并创建一个新的commit。注意,第一到三次commit不会revert。

git revert -n master~5..master~2

真正的批量回滚。回滚master分支上第五次(包括第五次)到第三次(包含第三次)共3次commit。代码里包含了第一次到第二次以及第六次(包含第六次)以后的所有commit。不会产生新的commit. 本次修改只发生在 the working tree 与 the index.

 

git revert

标签:ast   图片   mit   代码   目标   images   work   参考   logs   

原文地址:http://www.cnblogs.com/pzy-123/p/7840744.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!