比较两个文件的不同,然后记录下来,也就是所谓的 diff 补丁。
diff [options] from-file to-file
from-file:源文件
to-file:根据源文件修改后的文件
option:
-u 显示有差异行的前后几行(上下文), 默认是前后各 3 行, 这样, patch 中带有更多的信息
-p 显示代码所在的 c 函数的信息
-N 选项确保补丁文件将正确地处理已经创建或删除文件的情况
-a 逐行比较文本文件
-r 比较子目录中的文件
两个文件:需要打补丁的文件 a.c 和 patch 文件 test.patch
打补丁命令如下:
patch a.c < test.patch
实际操作如下:
补充:
patch -RE < test.patch 取消 patch 对源文件的修改
patch -p1 < test.patch
p 表示跳过几级目录,0 标识不去掉为全路径,1 标识去掉第一层路径。路径信息包含了你的 Linux 源码根目录的名称,但其他人的源码根目录可能是其它名字,所以,打补丁时,要进入你的 Linux 源码根目录,并且告诉 patch 工具,请忽略补丁中的路径的第一级目录。
注意:patch -p 后面是不能带负数 的。不使用 p 参数的时候,patch 命令会 忽略 任何目录,直接使用文件。
多文件打 patch
本文是两个文件做比较,打 patch,比较简单。如果是一个工程,有多个文件修改,需要在 diff 后面增加两个属性:
-r 递归地对比一个目录和它的所有子目录(即整个目录树).
-N 如果某个文件缺少了,就当作是空文件来对比. 如果不使用本选项,当 diff 发现旧代码或者新代码缺少文件时,只简单的提示缺少文件。如果使用本选项,会将新添加的文件全新打印出来作为新增的部分。
全部0条评论
快来发表一下你的评论吧 !