quilt基本使用

news2025/2/25 15:48:03

一、简介

quilt是制作补丁和管理的工具。比如想用开源代码做一些项目,我们如果直接在开源代码里进行修改,等到下次开源代码升级后,我们再将我们修改的部分转移到新版本的开源代码中就需要进行大量的新旧版本对比工作。那如果我们将这些改动使用补丁管理起来,待开源代码升级后,直接将这些补丁打到新源码中即可。

 

二、使用过程

2.1 环境准备

环境中没有quilt命令,ubuntu系统可以使用apt-get install quilt命令下载quilt工具。

假设现在环境中仅有一个文件tset.c,文件内容如下:

#include <stdlib.h>
#include <stdio.h> 

void main(char* args)
{
     printf("Hello world!");
}

2.2 创建一个patch文件过程

第一步quilt new test.patch创建一个patch,命令执行结束之后,当前目录下会出现一个patches和隐藏目录.pc,具体的内容如下:

 

patches 目录下 有一个 series 文件, cat查看发现里面记录了 test.patch, 是用来记录使用patch的顺序,使用的堆栈的记录方式;

.pc 是由quilt自己维护的,我们不用管。

要知道上面的new命令并没有创建文件,只是在Series里增加了记录,top栈顶指针当前指向的是该patch,可以使用quilt top命令查看当前的栈顶patch。

第二步使用quilt add <filename>添加关联patch文件。

生成patch的目的是为了为现有代码文件(test.c)打补丁,但又不是直接在test.c上修改,因此需要将补丁文件(test.patch)与代码文件(test.c)进行关联。这个关联用的是quilt add test.c命令,是将该源码文件添加到补丁环境中,即该文件后面需要打补丁。

注:因为当前最top的patch是test.patch,因此test.c关联的就是test.patch

如果添加错了, 还可以使用quilt remote <filename>将文件移除,然后重新添加。

第三步使用quilt edit <filename>命令编辑文件,进入的时候会让选择编辑器,这个看使用习惯。

可以使用任何编辑器修改文件,但是在修改文件之前最好输入一次quilt edit这个命令,修改文件如下:

#include <stdlib.h>
#include <stdio.h>

int main(void)
{
    printf("Hello world!");
    return 0;
}

第四步修改完代码后我们再使用quilt refresh将改动保存到patch中,这时在patches目录中才会多一个patch文件,这个文件就是我们最开始new新建的文件,内容是记录我们修改之后差异信息,文件内容如下:

 修改后记得一定要用上面的命令,否则无法生成需要的文件。

上面的过程是创建了一个patch文件,如果还需要继续创建新的补丁,需要继续重复上面的步骤,当有多个补丁之后,series文件里面就会是如下内容,

然也可以使用quilt series命令查看,如下:

2.3 使用patch

当patch制作好之后,放到另一个新环境中去使用,只需要将patches目录放到对应的工程下,然后使用quilt push -a 即可将所有的patch按照series中的顺序全部打上补丁,如下:

 

果想回退,就可以使用quilt pop往上一个补丁回退一次,如果希望所有的都一次性回退,那么就在后面加个-a选项quilt pop -a,效果如下,这时候如果看相关的代码,就会发现代码已经还原了。

 

 上面是按顺序去使用patch,也使用patch <filename>  <  patches/xxxx.patch可以给指定文件使用指定的patch。但是需要注意,但是可能会出现问题,因为patch可能是依赖于另一个patch的,导致后面正常使用quilt push命令都无法正常使用,另外patch不属于quilt下的命令,所以最好不要指定使用。

2.4 查看一些信息

2.4.1 查看应用/未应用patch

看现在的代码和原代码有点区别,查看使用了哪个patch,使用quilt applied命令查看当前使用了哪个补丁,相反的,看哪些补丁没有被使用,使用quilt unapplied

 

2.4.2  查看有补丁管理的文件

 可以使用quilt files查看当前哪些文件有被quilt所管理,使用quilt patches test.c查看指定文件关联的补丁情况,无论补丁有没有被使用都会关联。

三、问题

3.1 如何重命名patch文件名

使用命令rename

quilt rename [-P patch] <new_name>

例如:

quilt rename -P  patches/00-bt.patch  patches/00-bt-addprint.patch

3.2 在使用patch时, 出现Hunk

  • 现象:

 

  • 问题原因:

这种情况表示patch也是打成功了,但是存在一些偏移,或者上下文不正确的情况。

  • 修改方法:

首先要知道patch中的各部分内容含义,如下是一段patch,其中##后是添加的说明,真实patch中不存在该部分:

Index: src_build/src/detect-engine-loader.c                            ##表示指定的文件
===================================================================
    ##分割符
