Git Commit生成与合入Patch指南分享

 更新时间:2025年08月01日 10:56:27   作者:龙之叶  
文章介绍了生成和应用补丁的两种方法:diff命令对比目录生成补丁(需路径一致或使用软链接),及Git format-patch生成特定提交的补丁,同时说明了使用patch命令合入补丁的步骤,包括忽略目录层级和撤销操作

1. 生成 Patch 文件

1.1 使用 Diff 命令生成 Patch

通过 diff 命令,可以为两个目录生成差异补丁,这对于文件夹内文件的修改非常有用,可以生成一个包含所有修改操作的补丁文件。

前提条件:

  • 需要对比的两个目录的顶层路径深度需一致。若不一致,建议使用软链接来满足此要求。

示例:

假设有两个目录:

  • 目录1:/media/data2/quectel/r12/cn_kj_r12a07/ql-ol-kernel/
  • 目录2:/tmp/sdk/cn_kj_r12a07/ql-ol-kernel/

可以通过以下命令创建软链接并生成补丁:

mkdir patch
ln -s /media/data2/quectel/r12/cn_kj_r12a07/ql-ol-kernel/ patch/new 
ln -s /tmp/sdk/cn_kj_r12a07/ql-ol-kernel/ patch/old

若只修改了部分目录(如 arch/arm/boot/dts/qcom,drivers,sound),则只需对比这些路径:

cd patch 
diff -Naur old/arch/arm/boot/dts/qcom new/arch/arm/boot/dts/qcom > gpio-export.diff
diff -Naur old/drivers new/drivers >> gpio-export.diff
diff -Naur old/sound new/sound >> gpio-export.diff

参数说明:

  • -N: 将不存在的文件视为空文件。
  • -a: 将所有文件视为文本文件处理。
  • -u: 输出差异时附带差异前后三行的内容。
  • -r: 递归比较所有子目录。

注意:

  • 确保生成的补丁中,对比文件路径的顶层路径一致,以便合并时能正确找到对应文件。

1.2 使用 Git Format-Patch 生成 Patch

在 Git 中,可以使用 git format-patch 命令生成特定 commit 的补丁文件。

步骤:

  1. 确保已提交想要生成补丁的 commit。
  2. 使用 git format-patch 命令生成补丁文件。

示例:

  • 生成最新提交的补丁:
git format-patch -1 HEAD
  • 为特定 commit 生成补丁:
git format-patch -1 <commit-hash>
  • 为一系列 commits 生成补丁:
git format-patch <commit-hash1>..<commit-hash2>

常用命令:

$ git format-patch HEAD^ # 生成最近的1次commit的patch
$ git format-patch HEAD^^ # 生成最近的2次commit的patch
$ git format-patch HEAD^^^ # 生成最近的3次commit的patch
$ git format-patch <r1>..<r2> # 生成两个commit间的修改的patch
$ git format-patch -1 <r1> # 生成单个commit的patch
$ git format-patch --root <r1> # 生成从根到r1提交的所有patch

2. 合入 Patch 文件

2.1 使用 Patch 命令合入

将生成的 .diff 或 .patch 文件复制到目标目录,然后使用 patch 命令合入。

示例:

cp gpio-export.diff /tmp/sdk/cn_kj_r12a07/ql-ol-kernel/
patch -p1 < gpio-export.diff

参数说明:

  • -p1: 合入时忽略第一层目录。例如,.diff 文件中的 new/sound/soc/soc-jack.c 路径,查找时会忽略 new/ 前缀。
  • -pn: 忽略 n 层目录。

撤销补丁:

patch -p1 -RE < /media/data2/quectel/r12/patch/gpio-export.diff

参数说明:

  • -R: 还原修改,即撤销合入的补丁。
  • -E: 删除合入补丁后的空文件。

通过以上步骤,您可以轻松地生成并合入 Git commit 的 patch 文件,从而方便地进行代码的审查和合并。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Git中查看文件的变更历史的常用命令详解

    Git中查看文件的变更历史的常用命令详解

    在 Git 中,查看文件的变更历史是非常常见的操作,可以帮助你了解文件的修改记录、谁在何时进行了哪些修改,以下是一些常用的 Git 命令,可以帮助你查看文件的变更历史,需要的朋友可以参考下
    2025-06-06
  • 程序员喜欢的5款最佳代码比较工具

    程序员喜欢的5款最佳代码比较工具

    这篇文章主要介绍了程序员喜欢的5款最佳代码比较工具,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2020-06-06
  • json显示日期带T问题的解决方法

    json显示日期带T问题的解决方法

    使用json显示日期时,细心的朋友会发现带T字母,就是天数跟小时数之间出现了一个T,下面为大家介绍下具体的解决方法
    2013-10-10
  • VSCode常用知识小结

    VSCode常用知识小结

    本文给大家汇总介绍了vscode的下载,安装,常用插件以及常用的快捷键,非常的详细,希望对大家使用vscode能够有所帮助
    2020-02-02
  • 解决vs code通过remote-ssh远程到ubuntu频繁掉线问题

    解决vs code通过remote-ssh远程到ubuntu频繁掉线问题

    这篇文章主要介绍了vs code通过remote-ssh远程到ubuntu频繁掉线问题解决方法,这个解决方案只要用自己安装的Git替换掉windows本身的Git工具,需要的朋友可以参考下
    2022-09-09
  • 吐血推荐珍藏的Visual Studio Code插件(推荐)

    吐血推荐珍藏的Visual Studio Code插件(推荐)

    这篇文章主要介绍了吐血推荐珍藏的Visual Studio Code插件(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • 图片的色彩空间问题

    图片的色彩空间问题

    不知有多少朋友遇到此类问题:在PS里处理好的图,发到论论坛上以后发现图片颜色大变,变得灰蒙蒙,失去了层次,色彩生硬,还有点发青
    2014-05-05
  • 使用postman进行接口自动化测试

    使用postman进行接口自动化测试

    这篇文章介绍了使用postman进行接口自动化测试的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • Visual Assist X 番茄助手安装教程与汉化技巧

    Visual Assist X 番茄助手安装教程与汉化技巧

    Visual Assist X 是一款 Microsoft Visual Studio 扩展工具,能够帮助填补 Microsoft Visual Studio 在撰写 C/C++ 和 C# 程序之不足并提升其效率,本文给大家分享Visual Assist X 番茄助手安装与汉化教程,感兴趣的朋友一起看看吧
    2023-06-06
  • IDEA升级后Git拉取和推送的标签消失的解决方法

    IDEA升级后Git拉取和推送的标签消失的解决方法

    本文主要介绍了IDEA升级后Git拉取和推送的标签消失的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06

最新评论