patch和git制作和应用补丁


转自http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=29140689&id=4030348

patch命令

1、处理单个文件补丁的方法:
产生补丁
diff -uN from-file to-file >to-file.patch
打补丁
patch -p0 < to-file.patch
取消补丁
patch -RE -p0 < to-file.patch

2、对整个文件夹打补丁的情况:
产生补丁
diff -uNr from-docu to-docu >to-docu.patch
打补丁
patch -p1 < to-docu.patch
取消补丁
patch -R -p1 注,冲突:
.orig 合并前文件备份。
.rej 文件里是冲突没合入的内容。

git命令

1、git format-patch (推荐)
只适用于git的patch
包含diff信息,包含提交人,提交时间等
如果git format-patch 生成的补丁不能打到当前分支,git am会给出提示,并协助你完成打补丁工作
例:从master checkout一个新分支修改然后与master对比生成patch。git format-patch -M master //-M选项表示这个patch要和那个分支比对
git am 001-xxx.patch(不必重新commit)

2、git diff
生成标准的patch,只包含diff信息
git diff生成的Patch兼容性强,可以用git apply –check 查看补丁是否能够干净顺利地应用到当前分支中。
例:从master checkout一个新分支修改然后与master对比生成patch。 git diff master > patch
git apply xxx.patch(需要重新commit)

使用.diff文件打补丁的步骤如下: 1. 首先,使用diff命令生成.diff文件,该文件记录了源文件和目标文件之间的差异。语法格式为:diff 【选项】源文件(夹)目标文件(夹)\[1\]。 2. 然后,使用git apply命令将.diff文件应用到源文件上,使其变成目标文件。语法格式为:git apply ~/patch/patch/test.diff\[2\]。 3. 如果打补丁失败,可以尝试使用git apply命令的--reject选项和--ignore-whitespace选项来解决冲突。语法格式为:git apply --reject --ignore-whitespace ~/patch/patch/test.diff\[3\]。 请注意,打补丁前最好先检查diff文件是否可用,可以使用git apply --check命令来检查\[2\]。如果打补丁失败,可以查看错误信息以及使用日志文件来进行排查\[3\]。 #### 引用[.reference_title] - *1* [Linux下使用diff和patch制作及打补丁](https://blog.csdn.net/qq_21148843/article/details/107239113)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [git apply、git am打补丁.diff 和 .patch](https://blog.csdn.net/qq_31811537/article/details/82215938)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值