- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经开始使用如下命令进行挑选:
git cherry-pick A B C D
假设补丁 A 和 B 存在一些 merge 冲突,但我最终修复了所有冲突并 git cherry-pick --continue
。当我最终到达 C 时,我意识到必须已经应用了相同的代码,现在补丁是空的。
我可以选择 git cherry-pick --allow-empty
但这会在我的历史记录中留下一个我不想要的空提交。理想情况下,我只想跳过这个补丁 (C)。但是没有 git cherry-pick --skip
。我可以 git cherry-pick --abort
但这会丢失我对 A 和 B 的所有工作。
作为一种解决方法,我可以接受空的,记住它是哪个,然后在完成 cherry-pick 后使用 git rebase -i B
将其删除。有没有更好的办法?
最佳答案
在 Git 2.23(2019 年第 3 季度)中,“git cherry-pick/revert
”学习了一个新的“--skip
”操作。
所以在你的情况下:git cherry-pick --skip
on C
。
参见 commit dcb500d , commit de81ca3 , commit 265ab48 , commit 918d1e6 , commit 6a1f904 (2019 年 7 月 2 日)作者:Rohit Ashiwal (r1walz
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit d97c62c ,2019 年 7 月 19 日)
cherry-pick/revert: add --skip option
git am
orrebase
have a--skip
flag to skip the current commit if the user wishes to do so.During a
cherry-pick
orrevert
a user could likewise skip a commit, but needs to use 'git reset
' (or in the case of conflicts 'git reset --merge
'), followed by 'gi
t (cherry-pick
|revert
)--continue
' to skip the commit.
This is more annoying and sometimes confusing on the users' part.Add a
--skip
option to make skipping commits easier for the user and to make the commands more consistent.Update the advice messages, to tell users about this less cumbersome way of skipping commits.
所以不是看到:
Otherwise, please use 'git reset
If you wish to skip this commit, use:
git reset
你会看到:
Otherwise, please use 'git cherry-pick --skip
and then use:
git cherry-pick --continue
在 C 中重写“git rebase
”期间,防止“git commit
”在中断的 cherry-pick 期间进行空提交或修改的机制被破坏,已使用 Git 2.27(2020 年第二季度)更正。
参见 commit 5b7a64d (2019 年 12 月 6 日)Johannes Schindelin (dscho
) .
参见 commit 430b75f , commit 901ba7b , commit 8d57f75 , commit 21b11c6 , commit f028d66 , commit 780308d (2019 年 12 月 6 日)Phillip Wood (phillipwood
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit f085189,2020 年 3 月 25 日)
commit
: give correct advice for empty commit during a rebaseOriginal-patch-by: Johannes Schindelin
Signed-off-by: Phillip WoodIn dcb500dc16c ("
cherry-pick/revert
: advise using --skip", 2019-07-02, Git v2.23.0-rc0 -- merge listed in batch #6),git commit
learned to suggest to rungit cherry-pick --skip
when trying to cherry-pick an empty patch.However, it was overlooked that there are more conditions than just a
git cherry-pick
when this advice is printed (which originally suggested the neutralgit reset
): the same can happen during a rebase.Let's suggest the correct command, even during a rebase.
While at it, we adjust more places in
builtin/commit.c
that incorrectly assumed that the presence of aCHERRY_PICK_HEAD
meant that surely this must be acherry-pick
in progress.Note: we take pains to handle the situation when a user runs a
git cherry-pick
during a rebase.
This is quite valid (e.g. in anexec
line in an interactive rebase).
On the other hand, it is not possible to run a rebase during a cherry-pick, meaning: if bothrebase-merge/
andsequencer/
exist orCHERRY_PICK_HEAD
andREBASE_HEAD
point to the same commit , we still want to advise to usegit cherry-pick --skip
.
关于git - 如何在挑选多个补丁时跳过一个补丁?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53073010/
我正在尝试在站点列表中添加站点名称,以便在 publish:end:remote 上清除 HTML 缓存事件。 mysite 但是,它没有按预期工
我正在尝试使用不同目录中的多个文件制作补丁。我不想包含所有未提交的文件,因为我有很多不适用于补丁。 我知道这个命令可以使用特定文件创建补丁,唯一的问题是这是一个文件: svn diff -up ori
我经常使用 gnu-utils 补丁和差异。使用 git,我经常这样做: git diff 通常简单的更改会创建一个大补丁,因为唯一的更改是,例如,添加一个 if/else 循环,并且里面的所有内容都
我使用命令(从 ~ 执行)生成了一个 diff.txt 文件: diff -r /full/path/to/directory/A /full/path/to/directory/B > diff.t
我正在编写一个项目,我需要通过网络传输一组相似的图像。为了加快速度,我考虑过做大多数电影编解码器所做的事情。有关键帧,然后发送更改。 现在,我得到的是一组 BufferedImage,因此类似于文本文
我正在尝试将更改拆分为多个提交,但在手动编辑大块时我遇到了问题。 原始大块头: @@ -116,8 +116,8 @@ context context -
我想自动测试一组仍然干净利落地适用于(更新的)代码库的补丁。为此,我打算运行 patch -p 1 a echo b > b diff -Nu a b > p rm a b patch -p 1 <
我已经从一个模块中导入了一个类,但是当我尝试在没有模块作为前缀的情况下修补类名时,我得到一个类型错误: TypeError: Need a valid target to patch. You sup
最近我从 SVN 迁移到 git,我的团队已经开始在新的 git 存储库中工作。 后来我发现了一些转换问题,并从 SVN 制作了第二个 git repo,并进行了一些修复和历史重写。 现在我有了 SV
我正在尝试为我的应用程序创建一个补丁。实现描述的示例 here按预期工作。但是,每个版本的文件都存储在单独的目录中。 1.0 版文件在 c:sample\1.0 中,1.1 版文件在 c:sample
首先请原谅我的长文,但我会尽量详细。 我正在为一个开源项目 (DSpace) 进行开发。我没有对他们的 SVN 存储库的提交权限,所以我查看了源代码并一直使用 git 来管理我的版本控制。 在我的开发
有没有办法自动 merge (interdiff)2 个头分支和 1 个基分支之间的冲突? 我试图在补丁级别做这件事 版本A是我的基础 VersionB 是 VersionA 的分支 VersionB
我正在尝试申请 this修补到 MinGW 上的 GCC 以获取它 to compile GDC 2 ,但我不知道如何。 (我对 GCC 的内部结构还很陌生,甚至对一般的 *nix 工具也很陌生。)我
我对软件开发很陌生,所以这无疑是一个非常基本的问题。我得到了一个开源项目的 mercurial repo。我复制了它并做了一些工作。 promise 。工作更多,然后进行了第二次提交。所以我的树看起来
我想对这个错误 ( http://code.djangoproject.com/ticket/13095 ) 应用补丁,但我以前从未做过,也不知道从哪里开始。谁能给我指点教程? 最佳答案 在 Linu
我前段时间使用 p4 diff 生成了一个补丁。命令。 然而,现在我想应用它,我意识到没有办法在 Perforce 中应用补丁。 由于我没有使用 -du选项,补丁是那种晦涩难懂的 perforce 格
我可以使用 NSIS 的 Vpatch 生成从一个版本到另一个版本的补丁文件。假设我有 mydll.dll 版本 1,我有一个补丁可以将它更新到版本 2。然后我又有了一个新版本,因此我生成了另一个补丁
我有一个补丁,用 hg export 42 制作在另一个存储库中,修改文件 asd/fgh/foo/bar.c asd/fgh/foo/fish.h boo/hoo.txt 我需要将此补丁导入具有如下
我们有一个相当大的库,我们需要定期将其导入(然后修补)到我们的代码库中。 SVN Book 似乎推荐了一个“vendor branch”方案,我们保留了“vendor drops”的补丁版本。这会起作
我正在家里用 tensorflow 玩卷积神经网络(顺便说一句,我已经完成了 udacity 深度学习类(class),所以我有理论基础)。 运行卷积时,patch 的大小会产生什么影响?当图像变大/
我是一名优秀的程序员,十分优秀!