gpt4 book ai didi

Mercurial 内部 :merge and binary file conflicts

转载 作者:行者123 更新时间:2023-12-01 13:08:34 24 4
gpt4 key购买 nike

伙计们,我正在使用 iinternal:merge 工具,因为我不是 GUI 差异工具的忠实粉丝。我真的很喜欢它,唯一让我感到困惑和不太方便的是它对二进制文件冲突的行为。

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

它能否至少创建“foo.other”,以便我可以选择要使用的文件版本(我的还是提取的)?

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

最佳答案

您已经对您的问题进行了一些输入 on the Mercurial mailing list -- 我继续尝试制作线程中建议的脚本。我已经有很长一段时间没有使用 Subversion 了,但我认为这个简单的脚本可以解决问题:

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

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

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

我在 ~/tmp/m.sh 中保存了 Unix 版本,并在没有配置其他 merge 设置的情况下进行了尝试

[ui]
merge = ~/tmp/m.sh

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

% 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

好消息是预 merge 可以 merge 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 或至少将您的发现发布到邮件列表中。

关于 Mercurial 内部 :merge and binary file conflicts,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/992287/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com