diff options
author | kj_sh604 | 2024-06-29 17:27:13 -0400 |
---|---|---|
committer | kj_sh604 | 2024-06-29 17:27:13 -0400 |
commit | 1d54df9a77ca17c325426d09d286768669d80094 (patch) | |
tree | 5291ba92ddfe3e5fa61604e4da30492f1c22ff28 | |
download | aur-1d54df9a77ca17c325426d09d286768669d80094.tar.gz |
feat: add `coreutils-uutils` build to AUR
-rw-r--r-- | .SRCINFO | 33 | ||||
-rw-r--r-- | PKGBUILD | 91 |
2 files changed, 124 insertions, 0 deletions
diff --git a/.SRCINFO b/.SRCINFO new file mode 100644 index 000000000000..aa4b9fd73260 --- /dev/null +++ b/.SRCINFO @@ -0,0 +1,33 @@ +pkgbase = coreutils-uutils + pkgdesc = (warning: use at own risk) Cross-platform Rust rewrite of the GNU coreutils being used as actual system coreutils + pkgver = 0.0.27 + pkgrel = 1 + url = https://www.gnu.org/software/coreutils/ + arch = x86_64 + license = GPL3 + license = MIT + makedepends = rust + makedepends = cargo + makedepends = python-sphinx + depends = glibc + depends = acl + depends = attr + depends = gmp + depends = libcap + depends = openssl + depends = gcc-libs + depends = libkeccak + provides = coreutils + provides = b3sum + provides = sha3sum + conflicts = coreutils + conflicts = coreutils-hybrid + conflicts = coreutils-hybrid-git + conflicts = b3sum + conflicts = sha3sum + source = https://ftp.gnu.org/gnu/coreutils/coreutils-9.5.tar.xz + source = uutils-coreutils-0.0.27.tar.gz::https://github.com/uutils/coreutils/archive/0.0.27.tar.gz + sha512sums = 2ca0deac4dc10a80fd0c6fd131252e99d457fd03b7bd626a6bc74fe5a0529c0a3d48ce1f5da1d3b3a7a150a1ce44f0fbb6b68a6ac543dfd5baa3e71f5d65401c + sha512sums = e798a14a9d24b2ff857588336e4035817445850a1ed5216b1fa5b876082eb0693c7ae535d0106a7aab95690eb0369481308e877f60e39ae67a38b048e73574bd + +pkgname = coreutils-uutils diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..d1fa0cde86f0 --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,91 @@ +# # Maintainer: kj_sh604 <406hs_jk@proton.me> + +pkgname=coreutils-uutils +pkgver=0.0.27 +pkgrel=1 +gnu_coreutils=coreutils +rust_uutils=uutils-coreutils +gnu_coreutils_version=9.5 +rust_uutils_version=0.0.27 +pkgdesc='(warning: use at own risk) Cross-platform Rust rewrite of the GNU coreutils being used as actual system coreutils' +arch=('x86_64') +license=('GPL3' 'MIT') +url='https://www.gnu.org/software/coreutils/' +_url='https://github.com/uutils/coreutils' +depends=('glibc' 'acl' 'attr' 'gmp' 'libcap' 'openssl' 'gcc-libs' 'libkeccak') +conflicts=('coreutils' 'coreutils-hybrid' 'coreutils-hybrid-git' 'b3sum' 'sha3sum') +provides=('coreutils' 'b3sum' 'sha3sum') +makedepends=('rust' 'cargo' 'python-sphinx') +source=("https://ftp.gnu.org/gnu/$gnu_coreutils/$gnu_coreutils-$gnu_coreutils_version.tar.xz" + "$rust_uutils-$rust_uutils_version.tar.gz::$_url/archive/$rust_uutils_version.tar.gz") +sha512sums=('2ca0deac4dc10a80fd0c6fd131252e99d457fd03b7bd626a6bc74fe5a0529c0a3d48ce1f5da1d3b3a7a150a1ce44f0fbb6b68a6ac543dfd5baa3e71f5d65401c' + 'e798a14a9d24b2ff857588336e4035817445850a1ed5216b1fa5b876082eb0693c7ae535d0106a7aab95690eb0369481308e877f60e39ae67a38b048e73574bd') + +prepare() { + cd $gnu_coreutils-$gnu_coreutils_version + # apply patch from the source array (should be a pacman feature) + local filename + for filename in "${source[@]}"; do + if [[ "$filename" =~ \.patch$ ]]; then + echo "Applying patch ${filename##*/}" + patch -p1 -N -i "$srcdir/${filename##*/}" + fi + done + : +} + +build() { + # build gnu coreutils that are not implemented in the MULTICALL rust uutils + cd $gnu_coreutils-$gnu_coreutils_version + ./configure \ + --prefix=/usr \ + --libexecdir=/usr/lib \ + --with-openssl \ + --enable-no-install-program="[,arch,b2sum,base32,base64,basename,basenc,cat,\ + chgrp,chmod,chown,chroot,cksum,comm,cp,csplit,cut,date,dd,df,dir,dircolors,\ + dirname,du,echo,env,expand,expr,factor,false,fmt,fold,head,hostid,id,\ + join,link,ln,logname,ls,md5sum,mkdir,mkfifo,mknod,mktemp,mv,nice,nl,nohup,\ + nproc,numfmt,od,paste,pathchk,pinky,pr,printenv,printf,ptx,pwd,readlink,\ + realpath,rm,rmdir,seq,sha1sum,sha224sum,sha256sum,sha384sum,sha512sum,\ + shred,shuf,sleep,sort,split,stat,stdbuf,sum,sync,tac,tail,tee,test,timeout,\ + touch,tr,true,truncate,tsort,tty,uname,unexpand,uniq,unlink,users,vdir,wc,\ + who,whoami,yes" +} + +package() { + cd $gnu_coreutils-$rust_uutils_version + make \ + DESTDIR="$pkgdir" \ + PREFIX=/usr \ + MANDIR=/share/man/man1 \ + PROG_PREFIX= \ + PROFILE=release \ + MULTICALL=y \ + install + # merge specified gnu coreutils with the rust uutils + cd $srcdir && cd $gnu_coreutils-$gnu_coreutils_version + make DESTDIR="$pkgdir" install + # add libstdbuf.so + mkdir -p $pkgdir/usr/lib/coreutils + cd $srcdir && cd $gnu_coreutils-$rust_uutils_version/target/release/deps + mv liblibstdbuf.so $pkgdir/usr/lib/coreutils/libstdbuf.so + # clean conflicts, arch ships these in other apps + cd $pkgdir/usr/bin + rm groups hostname kill more uptime + # symlink missing binaries + if [ -f "coreutils" ]; then + local binaries=( + "b2sum" "b3sum" "md5sum" "sha1sum" "sha224sum" + "sha256sum" "sha3-224sum" "sha3-256sum" "sha3-384sum" "sha3-512sum" + "sha384sum" "sha3sum" "sha512sum" "shake128sum" "shake256sum" + ) + for bin in "${binaries[@]}"; do + ln -s coreutils "$bin" || echo "warning: failed to create symlink for $bin" + done + else + echo "coreutils binary not found, skipping symlink creation." + fi + # additional cleanup + rm $pkgdir/usr/share/bash-completion/completions/* + rm $pkgdir/usr/share/man/man1/{groups.1,hostname.1,kill.1,more.1,uptime.1} +} |