如何打包arch软件并且打包到arch仓库中(超详细教程)

news2025/1/15 13:38:45

如何打包arch软件并且打包到arch仓库中(超详细教程)

前提一:注册arch账号

略,官网是:https://archlinux.org/

前提二:将本地的ssh-key放入arch账号的ssh秘钥中

终端执行
生成ssh秘钥

ssh-keygen
cd ~/.ssh
cat id_rsa.pub

在这里插入图片描述
将该段复制到arch账号中ssh中
在这里插入图片描述
更新

写PKGBUILD(介绍各个变量含义,有些看看就行,不用太在意)

我习惯复制例子的PKGBUILD文件进行修改,每个qt项目大差不差,而且很简单
PKGBUILD 是一个 shell 脚本.
pkgname,pkgver,pkgrel 和 arch 是必须定义的变量。license在构建包时并不强制要求(会警报)
下面就介绍PKGBuild每个参数的作用,有些是个人理解,有些是直接来自官网的解释

pkgname:

包名

proname:

我自己定义的变量,方便后面使用的

pkgver:

版本,在下面的例子中出现两个:
(1) pkgver=1.1.0
(2) pkgver() {
cd “ s r c d i r / {srcdir}/ srcdir/{pkgname%-git}”
git describe --long --tags | sed ‘s/([^-]*-g)/r\1/;s/-/./g’
}
其中(1)为固定的版本号
(2)其实是浮动版本号,是可以不需要的,且必须git地址存在tag才可使用,否则会报错,一般我们认定tag为代码版本号,那么这里的意思就是如果上游软件更新tag ,如1.2.0,
那么本地安装也会使用上游的版本号1.2.0.**(其中可能git提交的commit前几位,如r513rab之类的)
即:上游更新,我重新安装或升级,会使用上游tag版本。

pkgrel:

我自己也不要清楚这个,似乎有写1,2的,说的第几次打包?

pkgdesc:

程序描述

arch:

适用于的平台,any为所有 其他还有x86_64等等

license:

开源协议

provides:

以下是官方解释
这个序列说明当前包能提供的功能(或者像 cron、sh 这样的虚拟包)。只要没有在 conflicts 序列中被标记,提供相同功能的软件包可以同时安装。注意: 如果你需要使用这个变量,应当加上所替代软件的版本号(
pkgver,可能的话还有pkgrel)。就是说,如果你提供一个修改过的 qt 包其版本号为 3.3.8,命名为 qt-foobar,那么 provides 应该写成 provides=(‘qt=3.3.8’)。如果忽略了版本号,会导致所有依赖于 qt 的某个特定版本的包编译失败。不要把 pkgname 加入 provides 序列。这个操作会自动进行。
conflicts:包冲突,比如simple-image-filter-git和simple-image-filter是同一个软件包,用同样的地址,只是可能版本不一样,所以需要在这里写,该两种软件包是冲突的,不能同时安装。
replaces:我的理解:替代过去的包,也就是装这个会判断系统有没有写的包,替代该包
会因安装当前包而取代的过时的包的列表。比如:wireshark-qt包 中的 replaces=(‘wireshark’)。在同步软件数据库后,pacman 会立刻用软件库中的另一个包替换掉 replaces 中已安装的包。如果你只是提供已存在包的一个替代品,或者上传到 AUR, 请不要使用 replace,而是使用 conflicts 和 provides 两个变量——它们仅在安装冲突软件包时被检查。
如下:

backup:

(我不怎么使用这些)
当包被升级或卸载时,应当备份的文件(的路径)序列。这些文件一般是用户会更改的文件,如主要放置在 /etc 中的配置文件。
列表中的文件应该使用没有绝对路径标识(/)的相对路径(如 etc/pacman.conf),而不是绝对路径(如 /etc/pacman.conf)。
在升级时,新版本会被命名为 file.pacnew 以避免覆盖旧有且被用户修改过的文件。类似地,当卸载包时,用户修改过的文件会以 file.pacsave 为名而保留下来——除非用 pacman -Rn 命令卸载。

options:

这个序列允许你重载 makepkg 的部分定义在 /etc/makepkg.conf 中的默认行为。要设置一个选项,请在序列中指定选项名。要禁用一个默认行为,则还需要在前面加上!。

url:

待打包软件官方站点的网址。

source:

源码包地址,可以是gitee地址,gitbub地址,或者某次release的地址,反正能下载到代码就对了

("${pkgname%-git}::git+${url}.git") 

就是从github下载最新的代码
sha256sums:用于判断md5码是否与文件匹配,如果是固定路径而不是一直拉github最新代码的形式,建议使用,
当然我喜欢跳过检查,直接写SKIP

