- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我尝试将source branch
合并到target branch
时,git识别出两个文件冲突。但是,这两个文件都对应source branch
和target branch
中的不同文件路径(文件已移动和修改)。我需要在source branch
中获取此冲突文件的路径。
请注意,我可以使用git diff --name-only --diff-filter=U
列出合并冲突下的文件,但这会列出目标分支中的路径(因为我检出target branch
并将source branch
拖入其中)。
是否有命令列出源分支中冲突文件的路径?
最佳答案
当我尝试将“源分支”合并到“目标分支”时,git识别出两个文件冲突。但是,这两个文件都对应于“源分支”和“目标分支”中的不同文件路径(文件已移动和修改)。
为了更具体地说明这一点,我相信您做到了:
git checkout tgtbranch
git merge srcbranch
CONFLICT (rename/delete): orig-filename deleted in HEAD and renamed
to new-filename in A. Version A of new-filename left in tree.
Automatic merge failed; fix conflicts and then commit the result.
A
和
B
的分支代替了分别为
srcbranch
和
tgtbranch
的分支来重现此冲突。此外,
CONFLICT
消息全部在一行上。我将其分为两部分,仅用于发布目的)
CONFLICT
打印的
git merge
消息中可用。
CONFLICT
消息。 (如果您没有保存
CONFLICT
消息,请参见下面的两个其他选择。)
git status
打印的内容:
$ git status --short
UA new-filename
$ git status
On branch B
You have unmerged paths.
(fix conflicts and run "git commit")
(use "git merge --abort" to abort the merge)
Unmerged paths:
(use "git add <file>..." to mark resolution)
added by them: new-filename
no changes added to commit (use "git add" and/or "git commit -a")
git ls-files --stage
来查看Git索引中的内容:
$ git ls-files --stage
100644 4466f6b253fc4b67ec2749befdd29b7c1f573e36 0 README
100644 923932af0c5b6ddc43c116c648cd793759949b66 3 new-filename
CONFLICT
行,该怎么办
git worktree add
,前提是您拥有
git worktree
git checkout
检出
tgtbranch
指向原始克隆(如果您是重新克隆的)或当前克隆(如果您使用的是
git worktree
)的提交,然后运行
git merge
将提交合并到
tgtbranch
指向原始克隆(如果重新克隆)或当前克隆(如果使用
git worktree
)。那是:
$ git rev-parse tgtbranch
<hash>
$ git rev-parse srcbranch
<hash>
$ cd /tmp && git clone <path> reclone && cd reclone
$ git checkout <hash> && git merge <hash>
$ git worktree add --detach <path> tgtbranch
$ cd <path> && git merge srcbranch
git worktree
方法。
CONFLICT
行。保存!然后删除新的克隆或添加的工作树,其全部目的是获得
CONFLICT
行。现在,您的问题已解决:您拥有原始文件名。
git diff
tgtbranch
在
git diff --find-renames
中检测到重命名。查找重命名的阈值设置为您随
-X find-renames=number
参数提供的阈值,如果未指定数字,则设置为50%。
git diff
是两个特定提交之间的区别:Git自动找到的合并基础提交和
tgtbranch
或
srcbranch
的尖端提交(无论哪个分支Git“看到”了重命名:一个尖端提交都有一个重命名,与合并基础相比,另一个删除了)。
git merge-base --all srcbranch tgtbranch
$ git merge-base --all A B
3a5c9ae0669e9969f8986810ea03c5283e0ac693
git diff --find-renames
命令。添加
--name-status
选项以限制输出量。您可能还想添加
--diff-filter=RD
以仅显示重命名或删除的文件。就我而言,我忽略了这些选项,因为重命名或删除是我所做的全部事情:
$ git diff --find-renames --name-status A...B
D orig-filename
$ git diff --find-renames --name-status B...A
R064 orig-filename new-filename
orig-filename
,新名称为
new-filename
。
A...B
(或者在您的情况下为
tgtname...srcname
和
srcname...tgtname
)具有
git diff
专有的一种特殊含义。在
git diff
中(但在其他Git命令中则不是1),这意味着找到两个指定提交之间的合并基础,并将其用作diff的左侧。使用右侧的提交说明符作为diff的右侧。由于只有一个合并基础,因此这会使合并基础与右侧参数命名的提交有所不同。
git diff-tree
以及面向用户的
git diff
。
REUC
记录:
$ od -c .git/index
0000000 D I R C \0 \0 \0 002 \0 \0 \0 002 ] 264 256 x
0000020 2 270 ) P ] 264 256 x 2 227 221 220 \0 \0 \0 ~
0000040 \0 320 ! a \0 \0 201 244 \0 \0 003 351 \0 \0 003 351
0000060 \0 \0 \0 W D f 366 262 S 374 K g 354 ' I 276
0000100 375 қ ** | 037 W > 6 \0 006 R E A D M E
0000120 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0
0000140 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 201 244
0000160 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 222 9 2 257
0000200 \f [ m 334 C 301 026 306 H 315 y 7 Y 224 233 f
0000220 0 \f n e w - f i l e n a m e \0 \0
0000240 \0 \0 \0 \0 T R E E \0 \0 \0 006 \0 - 1
0000260 0 \n R E U C \0 \0 \0 - o r i g - f
0000300 i l e n a m e \0 1 0 0 6 4 4 \0 0
0000320 \0 0 \0 214 354 + 214 330 360 004 N O 355 \b 243 '
0000340 4 331 225 \n W [ 037 026 216 K } 367 ? 373 354 364
0000360 [ ^ 364 b 001 371 6 , 3 370 320
0000373
DIRC
幻数开头,然后为我的两个文件都具有普通索引条目(如
git ls-files --stage
输出所示,我只有两个)。但是它有一个
TREE
记录,我们可以在偏移量
0000240
附近看到它,然后在下一行显示
REUC
记录。该REUC记录是“撤消”记录,它允许
git checkout -m
重现合并冲突。而且,正如我们所看到的,撤消记录实际上存储了原始文件名。
git ls-files
或更方便地通过
git status
访问此信息。 las,事实并非如此。
关于git - 在源分支中列出冲突文件路径的命令是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58572646/
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我有一系列 SQL 命令,我想在大约 40 个不同的表上运行。必须有一种方法可以在不编写 40 条不同命令的情况下执行此操作... 我在 SQL Server 中运行它。所有表都有不同的名称,我要操作
我习惯在 PHP 中使用命令“mysql_insert_id()”来返回插入到我的数据库中的最后一行的 id。 在 C# 中的 SQLite 中是否有等效的命令? 谢谢! -阿德娜 最佳答案 选择 l
试图找出一种方法来回填 ds 分区 Hive 表的分区。 我知道如何从 CLI 运行 Hive 命令,例如 $HIVE_HOME/bin/hive -e 'select a.col from tab1
我有 .bat 文件。看起来像下一个 ....many commands1 ftp -i -s:copy.txt ...many commands2 copy.txt 包含下一个命令 open ...
基本上我想输入 show 并检查是否有 show 命令或别名已定义并触发它,如果未定义则触发 git show 。 例如 rm 应该执行 rm 但 checkout 应该执行 git checkout
我公司的主数据库是 iSeries 机器,我已经非常习惯使用 DB2 命令和结构。我现在正在尝试做一个小项目,更新一个包含超过 300 万条记录的表。我想出一种比较和“清理”数据的更快方法是使用 My
我想在带有 Node 的终端中制作一个简单的按钮板,并“blessed”用于连接或运行不同的命令。 ----------------------------------------------- _
我们有一个 selenium IDE 脚本,正在转换为 python webdriver。以下命令未转换: [openWindow | http://mywebsite.com/index.php |
我正在学习这个关于从 GIT HUB 下载和安装 Web 文件的在线教程。我进入主题:启动我们的静态网站,系统提示我输入命令以下载和安装 Web 文件。但是,当我输入命令 yarn install 时
我在 shell 脚本中使用 elif 命令时遇到问题,就像在 fortran 中一样。 我有 100 家公司的员工名单。我想屏蔽那些员工少于 500 人的公司。我的脚本是 rm -f categor
我有一些 Linux 命令可以生成 token 。我在 Linux 机器上使用操作系统库形式的 Python 自动化了这些命令。它工作正常。 但是,当我在 Windows 中尝试相同的代码时,它没有返
本文分享自华为云社区《Git你有可能不知道交互式暂存》,作者:龙哥手记。 本节中的几个交互式 Git 命令可以帮助你将文件的特定部分组合成提交。 当你在修改了大量文件后,希望这些改动能拆分为若干提交而
我想知道如何使用 IN 比较语法来做到这一点。 当前的 SQL 查询是: select * from employee where (employeeName = 'AJAY' and month(e
我在这个位置安装了 Hadoop /usr/local/hadoop$ 现在我想列出 dfs 中的文件。我使用的命令是: hduser@ubuntu:/usr/local/hadoop$ bin/ha
是否有一个单一的 docker 命令可用于清除所有内容?如果正在运行,请停止所有容器、删除所有图像、删除所有卷...等。 最佳答案 我认为没有一个命令可以做到这一点。您首先需要停止所有容器使用 $ d
我基本上是在 clojure/nrepl 模式中寻找与 C-u C-x C-e 或 C-c C-p 等效的 Scheme。 我想要一个 C-x C-e 将输出打印到缓冲区,而不是仅仅在 repl 中。
我可以在 vim 中使用 pudb(一个 ncurses Python 调试器),因为,例如,:!python %在实际的终端窗口中运行。我更喜欢使用 gvim,但 gvim 运行 :!python
我正在尝试编写一个 FFMPEG 命令: 取为 输入 一个视频 input.mp4 和一个图像 pic.jpg 作为 输出 将 input.mp4 拆分为 20 秒的视频,按顺序重命名;对于每个分割视
我想转储视频每帧的比特率。我正在尝试使用 -vstats 获取此信息命令。当我运行此命令时 - ffmpeg -i input.mp4 -vstats 它显示至少应该定义一个文件。 如果有人能建议我任
我是一名优秀的程序员,十分优秀!