AUR 打包自己的软件
打包软件需要两个文件,才能上传自己的应用到AUR仓库。
一个是PKGBUILD,另一个是.SRCINFO。
PKGBUILD需要根据自己软件进行编写,而.SRCINFO则通过PKGBUILD自动生成。
先注册AUR账户,并添加ssh-key。用于通过git走ssh协议推送自己的仓库。
建立一个工作目录,即AUR仓库。
拷贝PKGBUILD模板到工作目录下。
然后根据实际情况进行修改:
# Maintainer: duapple <2832893880@qq.com>
pkgname=genmake
pkgver=0.4.0
pkgrel=2
pkgdesc="generate C/C++/Go Makefile template"
arch=('x86_64')
url="https://gitee.com/duapple/genmake/attach_files/904692/download/genmake"
license=('AGPL-3.0')
depends=()
makedepends=("git")
optdepends=()
source=("${srcdir}/template::git+https://gitee.com/duapple/makefile.git"
"${url}"
"https://gitee.com/duapple/genmake/attach_files/904564/download/genmake_conf.json")
noextract=()
md5sums=("SKIP" "cb3845ee35a1bea7b44daa7a9fef3aaf" "2bb569a143fa683893369eba49e8652c")
prepare() {
rm -rf ${pkgname}-${pkgver}
mkdir -p ${pkgname}-${pkgver}
mv template ${pkgname}-${pkgver}
mv genmake ${pkgname}-${pkgver}
mv genmake_conf.json ${pkgname}-${pkgver}
}
package() {
mkdir -p ${pkgdir}/usr/share/${pkgname}/
mkdir -p ${pkgdir}/usr/share/${pkgname}/config
cd ${pkgname}-${pkgver}
install -Dm777 ${pkgname} ${pkgdir}/usr/bin/${pkgname}
mv template ${pkgdir}/usr/share/${pkgname}/template
cp genmake_conf.json ${pkgdir}/usr/share/${pkgname}/config/
}
写完后,通过namcap PKGBUILD
检验是否正确,然后执行makepkg --printsrcinfo > .SRCINFO
生成.SRCINFO文件。然后提交到仓库中,并推送。直接提交这些修改到本地仓库,然后通过git进行推送。
在提交和推送,最好是自己测试一下,打包生成的应用是否可用。
在工作目录下执行makepkg
,可以生成pacman的安装包,然后通过pacman -U
进行安装和测试。没有问题了再提交。
提交时,只提交PKGBUILD,.SRCINFO,还有.install等,makepkg测试生成的文件一概不进行提交。
推送远程仓库后,yay -S
就可以搜索到我们提交的软件了。软件并不是来自AUR仓库,而是来自gitee,AUR的工作只是收集并打包这些应用,供我们本地安装。
这里分享两个我的小工具:
$ yay -S genmake-bin cformat
Makefile模板生成工具和C/C++格式化工具。