我需要编写一个脚本,为SHA-1提交号列表创建补丁。

我尝试使用git格式补丁<SHA1>,但从SHA-1值开始,每次提交都会生成一个补丁。在生成了几百个补丁之后,我不得不终止这个过程。

是否有方法只为特定的SHA-1值生成补丁?


当前回答

Try:

git format-patch -1 <sha>

or

git format-patch -1 HEAD

根据上面的文档链接,-1标志告诉Git补丁中应该包含多少提交;

-<n>    从最顶层提交准备补丁。


使用以下命令应用修补程序:

git am < file.patch

或者,您也可以应用(应适用于包括Windows在内的所有操作系统):

git apply --verbose file.patch

-v或--verbose将显示失败的内容(如果有的话)。告诉你如何修复。

其他回答

假设您在提交1之后有提交id 2,则可以运行:

git diff 2 1 > mypatch.diff

其中2和1是SHA-1散列。

以我的Mercurial背景,我打算使用:

git log --patch -1 $ID > $file

但我正在考虑使用git格式补丁-1$ID。

Try:

git format-patch -1 <sha>

or

git format-patch -1 HEAD

根据上面的文档链接,-1标志告诉Git补丁中应该包含多少提交;

-<n>    从最顶层提交准备补丁。


使用以下命令应用修补程序:

git am < file.patch

或者,您也可以应用(应适用于包括Windows在内的所有操作系统):

git apply --verbose file.patch

-v或--verbose将显示失败的内容(如果有的话)。告诉你如何修复。

该命令(如@Naftuli Tzvi Kay所建议的),

git format-patch -1 HEAD

用特定的哈希或范围替换HEAD。

将生成最新提交的补丁文件,格式与Unix邮箱格式相似。

-<n> -从最上面的<n>提交准备修补程序。

然后,您可以通过以下方式以邮箱格式重新应用修补程序文件:

git am -3k 001*.patch

参见:man git格式补丁。

要从特定提交(而不是最后一次提交)生成修补程序,请执行以下操作:

git format-patch -M -C COMMIT_VALUE~1..COMMIT_VALUE