linux补丁文件格式#
“补丁” 指的是文件之间一系列差异。
在原始文件的基础上进行修改后,然后根据所做的修改生成补丁文件(使用diff命令)。
一个持有原始文件的人,将该补丁打到原始文件上(使用patch命令),就变成了修改后的文件。
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. 生成补丁文件#
diff -u 1.txt 2.txt > diff.patch
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
3.补丁头#
--- 1.txt 2020-07-20 16:45:27.131654289 +0800
+++ 2.txt 2020-07-20 16:46:26.348728016 +0800
"---" 表示旧文件(原文件)
"+++" 表示新文件(修改后的文件)
补丁头记录了原始文件和修改后的文件的文件名和创建时间。
4.块#
补丁中的块是用来说明文件的改动情况。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头
。
@@ -1,3 +1,4 @@
this is a test
-for patch file format
+for linux patch file format
so let us go!
+learn it
5.块的缩进#
@@ -1,3 +1,4 @@
this is a test
-for patch file format
+for linux patch file format
so let us go!
+learn it
块会缩进一列,该列有三种情况:
-
以 "-" 开头的行,表示改行只在原始文件中存在,比如第5行
-
以 "+" 开头的行,表示改行只在修改后的文件中存在,比如第6行和第8行
-
以空格开头的行,表示改行在原始文件和修改后的文件中都存在,比如第4行和第7行
从打补丁的角度来看,这一列是用来表示这一行是要增加还是要删除的;
-
以 "-" 开头的行是要删除的
-
以 "+" 开头的行是要加上的
-
以空格开头的行保持不变
@@ -1,3 +1,4 @@
的含义分别是:
- -1,3 原文件,从第1行开始一共显示了3行
这3行时原文件中有的
this is a test
-for patch file format
so let us go!
- +1,4 修改后的文件,从第1行开始一共显示了4行
这4行时原文件中有的
this is a test
+for linux patch file format
so let us go!
+learn it