diff补丁格式
title: diff补丁格式
tags: 学习
categories: 学习
date: 2018-09-20 21:03:53
diff补丁格式
在Uboot学习中,接触到了打补丁这个操作,首先来学习下diff的patch文件格式.
命令参数
diff
- ”-u”:表示在比较结果中输出上下文中一些相同的行
- “-r“:表示递归比较各个子目录下的文件
- “-N“:将不存在的文件当作空文件
- “-w“:忽略空格的比较
- “-B“:忽略空行的比较
patch
-pn,表示忽略diff命令中原文件路径中的几层父目录,-p1表示忽略第一个父目录
补丁文件内容
- 第一行,首先指定文件目录路径个比对参数
- 第二行,
---.....表示原来的文件 - 第三行,
+++....表示新文件 - 第四行一般是被
@@...@@包含的内容,比如@@ -206,8 +206,8 @@: -206表示原来的第206行,8表示总共8行,+206表示这是从新文件的206行,总共也有8行 - 文件内容中
-表示删除这一行,+表示新增这一行,无+-表示保持原来的
制作补丁
使用命令 diff -urN oldFloder NewFloder > mypatch.diff,其中oldFloder为原旧文件,NewFloder为新文件,生成补丁mypatch.diff
应用补丁
使用命令patch 来应用补丁
例子
在OldFloder存在文件test.txt
111111
222222
333333
444444
555555
在NewFloder存在文件test.txt
111111 add here
delete 222222 here
33 change 33
444444
555555
为OldFloder创建补丁
diff -urN OldFloder NewFloder > test.diff查看下补丁的内容
cat test.diffdiff -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
应用补丁,
patch -p1 < ../test.diff,命令前面的-p1表示忽略路径中第1个父目录,我们这里是在OldFloder中应用的,所以是p查看在
OldFloder中的文件cat test.txt,可以发现已经应用成功111111 add here
delete 222222 here
33 change 33
444444
555555
例子解析
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表示删除原文这一行- 后面三个
+++....表示新增这一行 - 接下去的
444444和55555表示不更改 - 这么减了三行,去除三行,然后再保留原来的两行
444444和555555,总共还是5行
diff补丁格式的更多相关文章
- nginx补丁格式说明(CVE-2016-4450为例)
nginx安全公告地址:http://nginx.org/en/security_advisories.html CVE-2016-4450:一个特定构造的数据包,可引发nginx引用空指针,导致ng ...
- u-boot(一)启动简介
目录 u-boot(一)启动简介 启动概述 内部存储布局 Bootloader概述 内核启动参数 taggedlist 体验一下实际的Uboot U-boot的使用帮助 U-boot基本要求 titl ...
- 精《Linux内核精髓:精通Linux内核必会的75个绝技》一HACK #5 使用checkpatch.pl检查补丁的格式
HACK #5 使用checkpatch.pl检查补丁的格式 本节介绍发布前检查补丁格式的方法.Linux内核是由多个开发者进行开发的.因此,为了保持补丁评估与源代码的可读性,按照统一的规则进行编写是 ...
- git apply、git am打补丁.diff 和 .patch【转】
本文转载自:https://www.jianshu.com/p/e5d801b936b6 前提: 生成patch: git format-patch -M master 生成指定patch,0163b ...
- Git命令diff格式详解
diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...
- uboot补丁的使用
在u-boot跟linux内核(台湾叫核心)编译过程中, 有个东西叫补丁, 其实通过某些补丁文件, 可以知道它对原始的版本做过哪些修改, 比前面那个帖子的挨个文件挨个文件的修改, 显得要高级那么一丢丢 ...
- linux patch 格式与说明(收录)
转:http://blog.chinaunix.net/uid-26813001-id-3282954.html 首先介绍一下diff和patch.在这里不会把man在线文档上所有的选项都介绍一下,那 ...
- Linux diff patch
/***************************************************************************** * Linux diff patch * ...
- linux常用命令--diff
diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...
随机推荐
- WMS工作原理
图1:创建窗口 图2:通信过程 我们知道其实任何一个窗口的创建,最终都是会创建一个 ViewRootImpl对象.ViewRootImpl 是一很重要的类,类似 ActivityThread 负责跟A ...
- js判断一个元素是否在数组中
js判断一个元素是否在数组中 var arr = ['a','s','d','f']; console.info(isInArray(arr,'a'));//循环的方式 function isInAr ...
- 微信小程序——引入背景图片【六】
前言 之前写了一些小程序的博文只是看文档边看边写,了解下他,这次可是真枪真刀的做了! 框架使用的是美团的mpvue,我也是一边学习,一边写的,如有错误之处,还望大家指出. 在这里我有个问题,为什么微信 ...
- 洛谷P2678跳石头题解
题目 这个题也是一个很经典的题了.其主要思想也是二分答案,原因就是题目中只要出现最大值最小或最小值最大,这种描述十有八九就是二分答案. 这个题原题也是让我们求最短的跳跃距离的最大值. 显而易见,最大值 ...
- 以计算斐波那契数列为例说说动态规划算法(Dynamic Programming Algorithm Overlapping subproblems Optimal substructure Memoization Tabulation)
动态规划(Dynamic Programming)是求解决策过程(decision process)最优化的数学方法.它的名字和动态没有关系,是Richard Bellman为了唬人而取的. 动态规划 ...
- windows 虚拟环境下 安装 mysql 引擎一系列错误处理
报错现象 运行django 报错. 很明显是缺少引擎 下载引擎 django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb m ...
- DNS 透明代理
DNS 透明代理 一.使用DNS负载均衡虚拟服务器(DNS * 53)的方式 --- 推荐使用的方式 注意:只会代理跨内网网段的DNS查询请求 ---------------------------- ...
- Dynamic CRM 2015学习笔记(1)Azure 上安装 CRM 2015
今天终于在Azure上安装成功了CRM 2015,下面简单介绍下安装过程,以及出现问题的解决: 一. 配置AD, 安装IIS 参考下面的link,里面有详细的配置步骤 http://www.c-sha ...
- [JLOI2016/SHOI2016]侦察守卫(树形dp)
小R和B神正在玩一款游戏.这款游戏的地图由N个点和N-1条无向边组成,每条无向边连接两个点,且地图是连通的.换句话说,游戏的地图是一棵有N个节点的树. 游戏中有一种道具叫做侦查守卫,当一名玩家在一个点 ...
- 数据库设计E-R图
项目数据库的设计主要划分为以下6个阶段,本篇主要着重来介绍概念设计阶段 A.系统需求分析阶段B.概念结构设计阶段C.逻辑结构设计阶段D.物理结构设计阶段E.数据库实施阶段F.数据库运行与维护阶段 E- ...