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设成什么数值,都无法成功。
本文来自博客园,作者:白菜没我白,转载请注明原文链接:https://www.cnblogs.com/xingboy/p/16540480.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具