- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我 pull 时,我遇到了冲突,但像往常一样,冲突在冲突文件中被标记为内联。
我想将“我的”和“他们的”作为两个/三个单独的文件(.MINE、.THEIRS),以便我可以使用针对此文件类型的特殊工具来执行 merge 。
这可以用 git 实现吗?
最佳答案
是的。当 merge 因冲突而停止时,索引包含所有三个输入文件(不仅仅是 ours
和 theirs
,还有来自 merge 基础提交的基本版本)。
您一直在查看的工作树文件并不是 Git 真正关心的东西。 Git 会尽最大努力将索引中的三个输入写入工作树(这是 Git 真正关心的事情),而作为监督 merge 的人员,您的工作将随之而来得到正确的 merge 结果并将其填回到索引中。如果你能用 Git 在工作树中留下的困惑来做到这一点,那就太好了。如果没有...:
索引通常只有每个文件的一个副本。该副本位于“零槽”中,最初,它与您 checkout 的提交相匹配。
该文件的工作树副本可供您使用,但 Git 并不真正使用它,除非您运行 git add <em>file</em>
。然后 Git 将文件的工作树副本复制到索引副本之上,以便索引副本再次与工作树副本匹配(并且可能不再与当前提交副本匹配)。
在 merge 期间,零槽副本最终出现在槽 2 ( --ours
) 中。来自 merge 基础的同一文件的副本进入插槽 1。来自另一个提交(您要 merge 的那个)的同一文件的副本进入插槽 3 ( --theirs
)。 Git 尝试 merge 所有三个副本,如果 Git 自己成功,Git 会将 merge 后的版本放入槽零(并将其复制到工作树)并清空 merge 槽。如果 Git 失败,它会占用 merge 槽,而槽 0 为空。
因此,如果 Git 留下的工作树困惑不够好,您可以提取所有三个索引副本。手动执行此操作的方法是使用 git checkout-index
,但通常更简单(如果相当笨拙)的方法是使用 git mergetool
.
The git mergetool
command本质上是一个运行 git checkout-index
的大型 shell 脚本在每个尚未 merge 的文件的所有三个副本上,然后在这三个副本上运行您选择的任何命令。该命令应将正确的 merge 文件写入第四个文件:
... the configured command line will be invoked with
$BASE
set to the name of a temporary file containing the common base for the merge, if available;$LOCAL
set to the name of a temporary file containing the contents of the file on the current branch;$REMOTE
set to the name of a temporary file containing the contents of the file to be merged, and$MERGED
set to the name of the file to which the merge tool should write the result of the merge resolution.
同样,所有这些临时文件都是由 git mergetool
创建的使用git checkout-index
从索引中提取它们。当您的工具完成后,脚本将使用 git add
关于$MERGED
文件删除槽 1-3 条目并写入槽 0 条目。
上面出现短语如果可用是因为在一些极端情况下,由于一个文件丢失而发生了 merge 冲突。例如,当 newfile.ext
没有 merge 基础版本时,就会发生添加/添加冲突。 ,但两者 --ours
和--theirs
确实有newfile.ext
并且两个文件不匹配。在这里,基地将会消失; $LOCAL
和$REMOTE
都会存在。当 file.ext
时发生修改/删除冲突存在于基本提交中,您( --ours
)或他们( --theirs
)更改了该文件,而你们/他们中的另一个删除了该文件。在这里,$BASE
将存在,但仅 $LOCAL
之一或$REMOTE
将会存在。
自 git mergetool
是 shell script ,您可以复制并修改它 - 您将需要一些相邻的文件;从这里探索,它们应该是显而易见的 - 如果您想以某种方式更改其操作,而标志和工具配置尚不支持。
关于Git merge : get conflicts as separate files for merge with external tool,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53652592/
这个问题在这里已经有了答案: Joining elements of a list in GNU Make (3 个回答) 2年前关闭。 我有这个: FOO = foo1 foo2 ... fooN
我们有两种产品在客户现场实现,其中一个需要另一个在场。我在与附加组件所需的数据库对象的主要产品相同的数据库中实现了一个单独的模式。因为该附加组件理论上也可以成为 future 产品的附加组件(尽管目前
它的作用:这是一个 Android 应用程序,将模仿我的团队正在创建的网站 apdata.info。这是第二页,它将显示符合他们请求的搜索的机场。 PHP ... $sql = "SELECT apn
我在 Angular 4 中使用 slider 。下面是我的 HTML 代码: Actual/Optimised
Linux RHEL5 机器 如何对以下输入进行排序以在 latest 变量中获取 1.0.0.1019?尝试了 -t、-k 和 -n 但没有帮助,或者可能是我遗漏了什么。 $ echo '1.0.0
因此,我有一个值为“app、beta、theta”的单元格,我想查看填充有上述单元格的列是否包含我的单元格值。例如:AA 列有这些单元格:“app”; “theta,应用程序”; “theta,app
我想读取一个包含多个(未终止的)Kafka 主机的字符串,并使用 cmd for 将它们列出在单独的行中。 字符串如下: host1:9092,host2:9092,host3:9092,... 我所
我突然想到,例如,假设我们有二维 N 点的训练数据。我们知道我们总是可以天真地构建一个决策树,以便我们可以对每个数据点进行分类。 (可能我们过拟合了,深度可以到2N) 但是,我们知道如果数据集是线性可
我知道这是一件奇怪的事情,但现在我正在构建一个测试项目,并且我将正在测试的应用程序的几个区域/容器分开在不同的类中,如保持组织的措施。因此,如果我想将一个元素从区域 A 拖动到区域 B,我必须将 D&
你好, 在编写 XSLT 样式表时,我遇到了一个无法解决的问题。我的基本 XML 结构如下 我想打印所有列的名称。因此,我使用了以下语句(我正在遍历所有 nonUniqueConstr
单一职责原则和关注点分离有什么区别? 最佳答案 Single Responsibility Principle (SRP)- give each class just one reason to ch
如何获取指定文件/文件夹路径的文件分隔符? 在Java中,我们可以这样写 File f = new File("C:\\MyFolder\\MyText.txt"); 请记住,这是一种文件表示(该文件
我正在开始开发一个新程序(用于学校项目),其中用户登录并有一个类似“时间线”的页面。目前它是一个简单的命令行 C 项目。 我想通过以下方式将数据存储在文本文件中: # Message here
我正在将 UIView(作为容器 View )添加到 UITableViewController。出于某种原因,UITableView 分隔符通过 UIView 可见。我运行的是 iOS 7。 UIV
产品代码在 UNIX 上运行,但需要在 Windows 上运行本地 DEV。 当前代码从数据库获取 UNIX 格式的路径,然后使用 file.separator 在该路径上构建,它添加了窗口分隔符,导
我正在使用 Eclipse 和本地服务器(如 XAMPP)在 Windows 中开发我的企业应用程序项目。 要从文件系统(部署文件夹外部)加载配置,我使用: String dataOrdner = S
我刚刚使用 iTextSharp 从 pdf 中获取所有文本,现在我需要将该文本拆分为单词。我以前使用 Acrobat 库,它会自动将它分成单词(使用 getPageNthWord())。 我不知道使
在WPF的集合控件中常常需要在每一个集合项之间插入一个分隔符样式,但是WPF的ItemsControl没有相关功能的直接实现,所以只能考虑曲线救国,经过研究,大概想到了以下两种实现方式。 先写出I
出现如下错误 Groovy script throws an exception of type class java.util.regex.PatternSyntaxException with m
请问有没有语法来分隔“for”标签中的某些元素? 例如我有一个用户列表,我想用“-”分隔符显示他们的用户名,所以预期的结果是:Mickael - Dave - Chris - ... 我找到了这个解决
我是一名优秀的程序员,十分优秀!