source=("${pkgname%-git}::git+${url}.git") 
//由PKGBUILD生成.SRCINFO之后可以看到这个地址的直译
simple-image-filter::git+https://github.com/dependon/simple-image-filter.git
//固定路径写法,取pkgver版本的release(需要你的github中有pkgver版本的)
source=("${pkgname}-${pkgver}.tar.gz::${url}/archive/refs/tags/${pkgver}.tar.gz" )
//由PKGBUILD生成.SRCINFO之后可以看到这个地址的直译
source = simple-image-filter-1.1.2.tar.gz::https://github.com/dependon/simple-image-filter/archive/refs/tags/1.1.2.tar.gz
sha256sums = SKIP

install:

安装脚本,我喜欢直接在cmaketext和pro里面写,我不太需要这个,并且package也可以执行install相关功能

官方提供了多种依赖:最重要的depends和makedepends

depends:

运行时和编译时都需要依赖
如例子项目:

 depends=(qt5-tools)

由于qt5-tools已经依赖了qt5的base组件,所以我只需要写qt5-tools即可,其他项目自己看着来

makedepends:

编译时依赖

makedepends=(git
             qconf
             pkgconfig
             make)

由于我们需要执行git命令,所以需要git
qconf和qt有关
pkgconfig基本上都要
make,一般都需要吧

checkdepends:

我的不需要测试所以不用,下面是官网原文
运行测试组件时需要,而运行时不需要的包列表。该列表中的包遵循和 depends 相同的格式。这些依赖只在 check() 函数存在,且被 makepkg 执行时会被处理。

optdepends:

就是推荐一起使用的软件包
可选软件包序列。这些可选软件包不影响软件主要功能,但能提供额外特性。这通常暗示除非安装了对应的可选软件包软件包的个别程序可能无法正常使用[2]。如果软件有一些替代依赖,您可以将其在此处,而不是 depends 序列中,全部列出。
应该简要说明每个包所能提供的额外功能,例如:

optdepends=('cups: printing support'
            'sane: scanners support'
            'libgphoto2: digital cameras support'
            'alsa-lib: sound support'
            'giflib: GIF images support'
            'libjpeg: JPEG images support'
            'libpng: PNG images support')

最后最重要的两项:

build:

生成规则
如我的项目:

   cd "${srcdir}/${pkgname%-git}"
    qmake ./${proname}.pro -spec linux-g++ CONFIG+=qtquickcompiler -o build/
    make -C ./build

到指定目录,qmake一下,make输出到build目录

package:

安装规则
如我的项目:

  cd "${srcdir}/${pkgname%-git}"
    make INSTALL_ROOT="${pkgdir}" -C ./build install

到代码目录,执行make install 安装。

这样,一个PKGBUILD文件就完成了,

PKGBUILD例子1: pro工程

# Contributor: liuminghang <liuminghang0821@gmail.com>

pkgname=simple-image-filter
proname=simple-image-filter-process
pkgver=1.1.2
pkgrel=1
pkgdesc="Deepin DDe simple image filter qt"
arch=('any')
url="https://github.com/dependon/simple-image-filter"
license=('GPLv3')
provides=(${pkgname})
conflicts=(${pkgname} ${pkgname%-git})
#replaces=(${pkgname})
depends=(qt5-tools)
makedepends=(git
             qconf
             pkgconfig
             make)
backup=()
options=('!strip')
#install=${pkgname}.install
source=("${pkgname%-git}::git+${url}.git")
sha256sums=('SKIP')

pkgver() {
    cd "${srcdir}/${pkgname%-git}"
    git describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g'
}

build() {
    cd "${srcdir}/${pkgname%-git}"
    qmake ./${proname}.pro -spec linux-g++ CONFIG+=qtquickcompiler -o build/
    make -C ./build
}

package() {
    cd "${srcdir}/${pkgname%-git}"
    make INSTALL_ROOT="${pkgdir}" -C ./build install
}

在这里插入图片描述

PKGBUILD例子2: cmake工程

# Contributor: liuminghang <liuminghang0821@gmail.com>
pkgname=durian-ocr
srcname=durian-ocr
pkgver=1.0.0.r0.gbf3d465
pkgrel=1
pkgdesc=" durian-ocr is no dtk deepin-ocr. This is a ocr tool ui."
arch=('any')
url="https://github.com/dependon/durian-ocr"
license=('GPLv3')
provides=(${pkgname})
conflicts=(${pkgname} ${pkgname%-git})
depends=(qt5-tools
         )
makedepends=(git
            qconf
            pkgconfig
            cmake
            make)
