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

    1. 111111
    2. 222222
    3. 333333
    4. 444444
    5. 555555
  2. 在NewFloder存在文件test.txt

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

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

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

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

    1. 111111 add here
    2. delete 222222 here
    3. 33 change 33
    4. 444444
    5. 555555
  7. 例子解析

    1. diff -urN OldFloder/test.txt NewFloder/test.txt
    2. --- OldFloder/test.txt 2018-09-20 21:15:40.576162357 +0800
    3. +++ NewFloder/test.txt 2018-09-20 21:17:02.747161577 +0800
    4. @@ -1,5 +1,5 @@
    5. -111111
    6. -222222
    7. -333333
    8. +111111 add here
    9. +delete 222222 here
    10. +33 change 33
    11. 444444
    12. 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. Codeforces1037G A Game on Strings 【SG函数】【区间DP】

    题目分析: 一开始没想到SG函数,其它想到了就开始敲,后来发现不对才发现了需要SG函数. 把每个字母单独提出来,可以发现有用的区间只有两个字母之间的区间和一个位置到另一个字母的不跨越另一个相同字母的位 ...

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

  3. quartus prime 16.0 报警告 inferring latch

    前言 当写always组合逻辑块时,可能会写出 poor code.综合时软件会推断出锁存器.例如下面代码: always @* begin 'b1) begin w = (a & b) ^ ...

  4. 【XSY2691】中关村 卢卡斯定理 数位DP

    题目描述 在一个\(k\)维空间中,每个整点被黑白染色.对于一个坐标为\((x_1,x_2,\ldots,x_k)\)的点,他的颜色我们通过如下方式计算: 如果存在一维坐标是\(0\),则颜色是黑色. ...

  5. MySQL中 如何查询表名中包含某字段的表

    查询tablename 数据库中 以"_copy" 结尾的表 select table_name from information_schema.tables where tabl ...

  6. Android GPS定位测试(附效果图)

    今天因为工作需要,把以前编写的一个GPS测试程序拿出来重新修改了一下.这个程序说起来有些历史了,是我11年编写的,那时候学了Android开发没多久,算是一个实验性的作品.现在工作需要,重新拿出来修整 ...

  7. NOIP引水入城(dfs)

    为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施.水利设施有两种,分别为蓄水厂和输水站.蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中. 因此,只有与湖泊毗邻的第1 行的 ...

  8. A.01.01—模块的输入—低端输入

    汽车电子模块的输入一般包含数字量低端输入.数字量高端输入.模拟量输入.脉宽调制输入.总线信号输入.脉冲信号输入,对于无线信号输入和视频信号音频信号我们不做讨论. 数字量低端输入是应用最为广泛的一种输入 ...

  9. centos7安装mha4mysql

    mysql搭建mha需要用的两个rpm包.(manager包和node包) 下载地址:https://download.csdn.net/download/dajdajdajdaj/10603389 ...

  10. C语言中的类型转换——将字符串s转换为整数型(int)类型

    在讲类型转换之前,我们先要理解下C语言中单引号和双引号的区别. 先讲双引号,双引号就是字符串,我们要证实我们的想法,我选择写一段代码看看开: #include <stdio.h> int ...