linux下patch制作

diff
diff可以比较两个东西,并可同时记录下二者的区别。制作补丁时的一般用法和常见选项为:
diff 【选项】 源文件(夹) 目的文件(夹)
-r  递归。设置后diff会将两个不同版本源代码目录中的所有对应文件全部都进行一次比较,包括子目录文件。
-N 选项确保补丁文件将正确地处理已经创建或删除文件的情况。
-u  输出每个修改前后的3行,也可以用-u5等指定输出更多上下文。
-E, -b, -w, -B, --strip-trailing-cr
忽略各种空白,可参见文档,按需选用。

eg:

diff -uN from-file to-file >to-file.patch

补丁中的内容:

补丁头:补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。---开头表示旧文件,+++开头表示新文件
一个补丁文件中的多个补丁:一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。
块:块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。
块的缩进:块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。
块的第一列:+号表示这一行是要加上的。-号表示这一行是要删除的。没有加号也没有减号表示这里只是引用的而不需要修改。

eg:

--- aflgo/afl-fuzz.c	2020-04-14 17:03:11.000000000 +0800
+++ aflgo_new/afl-fuzz.c	2020-04-15 21:06:13.444000000 +0800
@@ -935,6 +935,7 @@
 
   if (*total_count > 0) {
     cur_distance = (double) (*total_distance) / (double) (*total_count);
+  }
   else
     cur_distance = -1.0;

 

你可能感兴趣的:(linux下patch制作)