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

如何打包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 你的软件

如:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面是 Docker 的详细基础教程: ## 什么是 Docker Docker 是一个开源的应用容器引擎,它可以让开发者将应用程序打包成一个容器,然后部署到任何一个支持 Docker 的环境,而不用担心环境的差异性。 ## 安装 Docker 在安装 Docker 之前,需要先安装一个支持 Docker 的操作系统,如 Ubuntu、CentOS、Debian 等,然后按照以下步骤安装 Docker: 1. 添加 Docker 的官方 GPG 密钥: ```shell curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - ``` 2. 添加 Docker 的 APT 软件源: ```shell sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" ``` 3. 更新 APT 软件包索引: ```shell sudo apt-get update ``` 4. 安装 Docker: ```shell sudo apt-get install docker-ce ``` 5. 验证 Docker 是否安装成功: ```shell sudo docker run hello-world ``` 如果输出如下信息,则说明 Docker 安装成功: ``` Hello from Docker! This message shows that your installation appears to be working correctly. ``` ## Docker 基本概念 在使用 Docker 之前,需要了解一些 Docker 的基本概念: ### Docker 镜像 Docker 镜像是一个只读的模板,它可以用来创建 Docker 容器。Docker 镜像是由 Dockerfile 构建而成的,Dockerfile 是一个文本文件,包含了一条条的指令,每条指令都对应着镜像的一层。 ### Docker 容器 Docker 容器是 Docker 镜像的一个运行实例。可以将 Docker 容器看作一个轻量级的虚拟机,它拥有自己的文件系统、网络和进程空间。 ### Docker 仓库 Docker 仓库是用来存储 Docker 镜像的地方,可以将 Docker 仓库看作一个代码仓库,开发者可以将代码提交到仓库,其他开发者可以从仓库拉取代码进行开发。 ### Dockerfile Dockerfile 是一个文本文件,包含了一条条的指令,用来构建 Docker 镜像。 ## Docker 常用命令 以下是 Docker 的常用命令: - `docker images`:列出本地所有的 Docker 镜像。 - `docker pull`:从 Docker 仓库拉取 Docker 镜像。 - `docker run`:创建并启动一个 Docker 容器。 - `docker ps`:列出所有正在运行的 Docker 容器。 - `docker stop`:停止一个正在运行的 Docker 容器。 - `docker rm`:删除一个已经停止的 Docker 容器。 - `docker rmi`:删除一个 Docker 镜像。 - `docker build`:根据 Dockerfile 构建一个 Docker 镜像。 ## Docker 构建镜像流程 以下是 Docker 构建镜像的流程: 1. 编写 Dockerfile; 2. 使用 `docker build` 命令构建 Docker 镜像; 3. 使用 `docker run` 命令创建并启动 Docker 容器。 ## 总结 以上就是 Docker 的详细基础教程,希望对你有所帮助。Docker 是一个非常强大的工具,可以大大简化开发者的部署流程,提高开发效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏有凉风,冬有雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值