我正在合并一个可能有很多冲突的远程分支机构。我怎么知道它是否会有冲突?
我没看到任何类似于,git合并的预演。
我正在合并一个可能有很多冲突的远程分支机构。我怎么知道它是否会有冲突?
我没看到任何类似于,git合并的预演。
当前回答
如前所述,传入——no-commit标志,但为了避免快进提交,也传入——no-ff,如下所示:
$ git merge --no-commit --no-ff $BRANCH
检查阶段性的变化:
$ git diff --cached
你可以撤销合并,即使是快进合并:
$ git merge --abort
其他回答
我只需要实现一个自动查找存储库与其远程存储库之间冲突的方法。这个解决方案在内存中进行合并,所以它不会影响索引,也不会影响工作树。我认为这是解决这个问题最安全的方法。下面是它的工作原理:
将远程获取到存储库。例如: 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 checkout my-branch
git merge origin/target-branch
你将看到是否有任何冲突,并可以计划如何解决它们。
在这之后,你可以通过git merge—abort终止合并,或者(如果没有任何冲突并且合并已经发生)通过git reset—hard HEAD~1回滚到之前的提交
我做了一个别名来做这件事,就像一个魅力,我这样做:
git config --global alias.mergetest '!f(){ git merge --no-commit --no-ff "$1"; git merge --abort; echo "Merge aborted"; };f '
现在我只需调用
git mergetest <branchname>
看看是否有任何冲突。
这可能很有趣:从文档中:
如果您尝试合并,导致复杂的冲突,并希望 重新开始,你可以用git merge -abort恢复。
但你也可以用幼稚(但缓慢)的方式来做:
rm -Rf /tmp/repository
cp -r repository /tmp/
cd /tmp/repository
git merge ...
...if successful, do the real merge. :)
(注意:仅仅克隆到/tmp不能工作,你需要一个副本,以确保未提交的更改不会冲突)。
我知道这在理论上是跑题的,但对于从谷歌搜索到这里的人来说,实际上是非常切题的。
当有疑问时,你可以使用Github界面创建一个pull-request,并检查它是否表明干净的合并是可能的。