- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我通常的功能/错误分支工作流程是这样的:
假设无法单击 PR 上的 merge 按钮,因为我的功能分支现在与 master 有冲突。在这一点上,我通常想解决与 master 的冲突,并且我想在我的功能分支上这样做,以便我可以让正在审查我的代码的人看到:
但是,我可能不想 rebase ,因为代码审查已经在进行中(有时我无论如何都会 rebase ,但其他时候我想避免它)。
我怎样才能可靠、高效地使用 git 来实现这一目标?
我目前所做的是这些事情的混合:
git merge master
;(查看哪个文件有冲突,然后 git annotate 以找到相关提交);git reset --hard origin/my-feature-branch
; git cherry-pick <some commit>
(或者可能手动进行一些更改);(重复))有时这不起作用,因为冲突是空的,所以我不知道要注释什么才能找到正确的提交。 编辑:事实上,在空冲突的情况下,我想它是没有 merge 或 rebase 就不可能解决(但在其他情况下是可能的——见下面的例子)。
当它确实起作用时,似乎 git 可以帮助我以更自动化的方式完成大量工作。
我试过了 git-imerge
另外——这似乎并不是专门为此目的而设计的,它也以未处理的异常退出。
这是一个具体的工作示例,因为这里的答案存在怀疑,有时可以像我在这里描述的那样解决分支上的冲突而无需 merge 或 rebase (请注意,这并没有显示上面工作流程的每个步骤,并仅演示“在没有 merge 或 rebase 的情况下解决分支上的冲突”部分):
$ mkdir -p conflict-example/upstream
$ cd conflict-example/upstream
$ git init .
Initialised empty Git repository in /tmp/conflict-example/upstream/.git/
$ echo 'changed_only_upstream before' > changed_only_upstream
$ echo 'changed_only_downstream before' > changed_only_downstream
$ echo 'changed_in_both before' > changed_in_both
$ git add .
$ git commit -m 'initial'
[master (root-commit) 23040ea] initial
3 files changed, 3 insertions(+)
create mode 100644 changed_in_both
create mode 100644 changed_only_downstream
create mode 100644 changed_only_upstream
$ cd ..
$ git clone upstream downstream
Cloning into 'downstream'...
done.
$ cd downstream
$ git checkout -b downstream
Switched to a new branch 'downstream'
$ vim changed_in_both
$ vim changed_only_downstream
$ cat changed_in_both
changed_in_both before
downstream
$ cat changed_only_downstream
changed_only_downstream before
downstream
$ git commit -am 'downstream'
[downstream 6ead47f] downstream
2 files changed, 2 insertions(+)
$ cd ../upstream
$ vim changed_in_both
$ vim changed_only_upstream
$ cat changed_in_both
changed_in_both before
upstream
$ cat changed_only_upstream
changed_only_upstream before
upstream
$ git commit -m 'upstream conflict' changed_in_both
[master e9ec7c5] upstream conflict
1 file changed, 1 insertion(+)
$ git commit -m 'upstream non-conflict' changed_only_upstream
[master d4057e0] upstream non-conflict
1 file changed, 1 insertion(+)
$ cd ../downstream/
$ git checkout master
Switched to branch 'master'
Your branch is up-to-date with 'origin/master'.
$ git pull
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 6 (delta 2), reused 0 (delta 0)
Unpacking objects: 100% (6/6), done.
From /tmp/conflict-example/upstream
23040ea..d4057e0 master -> origin/master
Updating 23040ea..d4057e0
Fast-forward
changed_in_both | 1 +
changed_only_upstream | 1 +
2 files changed, 2 insertions(+)
$ git checkout downstream
Switched to branch 'downstream'
$ git merge master
Auto-merging changed_in_both
CONFLICT (content): Merge conflict in changed_in_both
Recorded preimage for 'changed_in_both'
Automatic merge failed; fix conflicts and then commit the result.
$ git merge --abort
$ git log --all --graph --pretty=oneline --abbrev-commit --decorate
* d4057e0 (origin/master, origin/HEAD, master) upstream non-conflict
* e9ec7c5 upstream conflict
| * 6ead47f (HEAD -> downstream) downstream
|/
* 23040ea initial
$ git cherry-pick e9ec7c5
error: could not apply e9ec7c5... upstream conflict
hint: after resolving the conflicts, mark the corrected paths
hint: with 'git add <paths>' or 'git rm <paths>'
hint: and commit the result with 'git commit'
$ vim changed_in_both
$ cat changed_in_both
changed_in_both before
upstream
$ git add changed_in_both
$ git commit
Recorded resolution for 'changed_in_both'.
[downstream 7a4f7a7] upstream conflict
Date: Sat Aug 27 14:41:13 2016 +0100
1 file changed, 1 insertion(+), 1 deletion(-)
$ git log --all --graph --pretty=oneline --abbrev-commit --decorate
* 7a4f7a7 (HEAD -> downstream) upstream conflict
* 6ead47f downstream
| * d4057e0 (origin/master, origin/HEAD, master) upstream non-conflict
| * e9ec7c5 upstream conflict
|/
* 23040ea initial
$ git checkout master
Switched to branch 'master'
Your branch is up-to-date with 'origin/master'.
$ git merge downstream
Merge made by the 'recursive' strategy.
changed_only_downstream | 1 +
1 file changed, 1 insertion(+)
$ git log --all --graph --pretty=oneline --abbrev-commit --decorate
* c036d60 (HEAD -> master) Merge branch 'downstream'
|\
| * 7a4f7a7 (downstream) upstream conflict
| * 6ead47f downstream
* | d4057e0 (origin/master, origin/HEAD) upstream non-conflict
* | e9ec7c5 upstream conflict
|/
* 23040ea initial
我相信如果我在 cherry-pick 中选择了不同的分辨率,我将无法使用该 merge 命令进行 merge (这至少类似于 github merge 按钮所做的)。在那些情况下,通常我要么自己进行 merge ,要么进行 rebase ——但这不是这个问题的目的(尽管如果有某种方法可以实现 merge 按钮的可点击性,而无需在这些情况下 merge master 或 rebase ,那会很有趣听说!)。
最佳答案
这是一个bash完成这项工作的脚本:
#!/bin/bash
declare -a conflicts
echo "Detecting conflicts..."
for rev in `git rev-list HEAD..master`
do
git cherry-pick --no-commit $rev > /dev/null 2>&1
if [ $? -eq 1 ]
then
conflicts+=($rev)
fi
git reset --hard HEAD > /dev/null
done
for rev in ${conflicts[*]}
do
git cherry-pick --no-commit $rev > /dev/null 2>&1
echo "Commit $rev cherry-picked."
read -p "Resolve conflicts, then press any key to continue: "
done
echo "Done cherry-picking! Commit your changes now!"
运行此脚本,每次出现提示时,解决文本编辑器中的任何冲突,然后从另一个窗口执行 git add
。完成后,您可以 git commit
(根据提示)。
到目前为止,在我的测试中,我发现这个脚本有两个问题:
当我将功能分支 merge 回 master
时,我遇到了一些小冲突。如果从 master
merge 到功能分支,这些冲突要小得多。事实上,您可以这样做:
git checkout master
git merge --no-ff feature/my-feature -x theirs
它应该可以工作。但是,这可能意味着 GitHub Merge 按钮不起作用,而且我认为没有办法告诉 GitHub 使用 -x theirs
。
我不确定这是否仅取决于所做的相对更改,所以这可能只是由我的特定测试 repo 引起的问题。
如果您有依赖于 aaa
的提交 bbb
,都在 master
上,然后是 bbb 的
将被检测为冲突。我的测试表明,无论您是在 cherry-pick
cherry-pick
中保留这样的更改还是丢弃它都没有关系。 (它似乎也不会影响问题 #1。)
我正在寻找这两个问题的解决方案,但这应该足以让您入门。
关于git - 如何在不 merge 或 rebase 的情况下解决分支上的 git 冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39151523/
我的工作是将每条记录写入 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
我是一名优秀的程序员,十分优秀!