我正在合并一个可能有很多冲突的远程分支机构。我怎么知道它是否会有冲突?
我没看到任何类似于,git合并的预演。
我正在合并一个可能有很多冲突的远程分支机构。我怎么知道它是否会有冲突?
我没看到任何类似于,git合并的预演。
当前回答
为你的工作副本制作一个临时副本,然后合并,并将两者区分开来。
其他回答
只要将当前分支与远程分支区别开来,这将告诉你当你进行拉/合并时将会发生什么变化。
#see diff between current master and remote branch
git diff master origin/master
我的简单粗暴解决方案是:
创建一个“pre-master”分支(当然来自master) 将所有你想要的东西合并到这个预master中。 然后你可以看到合并是如何发生的,而不触及主。 将pre-master合并为master OR 将所有想要发布的分支合并到master中
不管怎样,我会听从@orange80的建议。
我猜你只是想知道在真正尝试合并之前你给自己惹了多少麻烦……并且在合并失败后重置到最后一次提交相对容易,所以如果这是预期的方法,我不会感到惊讶。
也就是说,如果你真的不想触及工作树中现有的文件,你可以创建一个补丁并针对目标分支测试它。这还可以显示对哪些文件做了哪些更改-只需在文本编辑器中打开补丁文件。
git checkout -b mycrazybranch
[change some stuff...]
git add .
git commit -m "changed some stuff"
git format-patch master --stdout > crazy.patch
git checkout master
git apply crazy.patch --check
[all good! cleanup...]
rm crazy.patch
如您所见,这将创建一个补丁文件,然后您可以测试它—检查并查看是否有任何错误,然后删除补丁文件。
我只需要实现一个自动查找存储库与其远程存储库之间冲突的方法。这个解决方案在内存中进行合并,所以它不会影响索引,也不会影响工作树。我认为这是解决这个问题最安全的方法。下面是它的工作原理:
将远程获取到存储库。例如: Git获取源主机 执行命令git merge-base: git merge-base FETCH_HEAD master 运行git merge-tree: git merge-tree mergebase master FETCH_HEAD (mergebase为上一步打印的merge-base十六进制id)
现在假设您想要合并远程主服务器和本地主服务器,但是您可以使用任何分支。Git合并树将在内存中执行合并,并将结果打印到标准输出。Grep模式<<或>>。或者您可以将输出打印到一个文件中并进行检查。如果你发现一行以“changed in both”开头,那么很可能会有冲突。
作为对已有答案的总结,有两种方法来检查是否存在合并冲突
Git format-patch $(Git merge-base branch1 branch2).——| git apply——3way——check -
注意,在运行上述命令时,当前的分支应该是branch1
另一种方法:
git merge --no-commit branch2
# check the return code here
git merge --abort