- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
有没有办法配置 git
以便 git rebase --continue
跳过“无变化”测试?
我不希望 git rebase --continue
因为没有检测到任何变化而失败。发生这种情况时,它应该会自动删除提交。
为什么?
我经常遇到 git 的问题,我 git rebase --continue
失败了,因为它看不到任何变化,需要我说 git rebase --skip
。我明白为什么会发生这种情况,但它会减慢我的工作流程并使其更加危险:如果我正在做一个大型 rebase ,其中问题多次重复出现,以及合法的 merge 冲突,我更有可能不小心使用跳过命令从我打算重用 continue 命令的历史来看。
示例
假设我有以下历史:
A -- B -- C -- D -- E -- F <-- topic
\
H -- I <-- master
我想将提交 B、C、E 和 F 推送到 origin
中的主分支。
假设当我挑选它们时,B 工作正常,C 和 F 有一些由提交 H 和 I 引起的琐碎的 merge 冲突,并且 E 有一个重要的 merge 冲突,如果 H 和 I 是在历史中比如果 D 在历史中。解决这些冲突后,假设我的历史是:
A -- B -- C -- D -- E -- F <-- topic
\
H -- I -- B -- C' -- E'' -- F' <-- master
现在,我想将我的 topic
分支 rebase 到 master
上。这样做时,B 将被自动删除,但我会遇到 C、E 和 F 的 merge 冲突,因为它们在被挑选时被修改了。当 rebase 在 C 处暂停时,解决冲突不会产生任何净变化,因此当我尝试运行 git rebase --continue
时,git
会采取防御措施并提示:
No changes - did you forget to use 'git add'?
解决方案是改用git rebase --skip
。那时,E 会发生冲突;解决它需要实际更改,所以我实际上(并成功地)使用了 git rebase --continue
。然后,F 产生另一个虚假的 merge 冲突。与 C 一样,解决该冲突不会导致任何净更改,因此我再次被告知在尝试继续时使用跳过模式。
我想配置 git
以便当我解决 merge 冲突(特别是使用 mergetool
)并且解决结果没有净变化时,我想要 git rebase --continue
只做 git rebase --skip
的工作,最多提示我。如果它不够聪明,不知道我运行了 mergetool,我宁愿它总是自动跳过。 continue 选项似乎在防御不正确的 git checkout
命令 mid-rebase;这些天我对 git 已经足够熟悉了,永远不会有在 rebase 中不小心修改更改的危险。然而,当我的历史记录如下时,我几乎不小心跳过了:
git rebase # start the rebase
git mergetool # apply non-trivial fix
git rebase --continue # succeeds: non-trivial fix
git mergetool # apply non-trivial fix
git rebase --continue # succeeds: non-trivial fix
git mergetool # apply non-trivial fix
git rebase --continue # succeeds: non-trivial fix
git mergetool # nuke all changes from the topic branch
git rebase --continue # fails: no changes
git rebase --skip # this should have been automatic
git mergetool # apply non-trivial fix (THIS MUST NOT BE SKIPPED)
... here I have to be careful and not just reflexively hit up-arrow twice then <ENTER>...
最佳答案
有趣的问题。这里Automatically skip empty commits when using git rebase用户 Olivier Refalo 建议使用 G2 中的功能,为新手简化 git 界面。基本上它归结为在执行 git add
后检查索引中文件的内容是否与存储库中的文件不同。如果不同则执行 git rebase --continue
,如果相同则执行 git rebase --skip
。您可以创建执行以下操作的脚本:
#!/bin/sh
if git diff-index --quiet HEAD --; then
git rebase --skip
else
git rebase --continue
fi
或者你可以给你的 .gitconfig 添加一个别名:
[alias]
reb = "!if git diff-index --quiet HEAD --; then git rebase --skip; else git rebase --continue; fi"
关于git rebase --continue : how to suppress the "no changes" check,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23955504/
编码新手,无法弄清楚为什么 continue 在我的 for 循环中不起作用。在打印语句之后,我想从顶部重新开始循环。如果有人能让我知道我做错了什么,那就太好了。我不允许共享 cse231_rando
我正在尝试运行连续异步查询。在我的 Windows 盒子上,我通过双击 ignite.bat 文件启动了 Apache Ignite,并尝试运行以下代码 - Data Publisher 客户端包点燃
目前我正在尝试了解 openCV 中连续矩阵和非连续矩阵之间的一些区别。有人向我建议连续矩阵提供更好的性能,因为程序不必在每一列的末尾跳回到下一行的开头。 简而言之,连续和非连续矩阵之间的可比较性能差
我有一个运行多个行的 cron,删除“坏”的行(根据我的标准)。我只是想知道优化脚本的最佳方法是什么。我可以执行以下操作之一: 让同一个 cron 在发现“坏”行后立即删除它们。 让相同的 cron
我已经在我的 Tfs2010 实例上运行了一个 CI 构建,但我还想运行一个门控检入构建。然而,我希望这两个构建运行的方式之间存在细微的差异。具体来说,我希望 Gated checkin 在失败时不产
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 1年前关闭。 Improve this
Here和 here据说Continuation Monad解决了回调 hell 。 RX 和 FRP 也解决了回调 hell 。 如果所有这三个工具都解决了回调 hell ,那么就会出现以下问题:
我的 Java 缩进风格可能有点特殊,我经常这样写: object.myMethod( myFirstArgument, mySecondArgument, myThirdArgument,
关闭。这个问题需要details or clarity .它目前不接受答案。 想要改进这个问题吗? 通过 editing this post 添加详细信息并澄清问题. 关闭 2 年前。 Improve
我正在使用苹果的 SpriteKit 和 Swift 制作一个简单的游戏,并且遇到了问题。我试图让桨节点(paddle)围绕圆内的固定节点(anchorNode)连续旋转;但是,我无法弄清楚如何使桨节
我正在尝试为控制系统编写一个自适应 Controller ,即使用 Q-learning 的电源管理系统。我最近为车杆系统实现了一个玩具强化学习问题,并根据 Andrew NG 的笔记制定了直升机控制
我想知道一种原生支持定界延续的编程语言。我确实知道 Scala 曾经有 shift 和 reset,但这些都被删除了;而且我也知道 Seaside 似乎有类似的东西,但 Seaside 是一个图书馆,
在本教程中,您将通过示例了解 continue 语句。 continue 语句用于跳过循环的当前迭代,程序的控制流转到下一个迭代。 continue 语句的语法是: continue
背景 目前,我在本地构建解决方案时运行预构建命令。但是,在我的 VSTS 持续集成服务器上构建时不需要此命令。 问题 有没有办法在本地机器上构建时只运行预构建事件命令? 我知道您可以添加如下条件语句。
我有时会有 1 或 2 个测试在 CI 中失败,并且重新运行构建会导致它们通过。 如何自动重新运行这些不稳定的测试,以便我的构建第一次通过?有没有类似 mocha 的东西的this.retries ?
希望有人可以帮助我解决这个问题。让 TeamCity 启动并运行并在各种项目上进行构建。我希望能够自动将成功的 TeamCity 运行构建复制/部署到测试服务器。 我正在考虑使用 PowerShell
我希望使用持续集成,但我对 Ant、Jenkins、CruiseControl、Phing、PHPUnderControl 等并不了解…… 什么是真正的持续集成? 我正在使用 Zend Framewo
我已将 travis 设置为使用 tox(Python 2.7 和 3.5)进行测试并部署到 pypi。 Travis 尝试为每次测试运行部署包,而 pypi 正确地拒绝了第二次尝试。 我希望 tra
我正在尝试使用 pem key 将一些文件 scp 到不同的计算机,所以我不需要我的密码。但是,每次我尝试连接到一个新盒子时,它都会问我“说真的,你想连接吗?你想保存 key 吗?......”这太烦
使用dvc无疑有很多优势,它可以像集中式vcs一样使用,但是具有本地提交功能并且能够很容易地将项目 fork 给一些较小的团队,从而使得更难于支持持续集成吗?它有助于开发,使每个人都可以访问由CI服务
我是一名优秀的程序员,十分优秀!