- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在使用 git rebase
的 --keep-empty
选项时遇到了一些问题,我不确定我是否误解了此选项的作用,或者存在错误。
这是一个最小的例子:
创建一个新的 Git 存储库和一个初始的、不相关的提交。
$ git init
$ echo something >base.txt
$ git add base.txt
$ git commit -m 'some base commit to not run into the root corner case'
创建一个添加两个新文件的新提交。
$ echo A >a.txt; echo B >b.txt
$ git add a.txt b.txt
$ git commit -m 'add A and B'
修改其中一个文件。
$ echo A1 >a.txt
$ git add a.txt
$ git commit -m 'change A'
修改其他文件。
$ echo B1 >b.txt
$ git add b.txt
$ git commit -m 'change B'
$ git checkout -b rebased master
$ git rebase --keep-empty -i :/base
…选择编辑
添加了A
和B
的提交,并更改它以便只有B
添加(在实际场景中,原因可能是 A
是 secret 的):
$ git rm a.txt
$ git commit --amend
$ git rebase --continue
自然地,修改 A
的下一个提交现在会产生冲突:
error: could not apply 182aaa1... change A
When you have resolved this problem, run "git rebase --continue".
If you prefer to skip this patch, run "git rebase --skip" instead.
To check out the original branch and stop rebasing, run "git rebase --abort".
Could not apply 182aaa1701ad100fc02a5d5500cacebdd317a24b... change A
...选择不添加 a.txt
的修改版本:
$ git mergetool
Merging:
a.txt
Deleted merge conflict for 'a.txt':
{local}: deleted
{remote}: modified file
Use (m)odified or (d)eleted file, or (a)bort? d
A
被修改的提交现在是空的:
$ git diff --cached
# nothing
...并完成 rebase :
$ git rebase --continue
Successfully rebased and updated refs/heads/rebased.
所以现在我有两个版本的我的历史,不同的是其中一个版本中没有 A
的踪迹。但是,因为我选择了 --keep-empty
选项,所以我仍然希望 rebased
中存在空提交,这将向我显示 A
如果它在那里,就会被修改。
但显然,事实并非如此:
$ git log --oneline master
f893569 change B
182aaa1 change A
3340b71 add A and B
38cb5da some base commit to not run into the root corner case
$ git log --oneline rebased
73a2c05 change B
55f502b add A and B
38cb5da some base commit to not run into the root corner case
这不是 --keep-empty
应该做的,还是它不起作用正确吗?
相关:Rebase on the root and keep empty commits是一个非常相似的问题,但它涉及我在此处明确避免的 --root
极端情况。它没有答案,只有一些评论表明我在这里展示的内容应该有效。另一个区别是,在另一个问题中,提交首先是空的,而在这里它只是在解决冲突后才变为空。
最佳答案
由于某种功能,这有点像错误。 :-)
当你运行 interactive rebase 并且它“暂停”时,实际上,它完成了,但留下了一些文件让 new git rebase
意识到它毕竟更像是一个延续。就目前而言,这很好;你将需要稍后运行 git rebase --continue
来开始一个新的 rebase 并告诉它:你不是新手,去阅读状态并表现得就像你在继续原来的 rebase 。
然后,让我们看一下“交互式 rebase ”。实际上,这主要是一系列的 cherry-pick 操作:pick
命令从字面上指示旧的 rebase shell 脚本(现在正在逐步淘汰)运行 git cherry-pick
.
好的,目前没什么大不了的。但是,让我们考虑一下为什么 交互式 rebase 会停止。有两个原因:
您将提交标记为“编辑”。它实际上提交了 cherry-pick,然后停下来让您修改提交或以其他方式大惊小怪。
或者,存在强制停止的问题(例如 merge 冲突)。
在情况 (1) 中,当您运行 git rebase --continue
时,Git 应该不自己提交。
在情况 (2) 中,当您运行 git rebase --continue
时,Git 应该 进行自己的提交。也就是说,它应该除非——这是特性部分——你先自己提交。在那种情况下,对于情况 (2),Git 应该不自己提交。
Git 可以,也许应该记录停止的原因,以便区分这两种情况……但它没有。相反,它只查看 --continue
上的状态。
对于非交互式 rebase ,Git 知道它只在发生冲突时停止,所以它知道尝试提交,如果没有什么可提交则提示。这就是 --keep-empty
或 -k
标志有用的地方。 (在内部,非交互式案例默认使用 git format-patch
和 git am
,尽管您可以通过 --preserve 强制它使用交互式机制-merges
例如。我在这里提到这个是因为这是 Git 必须知道您是否正在“交互”的实现原因:正如经常发生的那样,Git 在这里让实现指示行为。如果 Git 不需要这种区别,--continue
可以只对交互式和非交互式 rebase 使用相同的代码,但是 Git 确实需要这种区别,因此不使用相同的代码。)
不过,对于交互式 rebase ,Git 允许您在情况 (2) 中进行自己的提交,就在运行 git rebase --continue
之前(这是功能部分)。如果是这样,--continue
步骤应该继续进行下一次提交。所以 --continue
只是检查现在是否有要提交的内容,而不是针对案例 (1) 与案例 (2) 的早期交互式 rebase 是否退出。这个简单的实现技巧启用了该功能,但也意味着 --keep-empty
不能在这里工作:Git 只是不知道其中的区别。
解决方法是在解决 merge 后执行您自己的 git commit --allow-empty
。换句话说,使用“您可以自己提交”功能,将案例 (2) 转换为模拟案例 (1)。
关于git - 交互式 rebase 后删除了空提交,即使使用了 --keep-empty,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45691594/
我知道如何通过iPhone开发创建sqlite数据库、向其中插入数据、删除行等,但我试图以编程方式删除整个数据库本身,但没有得到任何帮助。请有人指导我如何通过代码从设备中删除/删除整个 sqlite
请帮助指导如何在 Teradata 中删除数据库。 当我运行命令DROP DATABASE database_name时,我收到错误消息: *** Failure 3552 Cannot DROP d
Azure 警报规则的删除命令似乎不起作用,尝试了下面的方法,它返回状态为无内容,并且警报未被删除 使用的命令Remove-AzAlertRule -ResourceGroup "RGName"-Na
我在 flex 搜索中为大约50000个视频建立了索引,但是当它达到52000左右时,所有数据都被删除。嗯,这对我来说真的很奇怪,我没有为ES设置任何Heap大小或最小或最大大小的内存大小,因此它们没
我正在处理的问题是表单错误“输入由字母、数字、下划线或连字符组成的有效‘slug’。” 以下是我的表单字段验证: def clean_slug(self): slug = self.c
阅读文档,我希望 $("#wrap2").remove(".error") 从 中删除所有 .error 元素#wrap2。然而看看这个 JSFiddle: http://jsfiddle.net/h
嗨,我第一次尝试发现 laravel 我从 laravel 4.2 开始,我刚刚创建了一个新项目,但我误以为我写了这样的命令行 composer create-project laravel/lara
我已经在网上搜索了很长一段时间,但我找不到如何完全删除 apache 2.4 。 使用: Windows 7 c:\apache24\ 我已经尝试了所有命令,但没有任何效果。 httpd -k shu
可能是一个简单的答案,所以提前道歉(最少的编码经验)。 我正在尝试从任何列中删除具有特定字符串(经济 7)的任何行,并且一直在尝试离开此线程: How to drop rows from pandas
有几种方法可以删除/移除 vector 中的项目。 我有一个指针 vector ,我需要在类的析构函数中删除所有指针。 什么是最有效/最快甚至最安全的方式? // 1º std::for_each(v
我安装了一个 VNC 服务器并在某处阅读了我必须安装 xinetd 的信息。稍后我决定删除 VNC 服务器,所以我也删除了 xinetd。似乎 xinetd 删除了一些与 plesk 相关的文件,如果
我制作了一个从我们的服务器下载视频的应用。问题是: 当我取消下载时,我打电话: myAsyncTask.cancel(true) 我注意到,myAsyncTask 并没有在调用取消时停止...我的 P
是否可以在使用DELETE_MODEL删除模型之前检查模型是否存在我试图避免在尝试删除尚未创建的模型时收到错误消息。基本上我正在寻找对应的: DROP TABLE IF EXISTS 但对于模型。 最
我已经有了这个代码: 但它仍然会生成一个表行条目。 我想做的是,当输入的数量为0时,表行将被删除。请耐心等待,因为我是 php 和 mySQL 编码新手。 最佳答案 您忘记执行查询。应该是 $que
在 SharePoint 中,如果您删除/修改重复日历条目的单次出现,则不会真正删除/修改任何内容 - 相反,会创建一个新条目,告诉 SP 对于特定日期,该事件不存在或具有新参数. 因此,这可以通过删
在 routes.php 中我有以下路由: Route::post('dropzone', ['as' => 'dropzone.upload', 'uses' => 'AdminPhotoContr
在我的应用程序中,我正在尝试删除产品。当我第一次删除产品时,它会成功并且 URL 更改为/remove_category/15。我正在渲染到同一页面。现在,当我尝试删除另一个产品时,网址更改为/rem
这个问题被问了很多次,但给出的答案都是 GNU sed 特定的。 sed -i '' "/${FIND}/,+2d""$FILE" 给出“预期的上下文地址”错误。 有人可以给我一个例子,说明如何使用
在使用 V3 API 时,我找不到任何方法来删除和清理 Google map 。 我已经在 AJAX 站点中运行它,所以我想完全关闭它而无需重新加载页面。 我希望有一个 .unload() 或 .de
是否可以创建一个 Azure SQL 数据库用户来执行以下操作: 针对所有表和 View 进行 SELECT 创建/更改/删除 View 但用户不应该不拥有以下权限: 针对任何表或 View 插入/更
我是一名优秀的程序员,十分优秀!