- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在一个删除了一些文件夹的分支上工作。与此同时,在 master 分支上,所有根文件夹都已重命名,因此所有文件(包括我已删除的文件)的路径都已重命名。
当我尝试 merge 时,所有已删除(在我的分支上)和重命名(在 master 上)的文件夹的所有文件都发生冲突。我列出了这些(1000+)个文件,这些文件在 git status 的未 merge 路径中显示如下:
added by them: FolderRenamed/File1.ext
added by them: FolderRenamed/File2.ext
git checkout --theirs FolderRenamed/File1.ext
最佳答案
TL;DR:您只需要 git add
他们。
更长
When I attempt to merge I get a conflict on all the files of all the folders that have been both deleted (on my branch) and renamed (on master) ...
git checkout branch
git merge master
HEAD
又名 branch
:这些通过哈希 ID 选择一个特定的提交,这也是您现在在索引和工作树中的提交),也称为本地或 --ours
,但我只是称它为 L(左/本地); master
),也称为远程、其他和 --theirs
,但我只是称之为 R(右/远程); master
并运行
git merge branch
,您只是在过程的这一部分交换 L 和 R。)
git diff
s 启用重命名检测:
git diff --find-renames B L > /tmp/b-vs-l.patch
git diff --find-renames B R > /tmp/b-vs-r.patch
--ours
留在索引中;和来自 R 的一个,Git 在索引中作为“阶段 3”或
--theirs
留在索引中.
somepath/file1.ext
.在重命名/删除冲突的情况下,基本文件有第 1 阶段条目,
--ours
有第 2 阶段或第 3 阶段条目。或
--theirs
文件。另一个阶段插槽(分别为 3 或 2)留空。
git status
命令将其显示为
added by us
(1 和 2 已占用,3 空)或
added by them
(1 和 3 已占用,2 为空)。
git checkout --ours
告诉 Git 将 stage-slot-2 版本复制到工作树。运行
git checkout --theirs
告诉 Git 将 stage-slot-3 版本复制到工作树。在任何一种情况下,stage-slot-1 条目都不会发生任何变化,而 stage-slot-0 条目保持为空。
git add
告诉 Git 将文件从工作树复制到阶段零插槽,完全清除剩余的插槽。该文件现已解决。
git add
重命名的文件。
git checkout commit-specifier -- path
, Git 提取给定的
path
来自给定的
commit-specifier
.当 Git 执行此操作时,它会将路径复制到索引的零槽中。这会清除该路径的任何插槽 1-3 条目,因此从特定提交 check out 文件的副作用是这会解析文件。
git checkout --ours
不同和
--theirs
因为那些是从现有索引条目中提取的,所以它们不会写入插槽零。
git checkout MERGE_HEAD -- paths
将重命名的文件提取为其重命名的名称,解决过程中的 merge 冲突。
关于git - 如何解决已在第一个分支中删除并在第二个分支中重命名的文件的 merge 冲突?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48793631/
我的工作是将每条记录写入 Hadoop 映射中的 DynamoDB。 我无法使用具有 httpclient-4.2.5.jar 和 httpcore-4.2.5.jar 的 Hadoop 2.6 运行
我在 JavaScript 中嵌套了循环开关,例如: for (var i = 0; i < checkBoxIds.length; i++) { if ($('#' + checkB
我有一个文件夹被重命名的分支。现在我正在尝试合并从主干到这个分支的更改,但是在主干中修改的文件仍然在原始文件夹名称下,因此 svn 引发了树冲突。我该如何解决这个问题? 该文件夹已使用 svn ren
我在使用 jquery 暴露插件和 Masked 输入插件时遇到了问题。问题是它们都占用 $.mask 函数,从而导致冲突。但我非常需要这两个插件一起工作。我会将其中一个中的 $.mask 重命名为.
我正在尝试为我所有的 INPUT 元素做一个简单的 :focus 效果,就像这样: INPUT:focus { border-color: orange; } 这很好用,直到我将这段 CSS 添加到样
我是 javascript 的新手。 在 wordpress 上工作,我在自定义 js 中为我的主题输入了以下函数: document.getElementsByName("empty_cart")[
为什么有些 javascript 会与其他的发生冲突?我的意思是我一直在为图片库使用 javascript 代码,然后尝试在 jquery 中获取文本水印。为什么在使用 jquery 之后,画廊完全消
是否可以根据已知的输入值创建 MD5 碰撞? 所以例如我有输入字符串 abc与 MD5 900150983cd24fb0d6963f7d28e17f72 . 现在我想将字节添加到字符串 def获得相同
我在我的项目中使用原型(prototype): NodeParser.prototype.getChildren = function(parentContainer) { return fl
根据我对 merge 冲突的理解,当两个人更改了同一文件和/或修改了该文件中的同一行时,就会发生 merge 冲突。所以当我做一个 git pull origin master 我期望 merge 冲
iPad 上 Mobile Safari 中的 HTML5 模板。带 iScroll 的 Div 工作正常。 if/else 语句中还包含一个 jQuery 函数。该函数测试用户是否在 iScroll
我一直在尝试使 2 个脚本(1 个 mootol 和 1 个 jquery)在同一页面上工作,但没有成功。我一直在研究许多论坛等,但我仍然无法使这两个脚本同时工作。 这就是它在我的标题中的样子: /w
我想克隆带标题的问号。一切正常,但是当我将鼠标悬停在新问号上时,第一个问号上会出现工具提示。有什么想法吗? 我正在使用 jQuery 和醉酒的工具提示。 Demo here click here
好吧,我已经在一个 friend 的网站上工作了一段时间了。我的编码技能......值得怀疑,而且我遇到了很多问题。 目前我网站上的 jQuery 停止工作了,我找不到原因,并且我已尽一切努力让它工作
我想使用一个文件来保存所有#define 和常量:示例 #ifndef CONSTANTS_H_ #define CONSTANTS_H_ #include //OVERALL DEFS
我在我的表单中的所有 HTML 下都有一些验证码,这似乎阻止了我的复选框验证码的工作,一旦我在我的 HTML 下的代码周围添加/* */(使其不活动),我就得出了这个结论) 复选框验证代码开始正常工作
我是新手。我的页面上有两个 javascript/jquery。如果我使用第一个脚本,第二个脚本将不起作用。如果我删除第一个脚本,第二个脚本就可以正常工作。我不知道如何解决这个问题。我知道有一个“无冲
我是 Bison 新手,在处理 Shift/Reduce 冲突时遇到了麻烦... 我正在为C语言编写语法规则:ID是标识变量的标记,我编写此规则是为了确保即使将标识符写在括号中,也可以考虑它。 id
我目前正在使用 LibGdx 开发我的第一个 Android 游戏项目。这是一款 2D 迷宫游戏,您可以使用触摸输入从其中一个入口到其中一个导出“画出”一条线。世界本身是一个 TiledMap,目前仅
我正在尝试通过 javascript 完成表单验证,并在 #form# 标记中放置一个要执行的 .py 文件操作。但问题是,当我提交数据后,它不会重定向到 .py 操作。所以我摆脱了 preventd
我是一名优秀的程序员,十分优秀!