博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
quilt
阅读量:6554 次
发布时间:2019-06-24

本文共 1481 字,大约阅读时间需要 4 分钟。

1 什么是quilt

quilt是一个patch管理工具,特别适合于对多个patch进行管理。

quilt是基于gnu patch和diff的。

2 使用quilt创建一个patch

第一步,quilt new xxx.patch,创建一个patch文件。

第二步,quilt edit xxx

            quilt edit xxx

            ......

进行各种修改,这些修改将会放在上面创建的patch中。

或者,quilt add xxx,然后直接去修改xxx文件即可。

第三步,quilt refresh

将修改写入patch文件中。

3 已经有了patch,打补丁

原工程目录结构和补丁分别应该放在哪里,另外,quilt push命令要在哪里执行?

关键是.pc和patches目录

所有的patch都放在patches这个目录下。

这个patches目录可以用QUILT_PATCHES环境变量来指定。

.pc目录放在patches同级目录即可。

这样quilt就可以找到patches了,quilt push在任何地方都可以执行。

 

4 关于series文件

这文件一行是一个patch,前面的patch先打,后面的后打。

5 quilt upgrade

因为其它人用的quilt的版本可能更高,所以,在执行quilt命令前先upgrade一下比较好。

6 打补丁的时候,quilt如何知道该patch是打给哪个文件的

打补丁的时候,是patch在打,首先,这个跟当前的工作目录有关,patch会去当前的工作目录下找要打patch文件,也就是说,patch的目标文件。查找目标文件是相对于当前目录而言的。

然后,还有一个-pN参数和patch文件头路径,比如“linux/Makefile”,如果是-p0,那么直接在当前工作目录下找linux文件夹,然后找linux文件夹下的Makefile文件。如果是-p1,那么直接在当前工作目录下找Makefile文件,也就是说,p1话,会丢掉patch文件头路径的第一个“/”及其之前的路径。同理,pN会丢掉第N个“/”及其之前的路径。

而,quilt在series文件中可以指定该patch的-pN,比如patchRp0.diff -p0,这样quilt就告诉patch,该patch使用-p0。如果在series文件中不指定-pN,quilt默认的是-p1。

所以,信息来自三个地方:第一,当前工作目录;第二,patch文件的头路径;第三, -pN,来自serires文件或者默认。

7 同一个文件被修改了多次,有多个patches,这些patches的行号是如何同最终的文件对应上的?

同一个文件有多个patches时,是按照顺序来打patch的,original文件,先打patch1,变成了orignal+patch1文件,然后在这个文件的基础上打patch2,依次类推。

patch前面的编号,在patch的context格式下,意思不大,它只是提供一个初始定位。当在原始文件中,没有定位到整个context时,patch会弄向前向后偏移去继续定位context。如果还没有找到,它会把context前后减一行,然后继续定位。还没有找到,把context减二行继续定位,还是找不到,返回error,失败。只要找到了,就会打patch。这也是为什么contex格式下,patch的每个hunk前后都有原文件的三行。

 

转载于:https://www.cnblogs.com/hustdc/p/7291804.html

你可能感兴趣的文章
sql语句
查看>>
android 一步一步教你集成tinker(热修复)
查看>>
到底有多少内存
查看>>
centos7.3 安装ovirt-engine4.0 版本
查看>>
putty、xshell的密钥认证
查看>>
Jenkins+git+tomcat 自动化持续部署
查看>>
项目log日志打印
查看>>
Openstack的环境的Mitaka部署环境服务,实例(1)
查看>>
Redis总结(七)Redis运维常用命令
查看>>
常用shell
查看>>
文档的压缩与打包
查看>>
python3 在不同操作系统安装第三方库方法
查看>>
redhat5.8+mfs(提供软件包文档)
查看>>
python编写登录接口
查看>>
MySQL高可用方案之多级复制
查看>>
OVS 中的各种网络设备 - 每天5分钟玩转 OpenStack(128)
查看>>
Python火车票代码
查看>>
Android开发者指南(7) —— App Install Location
查看>>
Trafficserver Cluster模式
查看>>
亚马逊推出 Blox,用于 EC2 容器服务的开源工具集合
查看>>