我正在尝试为我的存储库中的提交创建一个修补程序。
git --version => git version 2.10.1.windows.1当我尝试创建修补程序时,我会:
git format-patch master
git format-patch master -o C:\Users\MyUser\Desktop
git format-patch master --stdout > C:\Users\MyUser\Desktop\MyPatch.patch在所有三种情况下,我什么也得不到。在前2种情况下,在我指定的位置没有保存任何文件。在第三种情况下,生成的文件为0字节。
存储库的状态
我已经把一切都推给师父了。因此,我没有更多的本地未上演或上演的提交。所有东西都在服务器上。
另外,如果我更改了一个文件并进行了未分阶段的更改,它仍然无法工作。
我也试过:
git format-patch <ccommit-sha>使用我推送的提交的SHA哈希。还是不起作用。
我做错了什么?
发布于 2016-11-03 14:36:26
要创建修补程序,您需要指定应该使用什么来创建它。如果您想使用主分支的最后提交创建修补程序,只需调用git format-patch -1 main。
如果您需要为某些特定提交创建修补程序(修补程序),可以使用SHA-1值代替分支名称。
有关更多信息,请查看格式补丁文档。
值得一提的是,如果您将在当前提交(稍后的时间戳)之后使用提交的SHA-1散列,
这是由创建补丁的方式造成的。git格式补丁的Git文档表示,该修补程序在技术上是执行
diff -p stat哪个创建提交与其父级之间的差异。。在这种情况下,父键是一个键。如果希望在当前存储库状态(例如签出comit)和将来的存储库状态之间创建修补程序,则不可能这样做,因为未来的提交不是父级的,而是子的。
https://stackoverflow.com/questions/40404198
复制相似问题