- patch:通过补丁文件,来对原文件打补丁
- diff: 比较两个文件,然后生成一个补丁文件
1.patch用法
patch -p[剥离层级] <[补丁文件]
2.patch命令示例
代码语言:javascript复制cd u-boot-1.1.6/ //进入原文件目录
patch -p1 <../u-boot-1.1.6_jz2440.patach
//“p” 表示去掉补丁文件里路径的第几部分。"1",表示去掉第1个
//“<” 指补丁文件位置
// “../” 表示返回上一个目录,因为这补丁文件和原文件在同一目录下
为什么需要输入-p1?
如下图所示,可以看到补丁文件里,每个需要改的文件,都有u-boot-1.1.6目录,而我们之前已经cd进入了,所以需要输入-p1,去掉它
3.patch文件内容补充
代码语言:javascript复制diff -urN u-boot-1.1.6/common/cmd_bootm.c u-boot-1.1.6_jz2440/common/cmd_bootm.c //绿色代表原文件名以及文件地址,红色代表打上补丁后的新文件名以及地址
--- u-boot-1.1.6/common/cmd_bootm.c 2006-11-02 22:15:01.000000000 0800
u-boot-1.1.6_jz2440/common/cmd_bootm.c 2010-11-26 12:54:38.150155640 0800
//--- 对文件里代码删减 对文件里代码添加
@@ -318,5 318,5 @@ //-318,5 表示在原文件里第318行内有删减,接下来显示5段。 318,5同样类似
//第318行,第一段
switch (hdr->ih_comp) { //第319行,第二段
case IH_COMP_NONE: //第320行,第三段
- if(ntohl(hdr->ih_load) == addr) { //第321行,删减第四段
if(ntohl(hdr->ih_load) == data) { //第322行,增加第五段
4.diff常用参数
- -u: 表示在比较结果中输出上下文中一些相同的行,这有利于人工定位
- -r: 表示递归比较各个子目录下的文件
- -N“:将不存在的文件当作空文件
- -B: 忽略对空行的比较
5.diff命令示例
代码语言:javascript复制 diff -urN u-boot-2012.04.01 u-boot-2012.04.01_new > u-boot-2012.04.01_new.patch
//u-boot-2012.04.01:原文件
//u-boot-2012.04.01_new:修改后的新文件
当一个文件有多个补丁需要打,则使用for循环批处理命令
比如,在tmp/目录下打上../patches/目录下的所有补丁文件:
代码语言:javascript复制cd tmp/
for file in ../patches/*.patch; do patch -p1 < $file; done