我一直在使用Windows上的Git (msysgit)来跟踪我一直在做的一些设计工作的更改。

今天我一直在一台不同的PC上工作(与远程repo brian),我现在正试图将今天完成的编辑合并到我笔记本电脑上的常规本地版本。

在我的笔记本电脑上,我已经使用git pull brian master将更改拉到我的本地版本。除了主InDesign文档之外,一切都很好-这显示为冲突。

PC (brian)上的版本是我想保留的最新版本,但我不知道什么命令告诉回购使用这一个。

我试图直接复制文件到我的笔记本电脑上,但这似乎打破了整个合并过程。

有人能告诉我正确的方向吗?


当前回答

您必须手动解决冲突(复制文件),然后像这样提交文件(无论您是复制它还是使用本地版本)

git commit -a -m "Fix merge conflict in test.foo"

Git通常会在合并后自动提交,但当它检测到自己无法解决的冲突时,它会应用它找到的所有补丁,并将其余的补丁留给您手动解决和提交。Git合并手册页,Git- svn速成课程或这篇博客文章可能会对它的工作原理有所启发。

编辑:请看下面的帖子,你实际上不必自己复制文件,但可以使用

git checkout --ours -- path/to/file.txt
git checkout --theirs -- path/to/file.txt

以选择所需文件的版本。只有当你想混合使用两个版本时,才需要复制/编辑文件。

请将米帕迪斯的答案标记为正确答案。

其他回答

mipadi的回答对我不太管用,我需要这样做:

Git签出——我们的路径/to/file.bin

或者,保持被合并的版本:

Git签出——他们的路径/to/file.bin

then

选择add path/to/file

然后我可以再次使用"git合并工具"继续处理下一个冲突。

我使用Git工作流的Excel - https://www.xltrail.com/blog/git-workflow-for-excel应用程序来解决我的二进制文件相关的合并问题。这个开源应用程序可以帮助我高效地解决问题,而不用花费太多时间,让我选择正确的文件版本而不会有任何困惑。

对于这种情况,Git签出接受我们的或他们的选项。因此,如果你有一个合并冲突,你知道你只是想从你合并的分支文件,你可以这样做:

$ git checkout --theirs -- path/to/conflicted-file.txt

使用该版本的文件。同样,如果您知道您想要自己的版本(而不是被合并的版本),则可以使用

$ git checkout --ours -- path/to/conflicted-file.txt

这个过程是在你向Github提交了一个pull请求后解决二进制文件冲突:

所以在Github上,你发现你的拉请求在二进制文件上有冲突。 现在回到本地计算机上相同的git分支。 您(a)再次重新制作/重新构建这个二进制文件,(b)将生成的二进制文件提交到相同的git分支。 然后你把这个相同的git分支再次推到Github。

在Github上,在你的拉请求时,冲突应该会消失。

如果二进制文件不仅仅是一个dll文件,或者可以像图像一样直接编辑的文件,或者一个混合文件(你不需要丢弃/选择一个文件或另一个文件),真正的合并应该是这样的:

我建议搜索一个diff工具,针对你的二进制文件,例如,有一些免费的图像文件

npm install -g imagediff IIRC from https://github.com/uber/image-diff 或python https://github.com/kaikuehne/mirror.git 外面还有其他人

然后比较它们。

如果没有用于比较文件的diff工具,那么如果您有bin文件的原始生成器(也就是说,存在用于它的编辑器……)就像blender 3d一样,你可以手动检查这些文件,也可以查看日志,并询问其他人你应该包括什么) 并使用https://git-scm.com/book/es/v2/Git-Tools-Advanced-Merging#_manual_remerge输出文件

$ git show :1:hello.blend > hello.common.blend
$ git show :2:hello.blend > hello.ours.blend
$ git show :3:hello.blend > hello.theirs.blend