title: diff补丁格式

tags: 学习

categories: 学习

date: 2018-09-20 21:03:53

diff补丁格式

在Uboot学习中,接触到了打补丁这个操作,首先来学习下diff的patch文件格式.

命令参数

diff

  1. ”-u”:表示在比较结果中输出上下文中一些相同的行
  2. “-r“:表示递归比较各个子目录下的文件
  3. “-N“:将不存在的文件当作空文件
  4. “-w“:忽略空格的比较
  5. “-B“:忽略空行的比较

patch

  1. -pn,表示忽略diff命令中原文件路径中的几层父目录,-p1表示忽略第一个父目录

补丁文件内容

  1. 第一行,首先指定文件目录路径个比对参数
  2. 第二行,---.....表示原来的文件
  3. 第三行,+++....表示新文件
  4. 第四行一般是被 @@...@@包含的内容,比如@@ -206,8 +206,8 @@: -206表示原来的第206行,8表示总共8行,+206表示这是从新文件的206行,总共也有8行
  5. 文件内容中-表示删除这一行,+表示新增这一行,无+-表示保持原来的

制作补丁

使用命令 diff -urN oldFloder NewFloder > mypatch.diff,其中oldFloder为原旧文件,NewFloder为新文件,生成补丁mypatch.diff

应用补丁

使用命令patch 来应用补丁

例子

  1. 在OldFloder存在文件test.txt

    111111
    222222
    333333
    444444
    555555
  2. 在NewFloder存在文件test.txt

    111111 add here
    delete 222222 here
    33 change 33
    444444
    555555
  3. 为OldFloder创建补丁diff -urN OldFloder NewFloder > test.diff

  4. 查看下补丁的内容cat test.diff

    diff -urN OldFloder/test.txt NewFloder/test.txt
    --- OldFloder/test.txt 2018-09-20 21:15:40.576162357 +0800
    +++ NewFloder/test.txt 2018-09-20 21:17:02.747161577 +0800
    @@ -1,5 +1,5 @@
    -111111
    -222222
    -333333
    +111111 add here
    +delete 222222 here
    +33 change 33
    444444
    555555
  5. 应用补丁,patch -p1 < ../test.diff,命令前面的 -p1表示忽略路径中第1个父目录,我们这里是在OldFloder中应用的,所以是p

  6. 查看在OldFloder中的文件cat test.txt,可以发现已经应用成功

    111111 add here
    delete 222222 here
    33 change 33
    444444
    555555
  7. 例子解析

    diff -urN OldFloder/test.txt NewFloder/test.txt
    --- OldFloder/test.txt 2018-09-20 21:15:40.576162357 +0800
    +++ NewFloder/test.txt 2018-09-20 21:17:02.747161577 +0800
    @@ -1,5 +1,5 @@
    -111111
    -222222
    -333333
    +111111 add here
    +delete 222222 here
    +33 change 33
    444444
    555555
    • @@ -1,5 +1,5 @@表示原来文件的第1行开始,总共有5行,新文件从第1行开始,总共有5行
    • -111111表示删除原文件这一行
    • -222222表示删除原文这一行
    • -333333表示删除原文这一行
    • 后面三个+++....表示新增这一行
    • 接下去的44444455555表示不更改
    • 这么减了三行,去除三行,然后再保留原来的两行444444555555,总共还是5行

diff补丁格式的更多相关文章

  1. nginx补丁格式说明(CVE-2016-4450为例)

    nginx安全公告地址:http://nginx.org/en/security_advisories.html CVE-2016-4450:一个特定构造的数据包,可引发nginx引用空指针,导致ng ...

  2. u-boot(一)启动简介

    目录 u-boot(一)启动简介 启动概述 内部存储布局 Bootloader概述 内核启动参数 taggedlist 体验一下实际的Uboot U-boot的使用帮助 U-boot基本要求 titl ...

  3. 精《Linux内核精髓:精通Linux内核必会的75个绝技》一HACK #5 使用checkpatch.pl检查补丁的格式

    HACK #5 使用checkpatch.pl检查补丁的格式 本节介绍发布前检查补丁格式的方法.Linux内核是由多个开发者进行开发的.因此,为了保持补丁评估与源代码的可读性,按照统一的规则进行编写是 ...

  4. git apply、git am打补丁.diff 和 .patch【转】

    本文转载自:https://www.jianshu.com/p/e5d801b936b6 前提: 生成patch: git format-patch -M master 生成指定patch,0163b ...

  5. Git命令diff格式详解

    diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...

  6. uboot补丁的使用

    在u-boot跟linux内核(台湾叫核心)编译过程中, 有个东西叫补丁, 其实通过某些补丁文件, 可以知道它对原始的版本做过哪些修改, 比前面那个帖子的挨个文件挨个文件的修改, 显得要高级那么一丢丢 ...

  7. linux patch 格式与说明(收录)

    转:http://blog.chinaunix.net/uid-26813001-id-3282954.html 首先介绍一下diff和patch.在这里不会把man在线文档上所有的选项都介绍一下,那 ...

  8. Linux diff patch

    /***************************************************************************** * Linux diff patch * ...

  9. linux常用命令--diff

    diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...

随机推荐

  1. NAND闪存供过于求的情况今年会有所好转吗?

    2018年,NAND闪存全年供过于求,价格一直下跌,导致西数.东芝等厂商毛利率大幅下滑.如今到了2019年,情况会有所好转吗? 近日,集邦科技旗下半导体研究中心DRAMeXchange发布调查报告指出 ...

  2. BZOJ3876[Ahoi2014&Jsoi2014]支线剧情——有上下界的最小费用最大流

    题目描述 [故事背景] 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩怨情仇的剧情.这些游戏往往 都有很多的支线剧情,现在JYY想花费 ...

  3. BZOJ2038[2009国家集训队]小Z的袜子(hose)——莫队

    题目描述 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜子从1到N编号 ...

  4. POJ 3264-Balanced Lineup-RMQ问题

    裸RMQ问题 #include <cstdio> #include <algorithm> #include <cstring> using namespace s ...

  5. jsp小测试--猜大小

    page1.jpg: <%@ page language="java" import="java.util.*" pageEncoding="g ...

  6. 为什么开启子进程 一定要放在 if __name__ == '__main__' 下面

  7. Edge Deletion CodeForces - 1076D(水最短路)

    题意: 设从1到每个点的最短距离为d,求删除几条边后仍然使1到每个点的距离为d,使得剩下的边最多为k 解析: 先求来一遍spfa,然后bfs遍历每条路,如果d[v] == d[u] + Node[i] ...

  8. PHP错误代号列表

    代号 代号 语法 参考 T_ABSTRACT abstract 抽象类(自 PHP 5.0.0 起可用) T_AND_EQUAL &= 赋值运算符 T_ARRAY array() array( ...

  9. TypeError: __init__() got an unexpected keyword argument 't_command'

    python  .\manage.py migrate 报错如下 λ python .\manage.py migrateTraceback (most recent call last): File ...

  10. 压缩JS,CSS的工具

    目标: 压缩项目中的JS,CSS文件. 方法一:使用uglifyjs uglifycss 压缩JS: 1.安装NODEJS.是一个在服务端运行的JS语言.下载地址https://nodejs.org/ ...