如何应用' git diff '补丁没有安装git ?

我的客户端如何在没有安装git的情况下应用git diff创建的补丁? 我已经尝试使用patch命令,但它总是要求文件名修补
145243 次浏览
git diff > patchfile

而且

patch -p1 < patchfile

工作,但许多人注意到在评论和其他答案补丁不理解添加,删除和重命名。如果你需要处理文件的添加、删除和重命名,除了git apply patchfile没有其他选项。


编辑 2015年12月

patch命令的最新版本(2.7,2012年9月发布)支持“diff——git”格式的大部分功能,包括重命名和复制、权限更改和符号链接差异(但尚未二进制差分)(发布公告)。

因此,只要使用当前/最新版本的patch,就不需要使用git来将其diff应用为补丁。

试试这个:

$ git apply file.diff

试试这个:

patch -p1 < patchfile

使用

git apply patchfile

如果可能的话。

patch -p1 < patchfile

有潜在的副作用。

git apply还处理文件的添加、删除和重命名,如果它们是用git diff格式描述的,而patch不会这样做。最后,git apply是一个“全部应用或全部中止”模型,其中要么全部应用,要么什么都不应用,而patch可以部分应用补丁文件,使您的工作目录处于奇怪的状态。

我使用

patch -p1 --merge < patchfile

这样,冲突就可以像往常一样得到解决。