- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
merge 两个分支时,很多时候 merge 失败,我必须单独解决差异。
一些文件 merge 成功,我可以看到差异:
git diff --staged <merged-file>
问题是对于未 merge 的路径,当我尝试检查引入的差异时,我什么也看不到:
git diff <unmerged-file>
但是当我尝试将它与远程 master 分支进行比较时,就会出现差异:
git diff origin/master <unmerged-file>
为什么会这样? merge 操作是在更新我的本地 HEAD 还是什么?
此外,当我使用 git add
标记解决方案时,它们永远不会进入暂存区 - 这就是 git diff
没有显示任何内容的原因吗?
最佳答案
在 merge 过程中,冲突文件处于特殊状态。存在多个具有相同文件名和不同 blob id 的条目。这些通常是三个 blob(用于三向 merge )或两个 blob(用于简单 merge )。
尝试 merge ..
$ git merge origin/otherbranch
Merge remote-tracking branch 'origin/otherbranch' into mybranch
Conflicts:
somefile.txt
查看需要 merge 的文件
$ git diff --name-status --diff-filter=U
U somefile.txt
或
$ git update-index --refresh
somefile.txt: needs merge
查看与正在 merge 的文件相关的 blob;
$ git ls-files -s somefile.txt
100644 9a0579524e0c7ba9fc9ae18badadaddcad2d598f **1** somefile.txt
100644 1bcff16b6de5ed304a06e643070e40787db1ead8 **2** somefile.txt
100644 6e52271b22f6a6d1150619433551e0fa9094b108 **3** somefile.txt
根据 git-merge 手册页。 1 = 共同祖先,2 = HEAD(我们的)和 3 = MERGE_HEAD(他们的)
显示差异
$ git diff 9a0579524e0c7ba9fc9ae18badadaddcad2d598f 6e52271b22f6a6d1150619433551e0fa9094b108
< some differences >
检索共同祖先..
$ git 猫文件 blob 9a0579524e0c7ba9fc9ae18badadaddcad2d598f
从 HEAD check out 版本
$ git checkout --ours somefile.txt
从 MERGE_HEAD checkout 版本
$ git checkout --theirs somefile.txt
重置为“merge ”已更改
$ git checkout -m somefile.txt
这通过使用 <ref>:ID:Filepath
有所简化。例如
git diff :1:somefile.txt :2:somefile.txt
将在 merge 中给出两个父项之间的差异。0代表完成 merge 1 表示冲突 merge 2/3 代表 merge 的两个父级。
如果您在特定提交时完成了 merge xxxxxx
, 你可以使用 xxxxxx^0
来引用它的父级( merge 文件)xxxxxx^1
“左” parent ,和xxxxxx^2
“正确”的 parent 。可以按如下方式将 merge 后的文件与其祖先文件进行比较;
git diff xxxxxx^0:somefile xxxxxx^1:somefile
关于git - 为什么 git diff 不显示未 merge 路径的任何内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22215651/
我在我们的系统中使用了多种不同的查询,我们想要获取分页的“总”记录。 我所遵循的所有地方都遵循这种结构 - var query1 = "select SQL_CALC_FOUND_ROWS ...."
我是 diff 的新手。我过去用过它。但我想知道,是否可以使用 diff 来跟踪希伯来语中两个文件之间的差异?我想比较具有元音点和重音符号的圣经希伯来文文件。 最佳答案 我不知道有任何“差异”(文件比
在Word中,有一个选项可以比较两个文档并找出两个文档之间的差异。我正在寻找一个类似的功能来比较两个Powerpoint文档。理想情况下,它将列出不同的单个幻灯片,每个幻灯片之间版本之间的差异以及进行
Bizzaro-Diff!!! 有没有办法做一个只显示一组文件中相同部分的 bizzaro/inverse-diff? (即远超过 three files ) 奇怪的问题,我知道...但我正在将某人的
我将 git 与默认的 Ubuntu 12.04 软件包一起使用: git --version git version 1.7.9.5 我找不到任何可以让 git diff 打开外部差异工具的机制,它
这是我的树 ├── test │ ├── dir1 │ └── dir2 │ ├── file │ └── file2 └── test2 └── dir2
我在 source forge ( cocoa.diff ) 上找到了这个补丁,这意味着我可以使用 cocoa.diff 文件进行补丁。但是,我似乎无法弄清楚如何使用 .diff 文件。 谢谢你的帮助
我修改了某个文件的第 494 行,并使用 cvs diff -u4 来查看我修改的内容,cvs 输出如下内容: @@ -490,9 +490,9 @@ if (!(hPtr->hSta
我需要知道这两个补丁是否有效相同。 我有一个旧补丁文件和使用 unix diff 命令创建的新补丁文件。由于补丁创建时的时间戳,只是比较补丁会报告差异。 有没有办法(有差异?)可以可靠地告诉我这两个补
我有这样的东西 src/sim/simulate.cc 41d40 public: > 61,62c60,61 a.patch 用于创建补丁文件,尽管也可能会抛出一些其他开关(-N?)
我想知道是否有工具可以显示与 debian 打包相关的补丁中使用的 *.diff 文件。我需要从该工具中获得的是它可以只读取 diff 文件并显示随更改的行更改的实际文件,就像 kdiff 或 mel
主要有3个git diff版本: git diff - difference between WORKING DIRECTORY & STAGE git diff --staged - differe
根据 Ender 的 Applied Econometric Time Series ,变量 y 的二阶差分定义为: Pandas 提供了 diff 函数,它接收“periods”作为参数。尽管如此,
这是我的差异的开始部分。 #!/usr/bin/env python import fileinput import difflib import subprocess import sys # fo
有没有办法在 svn diff 或任何其他工具(基于 linux)到 仅显示空格/制表符更改 ?. 目的,我不希望 checkin 这些差异。如果工具可以捕获这些差异,我可以在 checkin 之前将
我正在尝试比较忽略回车符的文件 - diff -b 在任何其他 unix 上的表现令人钦佩。但是在这个 AIX 5.3 机器上: tst1:tst2$ od -c testfile 00000
这个问题已经有答案了: What does the “@@…@@” meta line with at signs in svn diff or git diff mean? (3 个回答) 已关闭
我在使用 git diff --word-diff 时遇到了问题。问题是当 diff 获取没有换行符的文件(单行文件)时,它会逐行区分。我想逐字区分。 以下是当我在没有换行符的情况下比较文件时发生的情
这个问题在这里已经有了答案: Highlight changed lines and changed bytes in each changed line (12 个答案) 关闭 7 年前。 给定一
我正在尝试使用两个大文件夹(〜7GB)创建一个补丁。 这是我的做法: $ diff -Naurbw . ../other-folder > file.patch 但可能由于文件大小而导致未创建补丁并给
我是一名优秀的程序员,十分优秀!