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. 如何在Ubuntu 18.04上安装Django

    Django是一个免费的开源高级Python Web框架,旨在帮助开发人员构建安全,可扩展和可维护的Web应用程序. 根据您的需要,有不同的方法来安装Django.它可以使用pip在系统范围内安装或在 ...

  2. Spring 使用介绍(二)—— IoC

    一.简单使用:Hello World实例 1.maven添加依赖 <dependency> <groupId>org.springframework</groupId&g ...

  3. this view is not constrainted......

    this view is not constrainted 解决方案: <EditText android:id="@+id/editText" android:layout ...

  4. Peaceful Commission HDU - 1814(输出最小的一组解)

    Description 根据宪法,Byteland民主共和国的公众和平委员会应该在国会中通过立法程序来创立. 不幸的是,由于某些党派代表之间的不和睦而使得这件事存在障碍. 此委员会必须满足下列条件: ...

  5. 【XSY1602】安全网络 树形DP 数学

    题目大意 有一颗树,要为每个节点赋一个值\(l_i\leq a_i\leq r_i\),使得任意相邻的节点互素.然后对每个节点统计\(a_i\)在所有可能的情况中的和. \(n\leq 50,1\le ...

  6. 【UVALive - 6534 】Join two kingdoms (树的直径的期望)

    bupt spring training for 2015 #2nd J 题意 给两棵树,分别有 n,m 个节点(1 ≤ N, Q ≤ 4 × 10^4),等概率连接属于不同树的两个节点,求新树的直径 ...

  7. 「洛谷1903」「BZOJ2120」「国家集训队」数颜色【带修莫队,树套树】

    题目链接 [BZOJ传送门] [洛谷传送门] 题目大意 单点修改,区间查询有多少种数字. 解法1--树套树 可以直接暴力树套树,我比较懒,不想写. 稍微口胡一下,可以直接来一个树状数组套主席树,也就是 ...

  8. 「TJOI2015」旅游 解题报告

    「TJOI2015」旅游 LCT沙比题 考虑我们其实是在维护一条链的\(\max\limits_{i<j} v_j-v_i\) 每次直接拿左右子树更新一下就可以了 写的时候把两个方向都维护一下, ...

  9. Age of Moyu HDU - 6386 (杭电多校7A)

    给出n和点,m条边,每条边有各自的标号,进入第一个标号需要消耗1的费用,此后转换标号需要1费用,在同一个标号上走不需要费用.问你从1到n最少需要多少费用. 最短路变形,把第一个点看成不存在的标号,然后 ...

  10. cobbler无人值守自动安装

      无人值守安装(自动按定制的需求来批量安装linux系统) kickstart cobbler linux安装系统的方法: 1,光盘 把iso镜像刻录(windows下有类似nero这类软件)到光盘 ...