Linux下 .patch 补丁文件生成和格式说明

转自:https://blog.csdn.net/jiasike/article/details/51700868 ,仅供学习参考使用。

1、补丁说明:  

  “补丁” 指的是文件之间一系列差异。

  在原始文件的基础上进行修改后,然后根据所做的修改生成补丁文件(使用diff命令)。

  一个持有原始文件的人,将该补丁打到原始文件上(使用patch命令),就变成了修改后的文件。

2、创建补丁文件 .patch 

  2.1、先创建两个实验文件

    原文件 1.txt

this is a test
for patch file format
so let us go!

    修改后的文件 2.txt

this is a test
for linux patch file format
so let us go!
learn it

  2.2、生成补丁文件:diff -u 1.txt 2.txt > diff.patch 

  2.3、查看补丁文件 vim diff.patch ,生成的补丁文件内容如下:

1 --- 1.txt       2020-07-20 16:45:27.131654289 +0800  #补丁头
2 +++ 2.txt       2020-07-20 16:46:26.348728016 +0800  #补丁头
3 @@ -1,3 +1,4 @@                                      #块
4  this is a test                       
5 -for patch file format
6 +for linux patch file format
7  so let us go!
8 +learn it    

  “- - -” 表示旧文件(原文件)

  “+++” 表示新文件(修改后的文件)

  补丁头记录了原始文件和修改后的文件的文件名和创建时间。

  补丁中的块是用来说明文件的改动情况。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头

  块会缩进一列,该列有三种情况:

    • 以 “-” 开头的行,表示改行只在原始文件中存在,比如第5行

    • 以 “+” 开头的行,表示改行只在修改后的文件中存在,比如第6行和第8行

    • 以空格开头的行,表示改行在原始文件和修改后的文件中都存在,比如第4行和第7行  

  从打补丁的角度来看,这一列是用来表示这一行是要增加还是要删除的;

    •   以 “-” 开头的行是要删除的

    •   以 “+” 开头的行是要加上的

    •   以空格开头的行保持不变

3、补丁的使用

  第一步

    打开补丁文件(xxx.patch)看内容

    diff --git a/arch/arm.... b/arch/arm....

    你会看到如上的文字,表示补丁修改的路径。注意a和b是不必要的路径。而arch/arm是linux内核的路径,是必须的。

  第二步

    输入命令如下,选项 -p 使用 -p1 打补丁,这样可以去掉路径中多余的a和b。

    patch -p1 < XXX.patch

  错误排查:

    如果出现

    can't find file to patch at input line 5

    Perhaps you used the wrong -p or --strip opetion

    表明你所在的路径不对,参照第二部修改p的值,或者把补丁文件放在正确的路径下。arch/arm/路径下的文件是在kernel文件夹里的,而我在kernel文件夹的上一级进行操作,那么,p设成什么数值,都无法成功。

posted @ 2022-08-01 15:24  白菜没我白  阅读(1413)  评论(0编辑  收藏  举报