Mercurial内部:合并和二进制文件冲突

时间:2009-06-14 06:14:20

标签: mercurial merge binary

伙计们,我正在使用i nternal:merge 工具,因为我不是GUI diff工具的忠实粉丝。我真的很喜欢它,我发现有点令人困惑,不太方便的是它对二进制文件冲突的行为。

它无法合并二进制文件和退出,这绝对是正确的。但是,在包含冲突文件“ foo ”的目录中,它只会创建“ foo.orig ”文件。

它至少可以创建“ foo.other ”,所以我可以选择使用哪个版本的文件(我的或拉动的文件)?

P.S。我在Mercurial邮件列表中问了同样的问题但几天没有人回复我,也许我会在这里有更多的运气:)

1 个答案:

答案 0 :(得分:4)

你已经对你的问题on the Mercurial mailing list得到了一些意见 - 我继续尝试在线程中建议脚本。自从我使用Subversion以来已经有很长一段时间了,但我认为这个简单的脚本可以解决问题:

#!/bin/sh
cp "$1" "$1.mine"
cp "$2" "$1.base"
cp "$3" "$1.other"
false

最后的false命令使脚本返回非零退出代码,向Mercurial发出合并失败的信号。对于Windows,它看起来像这样(感谢Pavel):

@copy %1 %1.mine
@copy %2 %1.base
@copy %3 %1.other
exit 1

我在~/tmp/m.sh中保存了Unix版本,并尝试了没有配置

的其他合并设置
[ui]
merge = ~/tmp/m.sh

我创建了一个包含两个头的存储库,每个头都对JPEG文件(mg.jpg)进行了相互冲突的更改。我还在文本文件(a.txt)中添加了一个非冲突的更改。合并给了:

% hg --debug merge
  searching for copies back to rev 1
resolving manifests
 overwrite None partial False
 ancestor 0848c2f8f8f8 local 845b8aa076bd+ remote f611c55aa8ec
 mg.jpg: versions differ -> m
 a.txt: versions differ -> m
preserving a.txt for resolve of a.txt
preserving mg.jpg for resolve of mg.jpg
picked tool '~/tmp/m.sh' for a.txt (binary False symlink False)
merging a.txt
my a.txt@845b8aa076bd+ other a.txt@f611c55aa8ec ancestor a.txt@0848c2f8f8f8
 premerge successful
picked tool '~/tmp/m.sh' for mg.jpg (binary True symlink False)
merging mg.jpg
my mg.jpg@845b8aa076bd+ other mg.jpg@f611c55aa8ec ancestor mg.jpg@0848c2f8f8f8
merging mg.jpg failed!
0 files updated, 1 files merged, 0 files removed, 1 files unresolved
use 'hg resolve' to retry unresolved file merges or 'hg up --clean' to abandon

好处是预合并可以自己合并a.txt,因此没有创建a.txt.*个文件:

% hg stat
M a.txt
M mg.jpg
? mg.jpg.base
? mg.jpg.mine
? mg.jpg.orig
? mg.jpg.other

您可以进一步调整此脚本以满足您的需求 - 如果您这样做,请考虑将信息添加到Mercurial wiki或至少在邮件列表中发布您的发现。