source=("${pkgname%-git}::git+${url}.git")
sha256sums=('SKIP')

pkgver() {
    cd "${srcdir}/${pkgname%-git}"
    git describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g'
}

build() {
    cd "${srcdir}/${pkgname%-git}"
    cmake -DCMAKE_INSTALL_PREFIX=/usr .
    cmake --build . -j`nproc`
}

package() {
    #cd "${srcdir}/${pkgname%-git}"
    make -C ${srcdir}/${srcname} DESTDIR="$pkgdir" install
}

执行打包测试

接下来我习惯在一个文件夹下,实验正确性

makepkg PKGBUILD

在这里插入图片描述
在这里插入图片描述

由于我的github中tag为1.1.2,加上我写了

pkgver() {
    cd "${srcdir}/${pkgname%-git}"
    git describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g'
}

所以打包不会按照上面的1.1.0来,并且把PKGBUILD同样修改了
在这里插入图片描述
打包完成(其实是测试完成)
相当于证明PKGBUILD没有问题即可

在arch的系统下点击改文件即可安装
在这里插入图片描述

上传到aur软件仓库

对于上传到官方仓库,.tat.zst的本地包不需要

官方仓库只需要PKGBUILD和.SRCINFO
好的,这样就能够打包了
接下来生成.SRCINFO文件(上传aur仓库需要)

makepkg --printsrcinfo > .SRCINFO

在这里插入图片描述

执行git clone ssh://aur@aur.archlinux.org/某项目.git
在这里插入图片描述
放入PKGBUILD和.SRCINFO
接下来add commit push即可
,文件push上去了之后,就能找到你的软件了

在这里插入图片描述

别的电脑怎么安装你的软件

yay -S 你的软件

如:
在这里插入图片描述

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

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

相关文章

Spring Boot 中的授权是什么,如何使用

Spring Boot 中的授权是什么&#xff0c;如何使用 在现代 Web 应用程序开发中&#xff0c;授权是一项至关重要的安全措施。授权是指在用户登录后&#xff0c;对用户进行身份验证&#xff0c;并授予用户访问应用程序特定资源的权限。在 Spring Boot 中&#xff0c;授权是通过 S…

集群 第三章

1. keepalived 功能

UE5打包SDK未正确安装的问题

正文 Windows&#xff08;笔者之前用的电脑是windows10&#xff0c;最新电脑使用的是windows11&#xff09;下UE5打包项目的需要安装Visual Studio。 而且安装的时候需要选择上C 游戏开发相关模块。如下图所示&#xff1a; 有时候安装了Visual Studio 之后&#xff0c;还是不能…

使用Stable Diffusion生成艺术二维码

在数字艺术的世界中&#xff0c;二维码已经从单纯的信息承载工具转变为可以展示艺术表达的媒介。这是通过使用Stable Diffusion的技术实现的&#xff0c;它可以将任何二维码转化为独特的艺术作品。接下来&#xff0c;我们将一步步教你如何使用Stable Diffusion生成艺术二维码。…

有私域和无私域的区别?

公域流量和私域流量的区别 (1)渠道区别&#xff1a;私域流量的流量池是个体独有的&#xff0c;而公域流量的流量池是公共的。简单说&#xff0c;私域流量是借助个人平台直接获取用户的渠道&#xff0c;而公域流量是要凭借一个公共的平台&#xff0c;依托平台的流量来获取用户。…

极智开发 | 教你gitlab管理员密码忘了怎么办

欢迎关注我的公众号 [极智视界]&#xff0c;获取我的更多经验分享 大家好&#xff0c;我是极智视界&#xff0c;本文介绍一下 教你gitlab管理员密码忘了怎么办。 邀您加入我的知识星球「极智视界」&#xff0c;星球内有超多好玩的项目实战源码和资源下载&#xff0c;链接&…

Ubuntu系统下用VSCode断点调试C++代码

文章目录 0 引言1 创建vsdebug工程1.1 创建文件夹和文件1.2 C代码1.3 CMakeLists.txt1.4 build.sh脚本 2 VSCode配置文件2.1 tasks.json2.2 launch.json 3 编译运行和调试3.1 编译运行3.2 调试 0 引言 Ubuntu下不能像Windows下使用Visual Studio那样方便Debug调试C代码&#x…

C++图形开发(9):静止的矩形(fillrectangle函数)

我们的graphics库提供了一个用于绘制矩形的函数&#xff0c;它就是…… fillectangle();其格式为&#xff1a; fillectangle(矩形左上角的x坐标,矩形左上角的y坐标&#xff0c;x方向的距离&#xff0c;y方向的距离);举个栗子&#xff1a; #include<graphics.h> #inclu…

