ChatGPT解决这个技术问题 Extra ChatGPT

如何以交互方式(视觉)解决 SourceTree / git 中的冲突

我正在为我的 git 项目使用(Windows)SourceTree。我可以在命令提示符或 Linux 终端中执行此操作。

但是,我想知道是否有一种以交互方式和视觉方式解决冲突的好方法。例如,如果 pull 检测到冲突,则弹出基于 GUI 的冲突工具(例如,P4Merge)。可能吗?

我总是在手动解决冲突,这很痛苦。

例如,这是来自 SourceTree 的 git pull 消息。

git -c diff.mnemonicprefix=false -c core.quotepath=false pull --no-commit origin master
From W:\repo\
 * branch            master     -> FETCH_HEAD   

Updating 33c07bf..41e0249

error: Your local changes to the following files would be overwritten by merge:
    foo.cpp
    goo.cpp
    goo.hpp
Please, commit your changes or stash them before you can merge.
Aborting    

Completed with errors, see above.

g
gtrig

在 SourceTree 中,单击工具->选项。然后在“常规”选项卡上,确保选中该框以允许 SourceTree 修改您的 Git 配置文件。

然后切换到“差异”选项卡。在下半部分,使用下拉菜单选择要用于进行差异和合并的外部程序。我已经安装了 KDiff3 并且非常喜欢它。完成后,单击确定。

现在,当有合并时,您可以进入 Actions->Resolve Conflicts->Launch External Merge Tool。


我试过这个,但最后,我没有看到无法比拟的推出。我看到正在生成比较文件,但仅此而已。我无法解决冲突。将此更改为标准/默认比较似乎也无济于事。
@echiban您可能拥有Beyond Compare的标准许可证,它不接受3路合并。你需要去 pro 才能将它用作 git mergetool
按照所有步骤配置“启动外部合并工具”对我来说仍然是灰色的,无法激活它
我也没有选择合并冲突文件,一旦我这样做了它就很好
我必须在提交列表中单击“未提交的更改”项,然后它才会变为灰色。
C
Community

我将 SourceTree 与 TortoiseMerge/Diff 一起使用,这是一个非常简单方便的 diff/merge 工具。

如果您也想使用它,那么:

获取 TortoiseMerge/Diff 的独立版本(相当旧,因为自 TortosieSVN 的 1.6.7 版以来,即自 2011 年 7 月以来,它不再独立发布)。此答案中的链接和详细信息。将 TortoiseIDiff.exe 和 TortoiseMerge.exe 解压缩到任何文件夹(在我的情况下为 c:\Program Files (x86)\Atlassian\SourceTree\extras\)。在 SourceTree 打开工具 > 选项 > 差异 > 外部差异/合并。在两个下拉列表中选择 TortoiseMerge。点击 OK 并将 SourceTree 指向 TortoiseIDiff.exe 和 TortoiseMerge.exe 的位置。

之后,您可以从本地存储库中每个冲突文件的上下文菜单中选择 Resolve Conflicts > Launch External Merge Tool。这将打开 TortoiseMerge,您可以在其中轻松处理所有冲突。完成后,只需关闭 TortoiseMerge(您甚至不需要保存更改,这可能会自动完成),几秒钟后 SourceTree 应该会优雅地处理它。

唯一的问题是,它会自动创建备份副本,即使是 proper option is unchecked


o
ozkary

当 Resolve Conflicts->Content Menu 被禁用时,一个可能在 Pending files 列表中。我们需要从下拉列表中选择冲突文件选项(顶部)

希望能帮助到你