如何打Patch

在团队开发的过程中,经常需要生成patch,或者打上别人提供的patch,那么一般情况是如何操作的呢。
首先生成patch需要有两个工程,一个修改前的A工程,一个修改后的B工程。

使用linux命令diff就可以生成patch了。格式如下:

diff -Naur path/to/A_Project path/to/B_Project > Project.patch

-N 选项确保补丁文件将正确地处理已经创建或删除文件的情况。
-a 将所有文件都当作文本文件处理。
-u 输出每个修改前后的3行,也可以用-u5等指定输出更多上下文。
-r 递归。设置后diff会将两个不同版本源代码目录中的所有对应文件全部都进行一次比较,包括子目录文件。

生成patch以后,在修改前A工程根目录下使用patch命令打上patch。

$ cd path/to/A_Project
$ patch -p1 < Project.patch
    -p Num 忽略几层文件夹

为了解释 -p 参数,需要看看如下patch文件片段:

--- old/modules/pcitable       Mon Sep 27 11:03:56 1999                                          +++ new/modules/pcitable       Tue Dec 19 20:05:41 2000

如果使用参数 -p0,那就表示从当前目录找一个叫做old的文件夹,再在它下面寻找 modules/pcitable 文件来执行patch操作。
而如果使用参数 -p1,那就表示忽略第一层目录(即不管old),从当前目录寻找 modules的文件夹,再在它下面找pcitable

如果要取消补丁做出的更改,恢复旧版本,在A工程的根目录下执行以下命令,A工程就会恢复成没有打patch的样子:

$ patch -RE -p0 < Project.patch

由Git管理的工程处理patch的方法:

  • 【生成patch】

分支master 上是没修改前的,分支patch 上是修改以后的打patch的。

  1. 先切换到 patch分支
    git checkout patch

  2. 生成patch
    git format-patch -M master
    会生成一个文件名如:0002-Release-version-1.4.6.patch 的patch文件

  • 【合并patch】

拿到patch以后,执行下面的命令:

git am 0002-Release-version-1.4.6.patch
如果不想直接commit,那么可以用下面这个命令打patch:

patch -p1 < 0002-Release-version-1.4.6.patch
然后手动commit 。

作者:cch___
来源:CSDN
原文:https://blog.csdn.net/cch___/article/details/53405450?utm_source=copy
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 要使用git打patch,你可以按照以下步骤进行操作。首先,你可以使用命令`git apply --stat 0001-limit-log-function.patch`来查看patch的情况。然后,你可以使用命令`git apply --check 0001-limit-log-function.patch`来检查patch是否能够成功应用,如果没有任何输出,则说明没有冲突,可以继续打patch。接下来,你可以使用命令`git apply 0001-limit-log-function.patch`来应用patch文件。\[1\]如果你想上传patch文件,你可以参考这篇文章:https://blog.csdn.net/qq_21583139/article/details/119588733。在正式打patch之前,一定要先备份原项目代码,并将patch文件放到线上项目目录下。确保线上的当前最新commit与打patch时生成的patch文件是相同的。最后,你可以使用命令`git apply --check 0001-bugfix-for-sg.patch`来检查patch文件是否与项目冲突。如果没有冲突,你可以继续进行打patch的操作。\[2\]另外,如果你想生成一个补丁文件,你可以使用命令`git diff > test.patch`。这个命令会将所有修改的文件都打成一个补丁文件,但需要注意的是,这里是本地修改的,没有执行add缓存的操作。\[3\]希望这些信息对你有帮助! #### 引用[.reference_title] - *1* [git 打patch的方法](https://blog.csdn.net/Chen_leilei/article/details/124153983)[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* [git项目如何打patch以及打patch的注意事项](https://blog.csdn.net/qq_21583139/article/details/127036451)[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] - *3* [Git 打patch (打补丁)的使用](https://blog.csdn.net/qq_33210042/article/details/128097580)[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、付费专栏及课程。

余额充值