git 打patch的方法

首先,我们要知道为什么要去打patch?

比如:我们交给客户的版本是2.0版本的,随着公司的发展,项目已经到了3.0。这时候客户提出了一个bug。我们需要对其进行修复。当然我们不能给客户升级到3.0版本(因为他没给钱)。。。这个时候我们就可以使用打包的方式来提交代码。

首先第一步我们要创建一个分支

git checkout -b patch_dev

第二步,我们进行bug修复

我就改了一下输出了:

 接下来第三步我们就正常的提交代码

 第四步:查看你要打patch的commit对应的id

 第五步。打一个patch包

git format-patch  你的commit对应的id

 这个时候我们目录上面多了一个patch(忽略那个12345)

 之后我们切换到master分支上面,并且进入到你修改的文件的目录下执行:

 git am  patch文件的路径

这时候我们只需要在master 上push一下代码就ok了。

或者 如果遇见冲突

git format-patch HEAD^ #生成最近的1次commit的patch

$ git apply --stat 0001-limit-log-function.patch  # 查看patch的情况
$ git apply --check 0001-limit-log-function.patch # 检查patch是否能够打上,如果没有任何输出,则说明无冲突,可以打上
$ git apply xxx.patch
 

  • 11
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
回答: 要使用gitpatch,你可以按照以下步骤进行操作。首先,你可以使用命令`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* [gitpatch方法](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* [Gitpatch (打补丁)的使用](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 ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值