--- src_build.orig/src/detect-engine-loader.c
+++ src_build/src/detect-engine-loader.c
@@ -44,6 +44,10 @@                    ##表示偏移位置,44表示起始行,6表示原来这里行数;44表示增加patch之后的起始行,10表示增加patch之后这里显示行数
 #include "util-threshold-config.h"    ##表示原文件第44行
内容
 #include "util-path.h"

+#ifdef USE_PATCH                        ##表示增加的内容
+#include "ndr-disable-rule.h"
+#endif
+
 #ifdef HAVE_GLOB_H
 #include <glob.h>
 #endif
@@ -302,6 +306,10 @@ int SigLoadSignatures(DetectEngineCtx *d    ##302表示下面一行在源码中的起始行,306表示上面patch打进去之后下面一行在源码的位置
         fp_engine_analysis_set = SetupFPAnalyzer();
         rule_engine_analysis_set = SetupRuleAnalyzer();
     }
+
+#ifdef USE_PATCH
+    LoadTenantDisableRule(de_ctx);
+#endif

     /* ok, let's load signature files from the general config */
     if (!(sig_file != NULL && sig_file_exclusive == TRUE)) {
Index: src_build/src/detect-sid.c
===================================================================
--- src_build.orig/src/detect-sid.c
+++ src_build/src/detect-sid.c
@@ -31,6 +31,9 @@
 #include "util-debug.h"

... ...

所以修改问题,只需要根据给定的前后行在源码中是否有变化,然后修改行号即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/45109.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

3D视觉应用案例:引导板件定位抓取

3D引导板件定位抓取 某知名模具钢材集团 项目背景 广州某知名模具钢材集团&#xff0c;需求3D引导板件定位抓取和2D识别信息获取功能。原场景用的桁车设备加人工搬运安全系数极低。 作业流程 • 3D相机视觉识别产品位置后&#xff0c;通过机器人电磁铁完成产品的抓取。 •…

大数据 安装配置centOS

安装vmware workstation 启动vmware workstation 启动【编辑】菜单下的“虚拟网络编辑器” 更改VMnet8 查看DHCP设置 查看NAT设置 安装centos7 链接&#xff1a;https://howard2005.blog.csdn.net/article/details/126830182?spm1001.2014.3001.5502 启动虚拟机 虚拟机 查…

代码调优?从Fibonacci数列的7种写法说起,看完coding能力上一个台阶

开启掘金成长之旅&#xff01;这是我参与「掘金日新计划 12 月更文挑战」的第2天&#xff0c;点击查看活动详情 引子 楼梯有 N阶&#xff0c;上楼可以一步上一阶&#xff0c;也可以一步上二阶。 编一个程序&#xff0c;计算共有多少种不同的走法。 例&#xff1a; 0层&…

【毕业设计】28-基于单片机的音乐播放器简易音乐播放器设计(原理图+源代码+仿真工程+答辩PPT+答辩论文)

typora-root-url: ./ 【毕业设计】28-基于单片机的音乐播放器简易音乐播放器设计&#xff08;原理图源代码仿真工程答辩PPT答辩论文&#xff09; 文章目录typora-root-url: ./【毕业设计】28-基于单片机的音乐播放器简易音乐播放器设计&#xff08;原理图源代码仿真工程答辩PP…

麦芽糖-聚乙二醇-甲氨蝶呤 MTX-PEG-maltose

麦芽糖-聚乙二醇-甲氨蝶呤 MTX-PEG-maltose 中文名称&#xff1a;麦芽糖-甲氨蝶呤 英文名称&#xff1a;maltose-MTX 别称&#xff1a;甲氨蝶呤修饰麦芽糖&#xff0c;甲氨蝶呤-麦芽糖 PEG接枝修饰麦芽糖&#xff0c;麦芽糖-聚乙二醇-甲氨蝶呤&#xff0c;MTX-PEG-maltose&…

【visual studio】visual studio 2022 无法 复制黏贴

visual studio 2022 cannot copy paste 其他网友也有反馈到微软&#xff1a;VS 2022 Copy and Paste form feature Broken?Copy paste still not fixed in Visual studio 2022表现是突然就无法复制和黏贴了其他的app 就没有这个问题每次都是重启电脑解决。 2022年11月fix 今…

java中csv导出-追加-列转行

1、问题描述 业务数据量比较大&#xff0c;业务上查询条件写入数据库&#xff0c;java定时去读&#xff0c;然后导出csv&#xff0c;供用户下载&#xff0c;因为有模板要求&#xff0c;前一部分是统计信息&#xff0c;后一部分是明细信息&#xff1b;首先csv中写入统计信息&am…

gradle安装配置

Gradle和Maven都是当前热门的自动化构建工具。 这里以安装6.8版本为例 下载地址 https://services.gradle.org/distributions/ 环境配置 新建系统环境 GRADLE_HOME D:\software\gradle-6.8 新建系统环境 GRADLE_USER_HOME D:\gradle\repository 找到path变量,后面添加 %…

uniapp 短信监听(验证码)插件 Ba-Sms

简介&#xff08;下载地址&#xff09; Ba-Sms 是一款用于拦截实时短信的插件&#xff0c;可以进行短信过滤&#xff0c;得到自己想要的内容&#xff0c;可以用于需要自动填写短信验证码的项目 支持监听当前接收到的短信信息支持过滤接收到的短信&#xff0c;默认过滤4~8位的…

Python学习笔记之进程池pool

平时很多操作都会用到多进程&#xff0c;比如爬虫、数据处理。 下面介绍一下多进程的函数方法、参数及使用方法。 目录 一.进程池Pool介绍 1.apply() 2.apply_async 3.map() 4.map_async() 5.close() 6.terminal() 7.join() 二&#xff0e;进程池Pool使用 1.map用法…

【虚幻引擎UE】UE5 材质动态修改的2种方法(含工程源码)

演示效果&#xff1a; 示例工程源码 一、直接材质参数变量 1、贴图变量&#xff1a; 在材质蓝图中右键&#xff0c;创建变量TextureSampeParameter2D&#xff08;贴图变量&#xff09;。 输入RGB到基础颜色 2、单色变量&#xff1a; 在材质蓝图中右键&#xff0c;创建变量…

[附源码]计算机毕业设计springboot高校商铺管理系统论文

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

要想后期修改少,代码重构要趁早

摘要&#xff1a;在敏捷中&#xff0c;让设计简单化&#xff0c;必须让设计从简单开始&#xff0c;然后变得成熟。要做到这一点&#xff0c;重构是唯一的出路。本文分享自华为云社区《敏捷技术实践之重构》&#xff0c;作者&#xff1a;华为云PaaS服务小智 。 前言 极限编程&…

Flink Forward Asia 2022 主论坛概览

2022 年 11 月 26-27 日&#xff0c;Flink Forward Asia&#xff08;FFA&#xff09;峰会成功举行。Flink Forward Asia 是由 Apache 软件基金会官方授权、由阿里云承办的技术峰会&#xff0c;是目前国内最大的 Apache 顶级项目会议之一&#xff0c;也是 Flink 开发者和使用者的…

使用nohup命令 或者 代码创建守护进程

目录 一、什么是守护进程&#xff1f; 1、守护进程的概念 2、为什么需要守护进程 二、理解进程组、会话、终端 三、创建守护进程的两种方式 1、nohup命令创建守护进程 2、代码创建守护进程 (1) 创建子进程&#xff0c;父进程退出 (2) 子进程创建新的会话 (3) 更改守护…

jsp美食共享平台系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 美食共享平台系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统采用mvc开发结构 serlvetdaobean模式&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用 B/S模式开发。开发环境为TOMCAT7.0,Myecl…

二叉树链式结构-c语言实现

文章目录二叉树链式结构实现1. 链式二叉树结构2. 二叉树的遍历2.1 前序遍历2.2 中序遍历2.3 后序遍历2.4 层序遍历3. 常见功能3.1 二叉树结点个数3.2 二叉树叶子结点个数3.3 第K层结点的个数3.4 二叉树的深度3.5 判断是不是树是不是完全二叉树3.6 在二叉树中查找值为x的结点3.7…

VM系列振弦采集读数模块的测量模式

VM系列振弦采集读数模块的测量模式 模块有连续测量和单次测量两种测量模式&#xff0c; 通过向测量模式寄存器 WKMOD.[0]写入 1 使模块工作于连续测量工作模式&#xff0c; 写入 0 使模块工作于单次测量工作模式。 WKMOD.[15]用来设置是否在模块“ 忙” 时禁用数字接口&#xf…

京东低代码平台:水滴表单联动可视化配置的实现与思考

TL;DR drip-form在0.9.0的alpha版支持了可视化配置联动的功能&#xff08;仍在测试中&#xff09;drip-form通过协议到代码的转换&#xff0c;尽可能降低常见联动配置的开发成本探讨&#xff1a;JSON diff动态生成常见联动和校验drip form的后续更新&#xff1a;v0.9.0是v0最后…

计算机组成原理-总线详细讲解(持续更新中)

总线概念与分类 定义 总线是一组能为多个部件分时共享的公共信息传送线路 共享是指总线上可以挂接多个部件&#xff0c;各个部件之间互相交换的信息都可以通过这组线路分时共享。 分时是指同一时刻只允许有一个部件向总线发送信息&#xff0c;如果系统中有多个部件&#xf…