- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
假设我的本地分支上有以下版本历史:
A -- B -- C
如何在 A 和 B 之间插入新版本 X,以便版本历史如下所示:
A -- X -- B -- C
注意,how to insert a commit in the past 上也有类似的问题然而,在我的例子中有点不同:X 引入的任何更改都不会传播到 B,在版本 X 插入 A 和 B 之后应该保持不变。
最佳答案
如果你想添加提交,但让它对源没有影响,那么是的,你确实需要一个不同于交互式 rebase 的路径。
没有专门为此设计的东西,但使用 git replace
相对容易:
A
(作为分离的 HEAD,或在新分支上,但新分支很快将无用):git checkout <hash-of-A>
。X
(无论您希望它如何出现)。git replace --graft <hash-of-B> HEAD
。你现在有这个真实的历史:
X--B' <-- refs/replace/<hash-of-B>
/
A--B--C <-- whatever-branch-this-is
这些“替换”对象的特别之处在于,无论何时 Git 将要对几乎任何对象执行几乎任何操作——例如,包括“出于任何目的使用提交”,Git 都会查看是否有 refs/replace/
名称与对象的哈希 ID。由于是 B
的替代品,Git 现在将查找 B'
。因此,git log
和其他 Git 命令的作用就好像历史是:
A--X--B'--C
但是请注意,真实历史仍然存在于此存储库中。替换历史当且仅当 refs/replace/
名称在存储库中——当然是在这个存储库中——并且替换被启用(它是由默认)。但是,如果您将此存储库克隆或推送到其他地方,提取或推送过程通常不会传输任何 refs/replace/
名称;所以这个存储库的克隆将切换回旧的历史。 (您也可以通过禁用替换来查看原始历史记录,例如使用 git --no-replace-objects log ...
。)
如果愿意,您现在可以运行 git filter-branch
,它只是复制提交。默认情况下,git filter-branch
遵循替换规则。这意味着当它复制分支上的提交时,它将从 A
开始,然后复制 X
,然后复制 B'
,然后复制指向 C
的 B'
。 A
、X
和 B'
的副本将与原件逐位相同,因此实际上将重新使用原件;但 C
的副本会略有不同:它将使用 B'
作为其真正的父级,而不是替代的、嫁接的父级。因此提交 C
将被复制到新的提交 C'
并且分支名称,无论它是什么,都将指向新副本。
这个过滤后的分支有实际(不仅仅是移植的)历史,从 B'
到 X
到 A
C'
并通过 B'
返回到 X
到 A
。
关于git - 如何在过去的两个任意版本之间注入(inject)一个版本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46678238/
我有一些文档,它的创建时间以毫秒为单位。我需要将它们分为今天、昨天、过去 7 天、过去 30 天、超过 30 天。 我使用了以下代码:convertSimpleDayFormat(1347022979
我正在尝试创建一个 Crystal 报告,用于在图表中显示十二个月的月费率。 对于此任务,我有一个 dc_date(mm/dd/yyyy) 作为变量,我将其更改为 mmyyyy 格式。但是当我看到月份
我想使用 Linux 命令将年转换为天(过去)。例如: 用户给出的号码:10年前 程序应计算 10 年前的天数总和(例如:10*12*31(年/月/日)--> 3720 天)。 程序将其与今年开始的当
我的要求有点复杂,为了便于理解,让我用简单的例子说明一下。假设,我们必须计算过去 12 个月消费者按月购买的产品数量。所以我们要做的是: SELECT DATENAME(MONTH, m.Invoic
如果我今天(2012 年 8 月 21 日)运行查询,我想得到这个结果集: [...] 为了得到这个,我正在使用以下内容,但它似乎过于复杂。这可以简化吗? ;WITH Numbers_cte([num
这是我目前用来显示下周五日期的方法。 $date_friday = date('F j', strtotime('Friday')); print $date_friday; 我应该使用什么来显示过去
我有一个包含一个日期时间列的表。我只需要返回过去 6 个月的行。这可以通过 来完成 where datetime_column > DATEADD(m, -6, current_timestamp)
我正在为我的应用使用 Firestore,并且希望能够获得过去 7 天内发布的最受欢迎的项目。在理想的情况下,调用看起来像这样: let calendar = Calendar.cur
我有以下方法来计算时间: public static String sumTime(String date1, String date2) throws ParseException { Ca
我想检索过去 24 小时内发布的观看次数最多的前 10 个主题。如果网站在过去 24 小时内获得的主题少于 10 个,则必须检索前一天剩余的浏览次数最多的主题。 我以unix格式将时间存储在数据库中,
我想从我的 MySQL 服务器获取过去 x 个月的所有记录。例如使用 2 个月(不是过去 2 个月,比如过去 60 天,而是过去整个月等等。如果实际月份是 4 月,我想要 2 月和 3 月的所有记录)
我正在尝试使用 php 创建一个博客系统,我需要一种方法来计算过去 21 天内浏览次数最多的帖子。有人知道这样做的好方法吗? 我对 php 没有太多经验,所以我需要有人给我指出正确的方向。我试图研究
我正在尝试查找过去 26 周每周结束时的用户总数。 例如, 从第 26 周开始,该周有 100 名用户注册,并且有 20 名新用户注册,因此到第 26 周结束时,注册用户数量为 120 名 从第 25
假设我们有下表,列如下所示: Rides ride_id start_time end_time passenger_id driver_id ride
好的,我正在尝试获取过去 24 小时内包含“价格”列的所有行的平均值。 $tickerBuy = $this->model->ticker("date AS datetime, avg(price)
我有一个账户表,其中名为“dateCreation”的列是账户的创建日期。 我想获取过去 12 个月内创建的所有帐户,但有时 2 个月或更长时间都没有创建帐户。在这几个月里,我希望 mysql 返回
是否有办法检索过去 7 天内添加的所有用户?添加用户时,包含时间戳。日期被添加到他们的“信息”中。 例如这样: 因此日期公式为:D/M/YYYY。谁能帮我理解如何做到这一点? PS:奇怪的OL3gee
我有一个 Angualr 服务,可以列出从当前月份开始的 12 个月和年份: JS: app.factory('12months', function() { return {
我有一个弹出窗口,其中一个名为 fade 的元素应该扩展到屏幕的整个宽度(当没有可滚动内容时它会这样做)。但是,当内容超过浏览器窗口的 100% 时,它不会扩展到页面高度的 100%。 如果我设置 h
我正在尝试选择过去 5 天的整数字段的总和,我需要将它分组为每一天。 我在确定分组时遇到了一些问题。到目前为止,这是我的 sql 查询: select sum(`amount_sale`) a
我是一名优秀的程序员,十分优秀!