- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在开发一个 git 仓库。在发布我的更改之前,我想删除一些提交 - a023b43
、315424b
和 7b51754
- 因为它们没有反射(reflect)任何有意义的更改。唯一重要的时间点是第一次 (70f72ca
) 和最后一次 (6937ddd
) 提交。
git rebase -i 4c802c1
我选择了:
pick 70f72ca Remove repetitions from Makefile
d a023b43 Separate target for image conversion
d 315424b Remove image conversion (#1)
d 7b51754 Fix Makefile
pick 6937ddd CV 2019.01
最终目标是拥有一个如下所示的 git 日志:
6937ddd CV 2019.01
4c802c1 Initial commit
Auto-merging src/Adam_Matan.tex
CONFLICT (content): Merge conflict in src/Adam_Matan.tex
error: could not apply 6937ddd... CV 2019.01
Resolve all conflicts manually, mark them as resolved with
"git add/rm <conflicted_files>", then run "git rebase --continue".
You can instead skip this commit: run "git rebase --skip".
To abort and get back to the state before "git rebase", run "git rebase --abort".
Could not apply 6937ddd... CV 2019.01
据我了解,这两个提交只是我工作目录的快照。我想要两个快照 - 原始提交和 CV 2019.01
一个。我不想以任何方式 merge 或组合它们。为什么我会收到 merge 冲突消息?
如何从分支中删除所有中间提交,只留下第一个和最后一个提交?
压缩也会产生 merge 冲突:
git rebase -i 4c802c1
Auto-merging Makefile
CONFLICT (content): Merge conflict in Makefile
error: could not apply 315424b... Remove image conversion (#1)
最佳答案
Rebase 通过进行一系列提交并重新应用它们来发挥作用,也许是在不同的“基础”对象上。它通过为每个提交创建一个补丁并重新应用它们,或者通过按顺序挑选它们来实现。
无论机制如何,通过从 rebase 指令列表中删除一个提交,您已经要求包含那些不的更改。
想象一下,如果您有一些文件,并且在其初始版本中,它只有一行内容为 one
.想象一下,在下一次提交中,您更改了 one
至 two
.在随后的提交中,two
至 three
.那么three
至 four
,最后 four
至 five
.所以你现在有五次提交,每次都改变这一行。
想象一下,在每次提交中,您都会向它发送一条消息,指示内容发生了变化,并且提交 ID(哈希)也神奇地反射(reflect)了内容。正在运行 rebase -i --root
会给你这个脚本:
pick 1111111 add one
pick 2222222 change one to two
pick 3333333 change two to three
pick 4444444 change three to four
pick 5555555 change four to five
换句话说,第一次提交选择了从无到one
的变化。 .第二个将从 one
中挑选更改至 two
等,直到最后一条指令从 four
中挑选出更改至 five
.
如果您删除其中一些行,则:
pick 1111111 add one
pick 5555555 change four to five
您将有两个精选。第一个将添加一个内容为 one
的文件.第二个将尝试更改 four
中的那些内容至 five
.
唉,那些内容不是 four
.因此,您有冲突。
如果你的目标是从one
至 five
没有中间提交,那么你想要 squash
它们或将它们标记为 fixup
提交。
pick 1111111 add one
pick 2222222 change one to two
squash 3333333 change two to three
squash 4444444 change three to four
squash 5555555 change four to five
在这种情况下,第一个更改将被挑选出来,因此文件 one
将被创建。随后的更改将被挑选出来,因此内容将从 one
更改为至 two
.随后的更改将被精心挑选,进一步更新文件,但这些更改将被“压缩”到先前的提交中。因此,您将获得全部内容,但最终只会提交两次。
(如果您将它们标记为 fixup
提交,您将获得相同的内容,但它们的提交消息不会包含在您建议的提交消息中。
关于git - 为什么从 git rebase 中删除的提交会导致 merge 冲突?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54461479/
尝试使用集成到 QTCreator 的表单编辑器,但即使我将插件放入 QtCreator.app/Contents/MacOS/designer 也不会显示。不过,相同的 dylib 文件确实适用于独
在此代码示例中。 “this.method2();”之后会读到什么?在返回returnedValue之前会跳转到method2()吗? public int method1(int returnedV
我的项目有通过gradle配置的依赖项。我想添加以下依赖项: compile group: 'org.restlet.jse', name: 'org.restlet.ext.apispark', v
我将把我们基于 Windows 的客户管理软件移植到基于 Web 的软件。我发现 polymer 可能是一种选择。 但是,对于我们的使用,我们找不到 polymer 组件具有表格 View 、下拉菜单
我的项目文件夹 Project 中有一个文件夹,比如 ED 文件夹,当我在 Eclipse 中指定在哪里查找我写入的文件时 File file = new File("ED/text.txt"); e
这是奇怪的事情,这个有效: $('#box').css({"backgroundPosition": "0px 250px"}); 但这不起作用,它只是不改变位置: $('#box').animate
这个问题在这里已经有了答案: Why does OR 0 round numbers in Javascript? (3 个答案) 关闭 5 年前。 Mozilla JavaScript Guide
这个问题在这里已经有了答案: Is the function strcmpi in the C standard libary of ISO? (3 个答案) 关闭 8 年前。 我有一个问题,为什么
我目前使用的是共享主机方案,我不确定它使用的是哪个版本的 MySQL,但它似乎不支持 DATETIMEOFFSET 类型。 是否存在支持 DATETIMEOFFSET 的 MySQL 版本?或者有计划
研究 Seam 3,我发现 Seam Solder 允许将 @Named 注释应用于包 - 在这种情况下,该包中的所有 bean 都将自动命名,就好像它们符合条件一样@Named 他们自己。我没有看到
我知道 .append 偶尔会增加数组的容量并形成数组的新副本,但 .removeLast 会逆转这种情况并减少容量通过复制到一个新的更小的数组来改变数组? 最佳答案 否(或者至少如果是,则它是一个错
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
noexcept 函数说明符是否旨在 boost 性能,因为生成的对象中可能没有记录异常的代码,因此应尽可能将其添加到函数声明和定义中?我首先想到了可调用对象的包装器,其中 noexcept 可能会产
我正在使用 Angularjs 1.3.7,刚刚发现 Promise.all 在成功响应后不会更新 angularjs View ,而 $q.all 会。由于 Promises 包含在 native
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我正在编写一个玩具(物理)矢量库,并且遇到了 GHC 坚持认为函数应该具有 Integer 的问题。是他们的类型。我希望向量乘以向量以及标量(仅使用 * ),虽然这可以通过仅使用 Vector 来实现
PHP 的 mail() 函数发送邮件正常,但 Swiftmailer 的 Swift_MailTransport 不起作用! 这有效: mail('user@example.com', 'test
我尝试通过 php 脚本转储我的数据,但没有命令行。所以我用 this script 创建了我的 .sql 文件然后我尝试使用我的脚本: $link = mysql_connect($host, $u
使用 python 2.6.4 中的 sqlite3 标准库,以下查询在 sqlite3 命令行上运行良好: select segmentid, node_t, start, number,title
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我是一名优秀的程序员,十分优秀!