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 <变动前的文件> <变动后的文件> ...
随机推荐
- hdu-1421(dp)
解题思路:dp[i][j]表示前i个物品中取k对所要的最小花费: 首先得对物品进行处理,因为需要当前物品减前一个物品的平方和最小: 所以先排序,因为排序的相邻两个的差的平方一定最小: 然后转移方程:d ...
- Nginx http keepalive针对客户端行为指令
keepalive 描述 多个http请求可以复用Tcp链接 减少握手次数 通过减少并发连接数减少服务器资源消耗 降低Tcp拥塞控制影响 Syntax: keepalive_disable none ...
- 如何在Ubuntu 18.04上安装Django
Django是一个免费的开源高级Python Web框架,旨在帮助开发人员构建安全,可扩展和可维护的Web应用程序. 根据您的需要,有不同的方法来安装Django.它可以使用pip在系统范围内安装或在 ...
- linux常用命令(个人总结)
1.快捷键: ctrl + l --------------------清屏 ctrl + c --------------------退出当前命令 ctrl + ...
- linux中安装gcc
在使用CentOS的yum -y install 时 可以先进入 /etc/yum.repos.d/ 文件下,将CentOS-Base.repo文件名改为CentOS-Base.repo.bak使 ...
- PHP——运行shell命令|脚本
内置函数 PHP | 系统程序执行 exec shell_exec passthru system 配置 打开php.ini配置文件,并从disable_function将用到的函数从禁用中删除,然后 ...
- 使用开源项目xutils3完成下载
上一次自己写了一个多线程断点续传下载的demo,过于麻烦,bug超多,所以我学习使用xutils来完成此功能. 先将xutils依赖搭建好(上一篇博客已经具体写了方法) 先看看效果图: 下面开始代码的 ...
- 直接使用security.basic.path无效|——springboot2.0以上的security的配置
问题 springcloud 版本 为 Finchley.RELEASEspringboot 版本为 2.0.3.RELEASE 现在有需求,/swagger-ui.html 页面需要添加登录认证,但 ...
- MT【284】构造函数的导数的两类题型
第一类: 已知定义在$R$上的奇函数$f(x),f(-1)=0,$当$x>0$时,$xf^{'}(x)-f(x)<0,$则$f(x)>0$的解集为____ 第二类: 已知函数$f(x ...
- 【BZOJ1188】分裂游戏(博弈论)
[BZOJ1188]分裂游戏(博弈论) 题面 BZOJ 洛谷 题解 这道题目比较神仙. 首先观察结束状态,即\(P\)状态,此时必定是所有的豆子都在最后一个瓶子中. 发现每次的转移一定是拿出一棵豆子, ...