Feign 调用报 RequestParam.value() was empty on parameter 0

详细报错: FactoryBean threw exception on object creation; nested exception is java.lang.IllegalStateException: RequestParam.value() was empty on parameter 0 背景 最近在使用 RequestParam、RequestBody 注解定义 feign 接口的时候出现一些使用上的问题&#xff…

Ceph:关于Ceph 集群中数据分布和容灾理论的一些笔记

写在前面 准备考试&#xff0c;整理 Ceph 相关笔记博文内容涉及,Ceph 集群中数据如何分布以及不同的容灾池介绍理解不足小伙伴帮忙指正 对每个人而言&#xff0c;真正的职责只有一个&#xff1a;找到自我。然后在心中坚守其一生&#xff0c;全心全意&#xff0c;永不停息。所有…

【MySQL系列】数据库基础学习_简单认识数据库

「前言」文章内容大致是数据库基础&#xff0c;以及数据库的基本知识。 「归属专栏」MySQL 「主页链接」个人主页 「笔者」枫叶先生(fy) 「枫叶先生有点文青病」「句子分享」 我见青山多妩媚&#xff0c;料青山、见我应如是。 ——辛弃疾《贺新郎》 目录 一、连接MySQL服务器二…

hcip第三次作业

1、合理规划IP地址&#xff0c;启用OSPF单区域。 2、R1-R2之间启用PPP的PAP单向认证。 把R1作为主认证方 然后在R2处做添加——帐号、密码 接口处于双UP的状态&#xff0c;证明认证成功 3、R2-R3之间启用PPP的chap双向认证 R2作为主认证方。 此时4/0/1口处于up - down状态 然…

Zabbix6.0 的部署、自定义监控服务

目录 一、概述 二、 zabbix 1.zabbix简介 2.zabbix监控原理 3. Zabbix 6.0 新特性 3.1Zabbix server高可用防止硬件故障或计划维护期的停机 3.2 Zabbix 6.0 LTS新增Kubernetes监控功能&#xff0c;可以在Kubernetes系统从多个维度采集指标 4. Zabbix 6.0 功能组件 4.1…

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:/

-XX:HeapDumpOnOutOfMemoryError -XX:HeapDumpPathD:/在内存溢出时导出整个堆信息 指定导出堆的存放路径(D:/java_customName.hprof)&#xff0c;可以自定义dump名字&#xff1b;自定义名字时重复执行dump文件貌似不会覆盖(D:/)&#xff0c;只指定路径会自动生成Dump文件&…

10G CWDM和DWDM的优势和应用场景解析

10G CWDM和10G DWDM光模块都是用于光纤通信系统的传输技术&#xff0c;它们在光纤网络中使用不同的光波分复用技术。本期文章我们通过分析10G CWDM SFP和10G DWDM SFP两种光模块进行区别对比。 一、10G CWDM和DWDM光模块参数区别对比 二、易天光通信10G CWDM和DWDM光模块优势对…

品牌从0到1,中小企业如何在市场中脱颖而出?

道叔在初创小企业做过品牌&#xff0c;所以对这一块很清楚。在资金有限的中小企业做品牌&#xff0c;并不需要在品牌建设上砸钱&#xff0c;没钱也不是不可以做品牌&#xff0c;不花钱有不花钱的做法。 以下是个人在小企业做品牌的一些实际操作经验&#xff0c;都是干得不能再…

【UnitDOTS 小知识】ChunkComponet存储

ChunkComponet存储 前言 例如&#xff1a;随着人工智能的不断发展&#xff0c;机器学习这门技术也越来越重要&#xff0c;很多人都开启了学习机器学习&#xff0c;本文就介绍了机器学习的基础内容。 一、ChunkComponet的特点 按ChunkComponent按Chunck存储的&#xff0c;他…

C4D和3dmax在不同应用场景下对比,哪个更好用

Maxon Cinema 4D 和Autodesk 3ds Max 是艺术家和工作室在许多领域经常使用的两种最著名的 3D 软件。它们都有不同的功能&#xff0c;在本文中&#xff0c;让我们对它们进行比较。我们将尽力向您概述它们之间的主要区别以及两者的能力。 哪一个更容易使用/学习&#xff1f; Ci…

Java 基础入门篇(四):方法的重载与参数传递机制

文章目录 一、方法的定义二、方法的参数传递机制 ★2.1 基本类型的参数传递2.2 引用类型的参数传递三、方法重载 一、方法的定义 方法的作用&#xff1a;封装一段代码的语法结构&#xff0c;可以被重复调用&#xff0c;以此提高代码的复用性&#xff0c;提高开发效率&#xff0…