我的客户端如何在没有安装git的情况下应用git diff创建的补丁? 我已经尝试使用补丁命令,但它总是要求文件名补丁。
git diff > patchfile
and
patch -p1 < patchfile
工作,但许多人注意到在评论和其他答案补丁不理解添加,删除和重命名。如果你需要处理文件的添加、删除和重命名,除了git apply patchfile之外没有其他选项。
2015年12月
补丁命令的最新版本(2.7,2012年9月发布)支持“diff——git”格式的大部分功能,包括重命名和复制、权限更改和符号链接差异(但还不是二进制差异)(发布公告)。
因此,如果一个人使用当前/最新版本的补丁,就不需要使用git来应用它的diff作为补丁。
Use
git apply patchfile
如果可能的话。
patch -p1 < patchfile
有潜在的副作用。
Git应用程序还可以处理文件的添加、删除和重命名,如果它们是用Git diff格式描述的,这是补丁无法做到的。最后,git apply是一个“apply all or abort all”模型,其中要么全部应用,要么什么都不应用,而patch可以部分应用补丁文件,使您的工作目录处于一种奇怪的状态。
推荐文章
- 为什么调用git分支——unset-upstream来修复?
- Windows git“警告:LF将被CRLF取代”,这是警告尾巴向后吗?
- git中的哈希冲突
- git可以自动在空格和制表符之间切换吗?
- Git暂存文件列表
- 如何将git配置存储为存储库的一部分?
- 如何修改GitHub拉请求?
- 如何在Github和本地删除最后n次提交?
- 我如何调试git/git-shell相关的问题?
- 错误:无法使用rebase进行拉取:您有未分阶段的更改
- Git隐藏未缓存:如何把所有未分期的变化?
- 真实的恶魔
- 如何从另一个分支获得更改
- Git:权限被拒绝(publickey)致命-无法从远程存储库读取。克隆Git存储库时
- git reflog和log有什么区别?