Compare commits

..

44 Commits

Author SHA1 Message Date
2ba8cb4fa5 deploypkg: fix exit code 2023-05-03 23:45:58 +02:00
278a6d17a7 buildtree: fix exit codes 2023-05-03 17:50:19 +02:00
d068fa6b75 Merge pull request 'buildtree: don't strip arch maintainer' (#69) from Dudemanguy/artools:keep-original-maintainer into master
Reviewed-on: #69
2023-05-03 17:47:01 +02:00
70e93c3843 buildtree: don't strip arch maintainer
Instead of completely overwriting the first maintainer line when doing
an import, copy it to the second line and then find/replace maintainer
with contributor.
2023-05-01 20:27:43 -05:00
8a0168cbe5 arch patches 2023-04-30 19:03:11 +02:00
c2082be241 upd makepkg.conf 2023-01-20 00:12:22 +01:00
d5d89cf7a4 commitpkg: small msg change 2022-11-04 18:36:55 +01:00
cc8c2fe38e commitpkg: clean up 2022-11-04 15:10:12 +01:00
9bf2bd2671 commitpkg: drop rebuild check, pipeline now supports skipping add/rm stages if rebuild <--> staging moves, both goblins 2022-11-04 12:01:50 +01:00
eb638abdfe patches (#67)
Reviewed-on: #67
2022-11-03 23:10:30 +01:00
332cc9751b Merge pull request 'buildtree: use git -C when importing packages' (#65) from Dudemanguy/artools:buildtree-use-path into master
Reviewed-on: #65
2022-11-02 18:02:41 +01:00
f86e36c361 buildtree: use git -C when importing packages
This way, the git config credentials that are retrieved correctly match
the actual directory of the package
2022-10-27 13:29:19 -05:00
2edcd2fd54 commitpkg: cp -r on move 2022-07-31 18:23:22 +02:00
80887fba39 commitpkg: cp -r to support keys sub dirs 2022-07-26 18:25:52 +02:00
bd07105192 patches (#64)
Reviewed-on: #64
2022-07-21 18:35:47 +02:00
02edf46d6a buildtree: set maintainer 2022-06-10 00:41:08 +02:00
860d2272ba buildtree: don't braid push ci 2022-06-09 01:26:01 +02:00
0d9e54c4e3 buildtree: braid push the ci fiiles 2022-06-09 00:09:37 +02:00
26bd425d55 buildtree: add func to set maintainer 2022-06-08 10:04:23 +02:00
c08f82044c commitpkg: only run braid update if push is success 2022-06-06 18:05:10 +02:00
74af21ca25 batchpkg: drop -u arg on move 2022-06-06 12:44:21 +02:00
e3b8439b04 commitpkg: fix update msg 2022-06-06 01:35:24 +02:00
e00096d503 braid (#63)
* use braid instead of git-subrepo

Reviewed-on: #63
2022-06-06 01:28:53 +02:00
f7ebc6bd11 mkdepgraph: include mode to graph artix-rebuild-order output 2022-05-28 09:30:37 +02:00
b5fa7084b2 mkdepgraph: remove printf vars 2022-05-27 19:58:03 +02:00
7eabdb0e46 add mkdepgraph 2022-05-27 19:54:00 +02:00
10c013bf33 data: update makepkg.conf 2022-05-27 19:54:00 +02:00
74618d77a5 comparepkg: don't check for result when moving 2022-05-12 13:06:56 +02:00
196761740b repo: rename var 2022-05-09 15:24:05 +02:00
a814655956 repo: simplify find_repo() return 2022-05-08 23:37:02 +02:00
7b03050ab9 comparepkg: rename var 2022-05-08 20:59:38 +02:00
0b1ff8d060 comparepkg: fix var 2022-05-08 19:12:09 +02:00
f66761aa57 comparepkg: use get_group() 2022-05-08 19:10:30 +02:00
f33d9bdac1 artix-chroot: remove obsolete help 2022-05-03 22:54:52 +02:00
f50c66cdd7 artix-chroot: remove -a arg 2022-05-03 22:45:58 +02:00
fd1bc87ef0 makefile: remove compat symlink, remove deploypkg symlinks 2022-05-03 22:45:27 +02:00
9da1ae8e31 jenkins: fix printf arg 2022-05-03 17:20:10 +02:00
52ecf8d463 update default trees used 2022-05-01 12:01:23 +02:00
38fa79e10b update conf 2022-04-28 13:18:53 +02:00
a53fb9e839 artools/0.27 (#62)
* refactoring
* drop echo

Reviewed-on: #62
2022-04-25 17:35:02 +02:00
1d85f8000c buildiso: write defaultBundle map for s6 cal 2022-04-12 16:54:05 +02:00
21c44dba79 checkrepo: update pkg filter 2022-04-11 16:10:57 +02:00
f4e3abae46 buildiso: clean up s6 sv handling 2022-04-11 02:06:20 +02:00
a7cef500ad s6 (#61)
Reviewed-on: #61
Co-authored-by: artoo <artoo@artixlinux.org>
Co-committed-by: artoo <artoo@artixlinux.org>
2022-04-10 20:44:11 +02:00
42 changed files with 1516 additions and 744 deletions

View File

@@ -1,4 +1,4 @@
V=0.26 V=0.28
TOOLS = artools TOOLS = artools
PREFIX ?= /usr PREFIX ?= /usr
@@ -40,7 +40,12 @@ PKG_BIN = \
bin/pkg/batchpkg \ bin/pkg/batchpkg \
bin/pkg/signpkg \ bin/pkg/signpkg \
bin/pkg/checkrepo \ bin/pkg/checkrepo \
bin/pkg/gitearepo bin/pkg/gitearepo \
bin/pkg/tidyarch \
bin/pkg/mkdepgraph \
bin/pkg/diffpkg \
bin/pkg/makerepropkg \
bin/pkg/export-pkgbuild-keys
LN_COMMITPKG = \ LN_COMMITPKG = \
extrapkg \ extrapkg \
@@ -71,20 +76,6 @@ LN_BUILDPKG = \
buildpkg-kde-wobble \ buildpkg-kde-wobble \
buildpkg-gnome-wobble buildpkg-gnome-wobble
LN_DEPLOYPKG = \
deploypkg-system \
deploypkg-world \
deploypkg-gremlins \
deploypkg-goblins \
deploypkg-galaxy \
deploypkg-galaxy-gremlins \
deploypkg-galaxy-goblins \
deploypkg-lib32 \
deploypkg-lib32-gremlins \
deploypkg-lib32-goblins \
deploypkg-kde-wobble \
deploypkg-gnome-wobble
PKG_DATA = \ PKG_DATA = \
data/pacman/makepkg.conf \ data/pacman/makepkg.conf \
data/valid-names.conf data/valid-names.conf
@@ -155,9 +146,6 @@ install_pkg:
for l in $(LN_COMMITPKG); do $(LN) commitpkg $(DESTDIR)$(BINDIR)/$$l; done for l in $(LN_COMMITPKG); do $(LN) commitpkg $(DESTDIR)$(BINDIR)/$$l; done
for l in $(LN_BUILDPKG); do $(LN) buildpkg $(DESTDIR)$(BINDIR)/$$l; done for l in $(LN_BUILDPKG); do $(LN) buildpkg $(DESTDIR)$(BINDIR)/$$l; done
for l in $(LN_DEPLOYPKG); do $(LN) deploypkg $(DESTDIR)$(BINDIR)/$$l; done
$(LN) artix-chroot $(DESTDIR)$(BINDIR)/artools-chroot
install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)
install $(FILEMODE) $(PKG_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS) install $(FILEMODE) $(PKG_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS)

View File

@@ -23,7 +23,7 @@ artools
- pkg: - pkg:
* namcap * namcap
* git-subrepo * ruby-braid
* rsync * rsync
- iso: - iso:

View File

@@ -18,134 +18,34 @@ m4_include(lib/base/message.sh)
m4_include(lib/base/chroot.sh) m4_include(lib/base/chroot.sh)
m4_include(lib/base/mount.sh) m4_include(lib/base/mount.sh)
#{{{ functions
chroot_part_mount() {
msg2 "mount: [%s]" "$2"
mount "$@" && CHROOT_ACTIVE_PART_MOUNTS=("$2" "${CHROOT_ACTIVE_PART_MOUNTS[@]}")
}
chroot_part_umount() {
chroot_api_umount
msg2 "umount: [%s]" "${CHROOT_ACTIVE_PART_MOUNTS[@]}"
umount "${CHROOT_ACTIVE_PART_MOUNTS[@]}"
unset CHROOT_ACTIVE_PART_MOUNTS
}
detect(){
local detected
detected="$(os-prober | tr ' ' '_' | paste -s -d ' ')"
echo "${detected}"
}
# $1: os-prober array
get_os_name(){
local str=$1
str="${str#*:}"
str="${str#*:}"
str="${str%:*}"
echo "$str"
}
mount_os(){
CHROOT_ACTIVE_PART_MOUNTS=()
CHROOT_ACTIVE_MOUNTS=()
trap_setup chroot_part_umount
chroot_part_mount "$2" "$1"
local mounts
mounts=$(perl -ane 'printf("%s:%s\n", @F[0,1]) if $F[0] =~ m#^UUID=#;' "$1"/etc/fstab)
for entry in ${mounts}; do
entry=${entry//UUID=}
local dev=${entry%:*} mp=${entry#*:}
case "${entry#*:}" in
'/'|'swap'|'none') continue ;;
*) chroot_part_mount "/dev/disk/by-uuid/${dev}" "$1${mp}" ;;
esac
done
chroot_setup "$1" true
chroot_add_resolv_conf "$1"
}
select_os(){
local os_list=( "$(detect)" ) count=${#os_list[@]}
if [[ ${count} -gt 1 ]];then
msg "Detected systems:"
local i=0
for os in "${os_list[@]}"; do
local last=${os##*:}
case $last in
'efi') count=$((count-1)) ;;
*) msg2 "$i) $(get_os_name "$os")"; i=$((i+1)) ;;
esac
done
i=0
msg "Select system to mount [0-%s] : " "$((count-1))"
read -r select
else
select=0
fi
local os_str=${os_list[$select]} type
type=$os_str
root=${os_str%%:*}
type=${type##*:}
if [[ "${type##*:}" == 'linux' ]];then
msg "Mounting (%s) [%s]" "$(get_os_name "$os_str")" "$root"
mount_os "$1" "$root"
else
die "You can't mount %s!" "$select"
fi
}
#}}}
automount=false
usage() { usage() {
echo "usage: ${0##*/} -a [or] ${0##*/} chroot-dir [command]" printf 'usage: %s chroot-dir [command]\n' "${0##*/}"
echo ' -a Automount detected linux system' printf ' -h Print this help message\n'
echo ' -h Print this help message' printf '\n'
echo '' printf " If 'command' is unspecified, %s will launch /bin/sh.\n" "${0##*/}"
echo " If 'command' is unspecified, ${0##*/} will launch /bin/sh." printf '\n'
echo '' printf '\n'
echo " If 'automount' is true, ${0##*/} will launch /bin/bash"
echo " and ${chrootdir}."
echo ''
echo ''
exit "$1" exit "$1"
} }
opts=':ha' opts=':h'
while getopts ${opts} arg; do while getopts ${opts} arg; do
case "${arg}" in case "${arg}" in
a) automount=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument ${arg}"; usage 1 ;;
esac esac
done done
shift $(( OPTIND - 1 )) shift $(( OPTIND - 1 ))
check_root check_root
if ${automount};then chrootdir=$1
chrootdir=/mnt shift
run_args=(/bin/bash)
select_os "${chrootdir}" [[ -d ${chrootdir} ]] || die "Can't create chroot on non-directory %s" "${chrootdir}"
else
chrootdir=$1
shift
run_args=("$@")
[[ -d ${chrootdir} ]] || die "Can't create chroot on non-directory %s" "${chrootdir}" chroot_api_mount "${chrootdir}" || die "failed to setup API filesystems in chroot %s" "${chrootdir}"
chroot_add_resolv_conf "${chrootdir}"
chroot_api_mount "${chrootdir}" || die "failed to setup API filesystems in chroot %s" "${chrootdir}" SHELL=/bin/sh unshare --fork --pid chroot "${chrootdir}" "$@"
chroot_add_resolv_conf "${chrootdir}"
fi
SHELL=/bin/sh unshare --fork --pid chroot "${chrootdir}" "${run_args[@]}"

View File

@@ -55,19 +55,19 @@ copymirrorlist=1
pacmode=-Sy pacmode=-Sy
usage() { usage() {
echo "usage: ${0##*/} [options] root [packages...]" printf "usage: %s [options] root [packages...]\n" "${0##*/}"
echo " -C <config> Use an alternate config file for pacman" printf " -C <config> Use an alternate config file for pacman\n"
echo " -c Use the package cache on the host, rather than the target" printf " -c Use the package cache on the host, rather than the target\n"
echo " -G Avoid copying the host's pacman keyring to the target" printf " -G Avoid copying the host's pacman keyring to the target\n"
echo " -i Avoid auto-confirmation of package selections" printf " -i Avoid auto-confirmation of package selections\n"
echo " -M Avoid copying the host's mirrorlist to the target" printf " -M Avoid copying the host's mirrorlist to the target\n"
echo ' -U Use pacman -U to install packages' printf ' -U Use pacman -U to install packages\n'
echo " -h Print this help message" printf " -h Print this help message\n"
echo '' printf '\n'
echo ' basestrap installs packages to the specified new root directory.' printf ' basestrap installs packages to the specified new root directory.\n'
echo ' If no packages are given, basestrap defaults to the "base" group.' printf ' If no packages are given, basestrap defaults to the "base" group.\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -81,8 +81,7 @@ while getopts ${opts} arg; do
G) copykeyring=0 ;; G) copykeyring=0 ;;
M) copymirrorlist=0 ;; M) copymirrorlist=0 ;;
U) pacmode=-U ;; U) pacmode=-U ;;
:) echo "invalid argument ${arg}:$OPTARG"; usage 1;; h|?) usage 0 ;;
?) usage 0 ;;
esac esac
done done
shift $(( OPTIND - 1 )) shift $(( OPTIND - 1 ))

View File

@@ -45,18 +45,18 @@ files=()
mount_args=("-B:/etc/hosts:/etc/hosts") mount_args=("-B:/etc/hosts:/etc/hosts")
usage() { usage() {
echo "Usage: ${0##*/} [options] working-dir [run arguments]" printf "Usage: %s [options] working-dir [run arguments]\n" "${0##*/}"
echo "A wrapper around chroot. Provides support for pacman." printf "A wrapper around chroot. Provides support for pacman.\n"
echo printf '\n'
echo ' options:' printf ' options:\n'
echo ' -C <file> Location of a pacman config file' printf ' -C <file> Location of a pacman config file\n'
echo ' -M <file> Location of a makepkg config file' printf ' -M <file> Location of a makepkg config file\n'
echo ' -c <dir> Set pacman cache' printf ' -c <dir> Set pacman cache\n'
echo ' -f <file> Copy file from the host to the chroot' printf ' -f <file> Copy file from the host to the chroot\n'
echo ' -s Do not run setarch' printf ' -s Do not run setarch\n'
echo ' -b <list> Bind mountargs' printf ' -b <list> Bind mountargs\n'
echo ' List format [mntarg1:src1:dest1 ... mntargN:srcN:destN]' printf ' List format [mntarg1:src1:dest1 ... mntargN:srcN:destN]\n'
echo ' -h This message' printf ' -h This message\n'
exit 1 exit 1
} }
@@ -71,7 +71,6 @@ while getopts ${opts} arg; do
s) nosetarch=1 ;; s) nosetarch=1 ;;
b) bindmounts+=("$OPTARG"); mount_args+=(${bindmounts[@]}) ;; b) bindmounts+=("$OPTARG"); mount_args+=(${bindmounts[@]}) ;;
h|?) usage ;; h|?) usage ;;
*) error "invalid argument '$arg'"; usage ;;
esac esac
done done
shift $(( OPTIND - 1 )) shift $(( OPTIND - 1 ))
@@ -95,7 +94,7 @@ host_mirrors=($(pacman-conf --repo world Server 2> /dev/null | sed -r 's#(.*/)wo
for host_mirror in "${host_mirrors[@]}"; do for host_mirror in "${host_mirrors[@]}"; do
if [[ $host_mirror == *file://* ]]; then if [[ $host_mirror == *file://* ]]; then
# shellcheck disable=2016 # shellcheck disable=2016
host_mirror=$(echo "$host_mirror" | sed -r 's#file://(/.*)/\$repo/os/\$arch#\1#g') host_mirror=$(printf "%s\n" "$host_mirror" | sed -r 's#file://(/.*)/\$repo/os/\$arch#\1#g')
in_array "$host_mirror" "${cache_dirs[@]}" || cache_dirs+=("$host_mirror") in_array "$host_mirror" "${cache_dirs[@]}" || cache_dirs+=("$host_mirror")
fi fi
done done

View File

@@ -23,15 +23,15 @@ files=()
chroot_args=() chroot_args=()
usage() { usage() {
echo "Usage: ${0##*/} [options] working-dir package-list..." printf "Usage: %s [options] working-dir package-list...\n" "${0##*/}"
echo ' options:' printf ' options:\n'
echo ' -U Use pacman -U to install packages' printf ' -U Use pacman -U to install packages\n'
echo ' -C <file> Location of a pacman config file' printf ' -C <file> Location of a pacman config file\n'
echo ' -M <file> Location of a makepkg config file' printf ' -M <file> Location of a makepkg config file\n'
echo ' -c <dir> Set pacman cache' printf ' -c <dir> Set pacman cache\n'
echo ' -f <file> Copy file from the host to the chroot' printf ' -f <file> Copy file from the host to the chroot\n'
echo ' -s Do not run setarch' printf ' -s Do not run setarch\n'
echo ' -h This message' printf ' -h This message\n'
exit 1 exit 1
} }
@@ -46,7 +46,6 @@ while getopts ${opts} arg; do
f) files+=("$OPTARG") ;; f) files+=("$OPTARG") ;;
s) nosetarch=1 ;; s) nosetarch=1 ;;
h|?) usage ;; h|?) usage ;;
*) error "invalid argument '%s'" "$arg"; usage ;;
esac esac
if [[ $arg != U ]]; then if [[ $arg != U ]]; then
chroot_args+=("-$arg") chroot_args+=("-$arg")
@@ -91,13 +90,13 @@ for f in "${files[@]}"; do
cp "$f" "$working_dir$f" cp "$f" "$working_dir$f"
done done
basestrap -${umode}Mc ${pacman_conf:+-C "$pacman_conf"} "$working_dir" \ unshare --mount basestrap -${umode}Mc ${pacman_conf:+-C "$pacman_conf"} "$working_dir" \
"${cache_dirs[@]/#/--cachedir=}" "$@" || die 'Failed to install all packages' "${cache_dirs[@]/#/--cachedir=}" "$@" || die 'Failed to install all packages'
printf '%s.UTF-8 UTF-8\n' en_US de_DE > "$working_dir/etc/locale.gen" printf '%s.UTF-8 UTF-8\n' en_US de_DE > "$working_dir/etc/locale.gen"
echo 'LANG=en_US.UTF-8' > "$working_dir/etc/locale.conf" printf 'LANG=C.UTF-8\n' > "$working_dir/etc/locale.conf"
# echo 'KEYMAP=en' > "$working_dir/etc/vconsole.conf" # printf 'KEYMAP=en\n' > "$working_dir/etc/vconsole.conf"
echo "${CHROOTVERSION}" > "$working_dir/.artools" printf "%s\n" "${CHROOTVERSION}" > "$working_dir/.artools"
dbus-uuidgen --ensure="$working_dir"/etc/machine-id dbus-uuidgen --ensure="$working_dir"/etc/machine-id

View File

@@ -181,7 +181,7 @@ gen_iso_fn(){
for n in "${vars[@]}"; do for n in "${vars[@]}"; do
name=${name:-}${name:+-}${n} name=${name:-}${name:+-}${n}
done done
echo "$name" printf "%s\n" "$name"
} }
prepare_build(){ prepare_build(){
@@ -325,28 +325,28 @@ chroots_iso="${CHROOTS_DIR}/buildiso"
arch=$(uname -m) arch=$(uname -m)
usage() { usage() {
echo "Usage: ${cmd} [options]" printf 'Usage: %s [options]\n' "${cmd}"
echo " -p <profile> Profile [default: ${profile}]" printf ' -p <profile> Profile [default: %s]\n' "${profile}"
echo ' -r <dir> Chroots directory' printf ' -r <dir> Chroots directory\n'
echo " [default: ${chroots_iso}]" printf ' [default: %s]\n' "${chroots_iso}"
echo ' -t <dir> Target directory' printf ' -t <dir> Target directory\n'
echo " [default: ${ISO_POOL}]" printf ' [default: %s]\n' "${ISO_POOL}"
echo ' -i <name> Init system to use' printf ' -i <name> Init system to use\n'
echo " [default: ${INITSYS}]" printf ' [default: %s]\n' "${INITSYS}"
echo ' -g <key> The gpg key for img signing' printf ' -g <key> The gpg key for img signing\n'
echo " [default: none]" printf ' [default: none]\n'
echo ' -m Set SquashFS image mode to persistence' printf ' -m Set SquashFS image mode to persistence\n'
echo ' -c Disable clean work dir' printf ' -c Disable clean work dir\n'
echo ' -x Build chroot only' printf ' -x Build chroot only\n'
echo ' -s Squash chroot only' printf ' -s Squash chroot only\n'
echo ' -b Generate iso boot only' printf ' -b Generate iso boot only\n'
echo ' -z Generate iso only' printf ' -z Generate iso only\n'
echo ' Requires pre built images (-x)' printf ' Requires pre built images (-x)\n'
echo ' -d Use dracut instead of mkinitcpio for iso initramfs' printf ' -d Use dracut instead of mkinitcpio for iso initramfs\n'
echo ' -q Query settings and pretend build' printf ' -q Query settings and pretend build\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -368,7 +368,6 @@ while getopts "${opts}" arg; do
d) use_dracut=true ;; d) use_dracut=true ;;
q) pretend=true ;; q) pretend=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -28,9 +28,9 @@ batch_move() {
src=${src#*:} src=${src#*:}
local dest=${entry%%:*} local dest=${entry%%:*}
if ${runlist}; then if ${runlist}; then
"${dest}"pkg -s "${src}" -u -p "${pkg}" "${dest}"pkg -s "${src}" -p "${pkg}"
else else
msg "%s" "${dest}pkg -s ${src} -u -p ${pkg}" msg "%s" "${dest}pkg -s ${src} -p ${pkg}"
fi fi
done < "$pkglist" done < "$pkglist"
} }
@@ -65,10 +65,10 @@ batch_update() {
local dest=${entry%:*} local dest=${entry%:*}
if ${runlist}; then if ${runlist}; then
buildtree -i -p "${pkg}" buildtree -i -p "${pkg}"
"${dest}"pkg -u -p "${pkg}" "${dest}"pkg -p "${pkg}"
else else
msg "buildtree -i -p ${pkg}" msg "buildtree -i -p ${pkg}"
msg2 "${dest}pkg -u -p ${pkg}" msg2 "${dest}pkg -p ${pkg}"
fi fi
done < "$pkglist" done < "$pkglist"
} }
@@ -76,13 +76,13 @@ batch_update() {
#}}} #}}}
usage() { usage() {
echo "Usage: ${0##*/} [optional listname]" printf 'Usage: %s [optional listname]\n' "${0##*/}"
echo ' -r Run generated commands' printf ' -r Run generated commands\n'
echo ' -c Create subrepos from list' printf ' -c Create pkgrepos from list\n'
echo ' -u Update subrepos from list' printf ' -u Update pkgrepos from list\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -98,7 +98,6 @@ while getopts "${opts}" arg; do
c) create=true ;; c) create=true ;;
u) update=true ;; u) update=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -29,17 +29,17 @@ chroots_pkg="${CHROOTS_DIR}/buildpkg"
arch=$(uname -m) arch=$(uname -m)
usage() { usage() {
echo "Usage: ${0##*/} [options] -- [mkchrootpkg_args]" printf 'Usage: %s [options] -- [mkchrootpkg_args]\n' "${0##*/}"
echo " -r <dir> Create chroots in this directory" printf ' -r <dir> Create chroots in this directory\n'
echo " -d <dir> Destination repo chroot" printf ' -d <dir> Destination repo chroot\n'
echo ' -c Recreate the chroot before building' printf ' -c Recreate the chroot before building\n'
echo ' -m Major rebuild' printf ' -m Major rebuild\n'
echo ' -N Disable check() function' printf ' -N Disable check() function\n'
echo ' -C Run checkpkg after built' printf ' -C Run checkpkg after built\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo "Default mkchrootpkg_args args: ${mkchrootpkg_args[*]}" printf 'Default mkchrootpkg_args args: %s\n' "${mkchrootpkg_args[*]}"
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -54,7 +54,6 @@ while getopts "${opts}" arg; do
C) mkchrootpkg_args+=(-C) ;; C) mkchrootpkg_args+=(-C) ;;
N) mkchrootpkg_args+=(-N) ;; N) mkchrootpkg_args+=(-N) ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '%s'" "${arg}"; usage 1 ;;
esac esac
done done

View File

@@ -23,88 +23,85 @@ m4_include(lib/pkg/jenkins.sh)
#{{{ new git repo #{{{ new git repo
subrepo_clone(){ pkgrepo_new(){
local pkg="$1"
local org="$2"
local name="$3"
msg2 "Subrepo clone [%s] from (%s)" "$pkg" "$org/$name"
git subrepo clone "${GIT_SSH}":"$org"/"$name".git "$pkg"
}
subrepo_new(){
cd "${TREE_DIR_ARTIX}/${group}" || return cd "${TREE_DIR_ARTIX}/${group}" || return
local org gitname local org gitname
org=$(get_pkg_org "${package}") org=$(get_pkg_org "${package}")
gitname=$(get_compliant_name "${package}") gitname=$(get_compliant_name "${package}")
gitearepo -cr "$gitname" if [[ ! -d "${package}" ]]; then
gitearepo -cr "$gitname"
add_team_to_repo "$gitname" "$org" "${team}" add_team_to_repo "$gitname" "$org" "${team}"
subrepo_clone "${package}" "$org" "$gitname" msg2 "Adding [%s] from (%s)" "${package}" "$org/$gitname"
braid add "${GIT_SSH}":"$org/$gitname".git "${package}"
mkdir -p "${TREE_DIR_ARTIX}/${group}/${package}/trunk" prepare_dir "${TREE_DIR_ARTIX}/${group}/${package}/trunk"
commit_jenkins_files "${package}" commit_ci "${package}"
# if braid push "${package}"; then
# braid update "${package}"
# fi
else
die "Package %s already exists!" "${package}"
fi
} }
#}}} #}}}
#{{{ pull #{{{ pull
clone_tree(){ config_tree() {
local url="$1" tree="$2" os="${3:-Artix}" local dist="$1" vars="${2:-false}"
case "$dist" in
msg "Cloning %s (%s) ..." "$tree" "$os" Artix)
if "$vars"; then
git clone "$url/$tree".git dist_tree=("${ARTIX_TREE[@]}")
dist_url="${GIT_SSH}:pkgbuild"
dist_dir=${TREE_DIR_ARTIX}
else
git config --bool pull.rebase true
git config commit.gpgsign true
if [[ -n "${GPGKEY}" ]];then
git config user.signingkey "${GPGKEY}"
else
warning "No GPGKEY configured in makepkg.conf!"
fi
fi
;;
Arch)
if "$vars"; then
dist_tree=("${ARCH_TREE[@]}")
dist_url="${HOST_TREE_ARCH}"
dist_dir=${TREE_DIR_ARCH}
else
git config --bool pull.rebase false
git config branch.master.mergeoptions --no-edit
fi
;;
esac
} }
pull_tree_arch(){ update_tree() {
cd "${TREE_DIR_ARCH}" || return local dist="${1:-Artix}"
for tree in "${ARCH_TREE[@]}";do config_tree "$dist" true
if [[ -d "${tree}" ]];then cd "$dist_dir" || return
( cd "${tree}" || return for tree in "${dist_tree[@]}"; do
pull_tree "${tree}" "$(get_local_head)" "Arch" if [[ -d "$tree" ]]; then
( cd "$tree" || return
config_tree "$dist"
msg "Checking (%s) (%s)" "$tree" "$dist"
pull_tree "$tree" "$(get_local_head)"
) )
else else
clone_tree "${HOST_TREE_ARCH}" "${tree}" "Arch" msg "Cloning (%s) (%s) ..." "$tree" "$dist"
fi git clone "$dist_url/$tree".git
done ( cd "$tree" || return
} config_tree "$dist"
config_tree(){
local tree="$1"
cd "$tree" || return
git config --bool pull.rebase true
git config commit.gpgsign true
if [[ -n "${GPGKEY}" ]];then
git config user.signingkey "${GPGKEY}"
else
warning "No GPGKEY configured in makepkg.conf!"
fi
cd ..
}
pull_tree_artix(){
local repos=()
if ${sync_group}; then
repos=("${group}")
else
repos=("${ARTIX_TREE[@]}")
fi
cd "${TREE_DIR_ARTIX}" || return
for tree in "${repos[@]}"; do
if [[ -d "${tree}" ]];then
config_tree "${tree}"
( cd "${tree}" || return
pull_tree "${tree}" "$(get_local_head)"
) )
else
clone_tree "${host_tree_artix}" "${tree}"
config_tree "${tree}"
fi fi
done done
} }
@@ -113,11 +110,23 @@ pull_tree_artix(){
#{{{ patch #{{{ patch
set_maintainer() {
local name email path="$1"
name=$(git -C $path config --get user.name)
email=$(git -C $path config --get user.email)
firstline=$(head -n 1 "$path"/PKGBUILD)
sed "2i ${firstline}" -i "$path"/PKGBUILD
sed -e "1s|Maintainer:.*|Maintainer: $name <$email>|" \
-i "$path"/PKGBUILD
sed -e "2s|Maintainer|Contributor|" -i "$path"/PKGBUILD
}
patch_pkg(){ patch_pkg(){
local pkgpath="$1" local pkgpath="$1"
local pkg=${pkgpath%/*} local pkg=${pkgpath%/*}
pkg=${pkg##*/} pkg=${pkg##*/}
sed -e 's|arch-meson|artix-meson|' -i "$pkgpath"/PKGBUILD sed -e 's|arch-meson|artix-meson|' -i "$pkgpath"/PKGBUILD
set_maintainer "$pkgpath"
case $pkg in case $pkg in
glibc) glibc)
msg2 "Patching %s" "$pkg" msg2 "Patching %s" "$pkg"
@@ -199,14 +208,14 @@ from_arch(){
[[ -z $srcpath ]] && die "Package '%s' does not exist!" "${package}" [[ -z $srcpath ]] && die "Package '%s' does not exist!" "${package}"
repo=$(find_repo "$srcpath") repo=$(find_repo "$srcpath")
msg "repo: %s" "${repo#*/}" msg "repo: %s" "$repo"
archpath=$srcpath/$repo archpath=$srcpath/repos/$repo
artixpath=$(find_pkg "${TREE_DIR_ARTIX}" "${package}") artixpath=$(find_pkg "${TREE_DIR_ARTIX}" "${package}")
show_deps "$archpath" show_deps "$archpath"
if [[ -f "$artixpath"/.gitrepo ]]; then if [[ -f "$artixpath"/Jenkinsfile ]]; then
artixpath="$artixpath"/trunk artixpath="$artixpath"/trunk
if [[ -d "$artixpath" ]];then if [[ -d "$artixpath" ]];then
@@ -225,7 +234,7 @@ view_build(){
archpath=$(find_pkg "${TREE_DIR_ARCH}" "${package}") archpath=$(find_pkg "${TREE_DIR_ARCH}" "${package}")
[[ -z $archpath ]] && die "Package '%s' does not exist!" "${package}" [[ -z $archpath ]] && die "Package '%s' does not exist!" "${package}"
repo=$(find_repo "${archpath}") repo=$(find_repo "${archpath}")
archpath=$archpath/$repo archpath=$archpath/repos/$repo
msg "repo: %s" "${repo#*/}" msg "repo: %s" "${repo#*/}"
show_deps "$archpath" show_deps "$archpath"
} }
@@ -243,8 +252,8 @@ check_tree(){
} }
sync_repos(){ sync_repos(){
${sync_arch} && pull_tree_arch ${sync_arch} && update_tree "Arch"
${sync_artix} && pull_tree_artix ${sync_artix} && update_tree
} }
load_makepkg_config load_makepkg_config
@@ -261,7 +270,6 @@ sync_artix=true
import=false import=false
view=false view=false
createnew=false createnew=false
sync_group=false
check=false check=false
package='' package=''
@@ -269,29 +277,27 @@ package=''
team='community' team='community'
group="${ARTIX_TREE[0]}" group="${ARTIX_TREE[0]}"
host_tree_artix="${GIT_SSH}:artixlinux"
usage() { usage() {
echo "Usage: ${0##*/} [options]" printf "Usage: %s [options]\n" "${0##*/}"
echo ' -p <pkg> Package name' printf ' -p <pkg> Package name\n'
echo ' -t <team> Team name (only with -n)' printf ' -t <team> Team name (only with -n)\n'
echo ' Possible values: core,extra,community,multilib' printf ' Possible values: core,extra,community,multilib\n'
echo " [default: ${team}]" printf " [default: %s]\n" "${team}"
echo ' -g <group> Group name, the superrepo (only with -n or -s)' printf ' -g <group> Group name, the superrepo (only with -n)\n'
echo " [default: ${group}]" printf " [default: %s]\n" "${group}"
echo " -s Clone or pull repos" printf " -s Clone or pull repos\n"
echo " -a Don't clone or pull arch repos" printf " -a Don't clone or pull arch repos\n"
echo " -b Don't clone or pull artix repos" printf " -b Don't clone or pull artix repos\n"
echo ' -i Import a package from arch repos' printf ' -i Import a package from arch repos\n'
echo ' -n New remote subrepo and clone it' printf ' -n New remote pkgrepo and add it\n'
echo ' -v Check if a package is in the artix tree(s)' printf ' -v Check if a package is in the artix tree(s)\n'
echo ' -c View package depends' printf ' -c View package depends\n'
echo ' -x Exclude testing (only with -i)' printf ' -x Exclude testing (only with -i)\n'
echo ' -y Exclude staging (only with -i)' printf ' -y Exclude staging (only with -i)\n'
echo ' -z Include kde & gnome unstable (only with -i)' printf ' -z Include kde & gnome unstable (only with -i)\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -301,7 +307,7 @@ while getopts "${opts}" arg; do
case "${arg}" in case "${arg}" in
p) package="$OPTARG" ;; p) package="$OPTARG" ;;
t) team="$OPTARG" ;; t) team="$OPTARG" ;;
g) group="$OPTARG"; sync_group=true ;; g) group="$OPTARG" ;;
s) sync=true ;; s) sync=true ;;
a) sync_arch=false ;; a) sync_arch=false ;;
b) sync_artix=false ;; b) sync_artix=false ;;
@@ -313,7 +319,6 @@ while getopts "${opts}" arg; do
y) staging=false ;; y) staging=false ;;
z) unstable=true ;; z) unstable=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done
@@ -321,12 +326,22 @@ shift $(( OPTIND - 1 ))
set_arch_repos "$testing" "$staging" "$unstable" set_arch_repos "$testing" "$staging" "$unstable"
${sync} && sync_repos if ${sync}; then
sync_repos
fi
${view} && view_build if ${view}; then
view_build
fi
${check} && check_tree if ${check}; then
check_tree
fi
${import} && from_arch if ${import}; then
from_arch
fi
${createnew} && subrepo_new if ${createnew}; then
pkgrepo_new
fi

View File

@@ -13,77 +13,10 @@
# GNU General Public License for more details. # GNU General Public License for more details.
m4_include(lib/base/message.sh) m4_include(lib/base/message.sh)
m4_include(lib/pkg/diff.sh)
shopt -s extglob
load_makepkg_config load_makepkg_config
#{{{ functions
pkgver_equal() {
if [[ $1 = *-* && $2 = *-* ]]; then
# if both versions have a pkgrel, then they must be an exact match
[[ $1 = "$2" ]]
else
# otherwise, trim any pkgrel and compare the bare version.
[[ ${1%%-*} = "${2%%-*}" ]]
fi
}
find_cached_package() {
local searchdirs=("$PKGDEST" "$PWD") results=()
local targetname=$1 targetver=$2 targetarch=$3
local dir pkg pkgbasename name ver rel arch r results
for dir in "${searchdirs[@]}"; do
[[ -d $dir ]] || continue
for pkg in "$dir"/*.pkg.tar?(.!(sig|*.*)); do
[[ -f $pkg ]] || continue
# avoid adding duplicates of the same inode
for r in "${results[@]}"; do
[[ $r -ef $pkg ]] && continue 2
done
# split apart package filename into parts
pkgbasename=${pkg##*/}
pkgbasename=${pkgbasename%.pkg.tar*}
arch=${pkgbasename##*-}
pkgbasename=${pkgbasename%-"$arch"}
rel=${pkgbasename##*-}
pkgbasename=${pkgbasename%-"$rel"}
ver=${pkgbasename##*-}
name=${pkgbasename%-"$ver"}
if [[ $targetname = "$name" && $targetarch = "$arch" ]] &&
pkgver_equal "$targetver" "$ver-$rel"; then
results+=("$pkg")
fi
done
done
case ${#results[*]} in
0)
return 1
;;
1)
printf '%s\n' "${results[0]}"
return 0
;;
*)
error 'Multiple packages found:'
printf '\t%s\n' "${results[@]}" >&2
return 1
;;
esac
}
#}}}
usage() { usage() {
cat <<- _EOF_ cat <<- _EOF_
Usage: ${BASH_SOURCE[0]##*/} [OPTIONS] Usage: ${BASH_SOURCE[0]##*/} [OPTIONS]
@@ -197,7 +130,7 @@ for _pkgname in "${pkgname[@]}"; do
if ! diff_output="$(sdiff -s "$TEMPDIR/libraries-$_pkgname-old" "$TEMPDIR/libraries-$_pkgname")"; then if ! diff_output="$(sdiff -s "$TEMPDIR/libraries-$_pkgname-old" "$TEMPDIR/libraries-$_pkgname")"; then
message="Sonames differ in $_pkgname!" message="Sonames differ in $_pkgname!"
(( WARN )) && warning "$message" || msg "$message" (( WARN )) && warning "$message" || msg "$message"
echo "$diff_output" printf "%s\n" "$diff_output"
else else
msg "No soname differences for %s." "$_pkgname" msg "No soname differences for %s." "$_pkgname"
fi fi

View File

@@ -129,14 +129,14 @@ show_obsolete_table() {
if [[ "$p" != *openrc* ]] && [[ "$p" != *runit* ]] \ if [[ "$p" != *openrc* ]] && [[ "$p" != *runit* ]] \
&& [[ "$p" != *s6* ]] && [[ "$p" != *suite66* ]] \ && [[ "$p" != *s6* ]] && [[ "$p" != *suite66* ]] \
&& [[ "$p" != *eudev* ]] && [[ "$p" != *elogind* ]] \ && [[ "$p" != *udev* ]] && [[ "$p" != *elogind* ]] \
&& [[ "$p" != *sysusers* ]] && [[ "$p" != *tmpfiles* ]] \ && [[ "$p" != *sysusers* ]] && [[ "$p" != *tmpfiles* ]] \
&& [[ "$p" != *execline* ]] && [[ "$p" != *skalibs* ]] \ && [[ "$p" != *execline* ]] && [[ "$p" != *skalibs* ]] \
&& [[ "$p" != *netifrc* ]] && [[ "$p" != *bootlogd* ]] \ && [[ "$p" != *netifrc* ]] && [[ "$p" != *bootlogd* ]] \
&& [[ "$p" != *pam_rundir* ]] && [[ "$p" != *artools* ]] \ && [[ "$p" != *pam_rundir* ]] && [[ "$p" != *artools* ]] \
&& [[ "$p" != *archlinux* ]] && [[ "$p" != *iso-profiles* ]] \ && [[ "$p" != *archlinux* ]] && [[ "$p" != *iso-profiles* ]] \
&& [[ "$p" != *calamares* ]] && [[ "$p" != *iso-initcpio* ]] \ && [[ "$p" != *calamares* ]] && [[ "$p" != *iso-initcpio* ]] \
&& [[ "$p" != *dinit* ]] && [[ "$p" != *artix* ]]; then && [[ "$p" != *dinit* ]] && [[ "$p" != *artix* ]] && [[ "$p" != *blocaled* ]]; then
if [[ ! -d "${arch_db}/$p" ]]; then if [[ ! -d "${arch_db}/$p" ]]; then
msg_row "${tableQ}" "${artix_repo}" "$p" "true" msg_row "${tableQ}" "${artix_repo}" "$p" "true"
fi fi
@@ -209,17 +209,17 @@ searchrepos=(
#}}} #}}}
usage() { usage() {
echo "Usage: ${0##*/} [options] (with -q [libname])" printf "Usage: %s [options] (with -q [libname])\n" "${0##*/}"
echo ' -r <repo> Repo name to query' printf ' -r <repo> Repo name to query\n'
echo ' [default: all]' printf ' [default: all]\n'
echo " -s Sync repo databases" printf " -s Sync repo databases\n"
echo ' -c Check repos' printf ' -c Check repos\n'
echo ' -a Show repo db (-c)' printf ' -a Show repo db (-c)\n'
echo ' -o Check for obsolete packages' printf ' -o Check for obsolete packages\n'
echo " -q Query repo databases for so libs" printf " -q Query repo databases for so libs\n"
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -234,7 +234,6 @@ while getopts "${opts}" arg; do
q) query=true ;; q) query=true ;;
o) obsolete=true ;; o) obsolete=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -22,42 +22,6 @@ m4_include(lib/pkg/repo.sh)
#{{{ functions #{{{ functions
push_tree(){
local tree="$1"
msg "Update (%s)" "${tree}"
git push origin master
}
subrepo_push(){
local pkg="$1"
msg2 "Subrepo push (%s)" "$pkg"
git subrepo push "$pkg" || die "%s push failed" "$pkg"
}
subrepo_clean(){
local pkg="$1"
msg2 "Subrepo clean (%s)" "$pkg"
git subrepo clean "$pkg"
}
subrepo_pull(){
local pkg="$1"
msg2 "Subrepo pull (%s)" "$pkg"
git subrepo pull "$pkg"
}
check_rebuild(){
if [[ -d "$CARCH"/"${valid_names[10]}" ]] \
&& [[ "${repo_dest}" == "${valid_names[7]}" ]]; then
git rm -r "$CARCH"/"${valid_names[10]}"
git commit -m "switch from ${valid_names[10]} to ${valid_names[7]}"
elif [[ -d "$CARCH"/"${valid_names[7]}" ]] \
&& [[ "${repo_dest}" == "${valid_names[10]}" ]]; then
git rm -r "$CARCH"/"${valid_names[7]}"
git commit -m "switch from ${valid_names[7]} to ${valid_names[10]}"
fi
}
check_team(){ check_team(){
if [[ "${repo_src}" == "${valid_names[0]}" && "${repo_dest}" == "${valid_names[1]}" ]] || \ if [[ "${repo_src}" == "${valid_names[0]}" && "${repo_dest}" == "${valid_names[1]}" ]] || \
[[ "${repo_src}" == "${valid_names[1]}" && "${repo_dest}" == "${valid_names[0]}" ]] || \ [[ "${repo_src}" == "${valid_names[1]}" && "${repo_dest}" == "${valid_names[0]}" ]] || \
@@ -74,19 +38,30 @@ check_team(){
fi fi
} }
path_config() { push_super() {
[[ "${repo_src}" != 'trunk' ]] && pkgbuild="$CARCH/${repo_src}"/PKGBUILD local name="$1"
msg "Update (%s)" "$name"
git push origin master
git prune
[[ "${cmd}" != 'commitpkg' ]] && check_team
}
# shellcheck disable=1090 push_pkg() {
. "$pkgbuild" local name="$1"
if braid push "${package}"; then
braid update "${package}"
push_super "$name"
else
error "'braid push %s' failed.\n" "${package}"
fi
} }
get_repo_commit_msg() { get_repo_commit_msg() {
echo "[${repo_src}] -> [${repo_dest}] '${package}-$(get_full_version)' ${action}" printf "[%s] -> [%s] '%s' %s\n" "${repo_src}" "${repo_dest}" "${package}-$(get_full_version)" "${action}"
} }
get_commit_msg() { get_commit_msg() {
echo "[${repo_src}] '${package}-$(get_full_version)' ${action}" printf "[%s] '%s' %s\n" "${repo_src}" "${package}-$(get_full_version)" "${action}"
} }
commit_pkg() { commit_pkg() {
@@ -96,15 +71,15 @@ commit_pkg() {
commit_msg=$(get_commit_msg) commit_msg=$(get_commit_msg)
msg "Action: %s" "$commit_msg" msg "Action: %s" "$commit_msg"
if [[ "${repo_src}" == 'trunk' ]];then if [[ "${repo_src}" == 'trunk' ]];then
git rm -r trunk git rm -r $package/trunk
else else
git rm -r "$CARCH/${repo_src}" git rm -r "$package/$CARCH/${repo_src}"
fi fi
else else
action='modify' action='modify'
commit_msg=$(get_commit_msg) commit_msg=$(get_commit_msg)
msg "Action: %s" "$commit_msg" msg "Action: %s" "$commit_msg"
git add . git add "$package"
fi fi
git commit -m "$commit_msg" git commit -m "$commit_msg"
} }
@@ -112,58 +87,51 @@ commit_pkg() {
repo_commit_pkg() { repo_commit_pkg() {
local commit_msg local commit_msg
[[ -d "$CARCH/${repo_dest}" ]] && git rm -r "$CARCH/${repo_dest}" [[ -d "$package/$CARCH/${repo_dest}" ]] && git rm -r "$package/$CARCH/${repo_dest}"
[[ ! -d "$CARCH" ]] && mkdir "$CARCH" [[ ! -d "$package/$CARCH" ]] && mkdir "$package/$CARCH"
[[ ! -d "$CARCH/${repo_dest}" ]] && mkdir "$CARCH/${repo_dest}" [[ ! -d "$package/$CARCH/${repo_dest}" ]] && mkdir "$package/$CARCH/${repo_dest}"
if [[ "${repo_src}" == 'trunk' ]]; then if [[ "${repo_src}" == 'trunk' ]]; then
action='add' action='add'
commit_msg=$(get_repo_commit_msg) commit_msg=$(get_repo_commit_msg)
msg "Action: %s" "$commit_msg" msg "Action: %s" "$commit_msg"
check_rebuild cp -r "$package"/trunk/* "$package/$CARCH/${repo_dest}"/
cp trunk/* "$CARCH/${repo_dest}"/
else else
action='move' action='move'
[[ ! -f $pkgbuild ]] && die "%s does not exist!" "$pkgbuild" [[ ! -f $pkgbuild ]] && die "%s does not exist!" "$pkgbuild"
commit_msg=$(get_repo_commit_msg) commit_msg=$(get_repo_commit_msg)
msg "Action: %s" "$commit_msg" msg "Action: %s" "$commit_msg"
cp "$CARCH/${repo_src}"/* "$CARCH/${repo_dest}"/ cp -r "$package/$CARCH/${repo_src}"/* "$package/$CARCH/${repo_dest}"/
git rm -r "$CARCH/${repo_src}" git rm -r "$package/$CARCH/${repo_src}"
fi fi
git add . git add "$package"
git commit -m "$commit_msg" git commit -m "$commit_msg"
} }
run(){ run(){
local artixpath head group local artixpath head tree tree_name
artixpath=$(find_pkg "${TREE_DIR_ARTIX}" "${package}") artixpath=$(find_pkg "${TREE_DIR_ARTIX}" "${package}")
if [[ -n ${artixpath} ]];then if [[ -n ${artixpath} ]];then
group=${artixpath%/*} tree=${artixpath%/*}
cd "${group}" || return tree_name=${tree##*/}
cd "$tree" || return
head=$(get_local_head) head=$(get_local_head)
cd "${artixpath}" || return pkgbuild="$package"/trunk/PKGBUILD
if [[ "${repo_src}" != 'trunk' ]]; then
path_config pkgbuild="$package/$CARCH/${repo_src}"/PKGBUILD
if [[ "${cmd}" == 'commitpkg' ]];then
commit_pkg
else
repo_commit_pkg
fi fi
# shellcheck disable=1090
. "$pkgbuild"
cd "${group}" || return case "${cmd}" in
'commitpkg') commit_pkg ;;
*) repo_commit_pkg ;;
esac
${push} && pull_tree "${group##*/}" "$head" msg "Checking (%s) (Artix)" "$tree_name"
# subrepo_pull "${package}" pull_tree "$tree_name" "$head"
subrepo_push "${package}" push_pkg "$tree_name"
subrepo_clean "${package}"
${push} && push_tree "${group##*/}"
git prune
[[ "${cmd}" != 'commitpkg' ]] && check_team
else else
die "Package '%s' does not exist!" "${package}" die "Package '%s' does not exist!" "${package}"
fi fi
@@ -189,35 +157,29 @@ load_valid_names
repo_src='trunk' repo_src='trunk'
package='' package=''
remove=false remove=false
push=false
pkgbuild=trunk/PKGBUILD
cmd=${0##*/} cmd=${0##*/}
repo_dest=${cmd%pkg} repo_dest=${cmd%pkg}
usage() { usage() {
echo "Usage: ${0##*/} [options]" printf "Usage: %s [options]\n" "${0##*/}"
echo " -s <name> Source repository [default:${repo_src}]" printf " -s <name> Source repository [default: %s]\n" "${repo_src}"
echo ' -p <pkg> Package name' printf ' -p <pkg> Package name\n'
echo ' -r Delete from repo (commitpkg only)' printf ' -r Delete from repo (commitpkg only)\n'
echo ' -u Push' printf ' -h This help\n'
echo ' -h This help' printf '\n'
echo '' printf '\n'
echo ''
exit "$1" exit "$1"
} }
opts='p:s:urh' opts='p:s:rh'
while getopts "${opts}" arg; do while getopts "${opts}" arg; do
case "${arg}" in case "${arg}" in
s) repo_src="$OPTARG" ;; s) repo_src="$OPTARG" ;;
p) package="$OPTARG" ;; p) package="$OPTARG" ;;
r) remove=true ;; r) remove=true ;;
u) push=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -31,23 +31,32 @@ write_list(){
printf "%s\n" "$line" >> "${TREE_DIR_ARTIX}"/"$name".list printf "%s\n" "$line" >> "${TREE_DIR_ARTIX}"/"$name".list
} }
get_group() {
local group
group="${artixpath%/*}"
group=${group##*/}
printf "%s\n" "${group#*-}"
}
compare_m(){ compare_m(){
case ${artixrepo} in # if [ "$result" -eq 0 ];then
*testing*|*staging*|*rebuild) case "$artixrepo" in
if [[ "${a}" == "${b}" ]]; then *testing*|*staging*|*rebuild)
msg_row "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}" if [[ "${archrepo}" == "${artixrepo}" ]]; then
elif [[ "${a}" == 'staging' && "${b}" == 'rebuild' ]]; then msg_row "${table}" "${archrepo}" "${artixrepo}" "$pkg" "$archver" "$artixver" "$(get_group)"
msg_row_yellow "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}" elif [[ "${archrepo}" == 'staging' && "${artixrepo}" == 'rebuild' ]]; then
else msg_row_yellow "${table}" "${archrepo}" "${artixrepo}" "$pkg" "$archver" "$artixver" "$(get_group)"
msg_row_green "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}"
if [[ -n "$archrepo" ]]; then
write_list "${a}:${b}:$pkg" pkg_moves
else else
write_list "@repo@:${b}:$pkg" artix msg_row_green "${table}" "${archrepo}" "${artixrepo}" "$pkg" "$archver" "$artixver" "$(get_group)"
if [[ -n "${archrepo}" ]]; then
write_list "${archrepo}:${artixrepo}:$pkg" pkg_moves
else
write_list "@repo@:${artixrepo}:$pkg" artix
fi
fi fi
fi ;;
;; esac
esac # fi
} }
compare_u(){ compare_u(){
@@ -55,15 +64,15 @@ compare_u(){
# local arel=${archver##*-} brel=${artixver##*-} # local arel=${archver##*-} brel=${artixver##*-}
# local reldiff # local reldiff
# reldiff=$(( $arel-${brel%.*} )) # reldiff=$(( $arel-${brel%.*} ))
msg_row_red "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}" msg_row_red "${table}" "${archrepo}" "${artixrepo}" "$pkg" "$archver" "$artixver" "$(get_group)"
write_list "${a}:$pkg" pkg_upgrades write_list "${archrepo}:$pkg" pkg_upgrades
fi fi
} }
compare_d(){ compare_d(){
if [ "$result" -eq 1 ];then if [ "$result" -eq 1 ];then
if [[ -n "$archver" ]] && [[ -n "$archrepo" ]];then if [[ -n "$archver" ]] && [[ -n "${archrepo}" ]];then
msg_row_yellow "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}" msg_row_yellow "${table}" "${archrepo}" "${artixrepo}" "$pkg" "$archver" "$artixver" "$(get_group)"
fi fi
fi fi
} }
@@ -74,31 +83,26 @@ get_archpath(){
for tree in "${ARCH_TREE[@]}"; do for tree in "${ARCH_TREE[@]}"; do
[[ -d ${TREE_DIR_ARCH}/$tree/$pkg/repos ]] && archpath=${TREE_DIR_ARCH}/$tree/$pkg [[ -d ${TREE_DIR_ARCH}/$tree/$pkg/repos ]] && archpath=${TREE_DIR_ARCH}/$tree/$pkg
done done
echo "$archpath" printf "%s\n" "$archpath"
} }
pre_compare(){ pre_compare(){
local func="$1" pkgpath="$2" result group pkg local artixpath="$1" func="$2" pkg
group="${pkgpath%/*}" pkg=${artixpath##*/}
group=${group##*/}
pkg=${pkgpath##*/}
local artixrepo archrepo pkgbuild artixver archver archpath node a b local artixrepo archrepo pkgbuild artixver archver archpath epoch
artixrepo=$(find_repo "$pkgpath")
pkgbuild=$pkgpath/$artixrepo/PKGBUILD
if [[ -f $pkgbuild ]]; then artixrepo=$(find_repo "$artixpath")
pkgbuild=$artixpath/$CARCH/$artixrepo/PKGBUILD
if [[ -f "$pkgbuild" ]]; then
# shellcheck disable=1090 # shellcheck disable=1090
. "$pkgbuild" 2>/dev/null . "$pkgbuild" 2>/dev/null
artixver=$(get_full_version) artixver=$(get_full_version)
archpath=$(get_archpath "$pkg") archpath=$(get_archpath "$pkg")
archrepo=$(find_repo "${archpath}") archrepo=$(find_repo "$archpath")
pkgbuild=$archpath/$archrepo/PKGBUILD pkgbuild=$archpath/repos/$archrepo/PKGBUILD
node=${artixrepo%/*} archrepo="${archrepo%-*}"
a=${archrepo#*/} b=${artixrepo#*/}
a="${a%-*}"
[[ "$node" != "$CARCH" ]] && b=${b%-*}
if [[ -f "$pkgbuild" ]]; then if [[ -f "$pkgbuild" ]]; then
# shellcheck disable=1090 # shellcheck disable=1090
@@ -106,27 +110,26 @@ pre_compare(){
archver=$(get_full_version) archver=$(get_full_version)
fi fi
local result
result=$(vercmp "$artixver" "$archver") result=$(vercmp "$artixver" "$archver")
"$func" "$func"
unset epoch
fi fi
} }
compare_upgrades(){ compare_upgrades(){
local pkgpath="${1%/*}" local artixpath="${1%/*}"
pre_compare compare_u "$pkgpath" pre_compare "$artixpath" compare_u
} }
compare_downgrades(){ compare_downgrades(){
local pkgpath="${1%/*}" local artixpath="${1%/*}"
pre_compare compare_d "$pkgpath" pre_compare "$artixpath" compare_d
} }
compare_move(){ compare_move(){
local pkgpath="${1%/*}" local artixpath="${1%/*}"
pre_compare compare_m "$pkgpath" pre_compare "$artixpath" compare_m
} }
#}}} #}}}
@@ -165,19 +168,19 @@ upgrades=false
downgrades=false downgrades=false
move=false move=false
readonly table="%-18s %-18s %-25s %-27s %-27s %-10s" readonly table="%-18s %-18s %-29s %-27s %-27s %-7s"
usage() { usage() {
echo "Usage: ${0##*/} [options]" printf 'Usage: %s [options]\n' "${0##*/}"
echo ' -u Show upgrade packages' printf ' -u Show upgrade packages\n'
echo ' -d Show downgrade packages' printf ' -d Show downgrade packages\n'
echo ' -m Show packages to move' printf ' -m Show packages to move\n'
echo " -x Don't inlcude testing packages" printf ' -x Do not inlcude testing packages\n'
echo " -y Don't inlcude staging packages" printf ' -y Do not inlcude staging packages\n'
echo ' -z Include unstable kde and gnome' printf ' -z Include unstable kde and gnome\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -192,7 +195,6 @@ while getopts "${opts}" arg; do
y) staging=false ;; y) staging=false ;;
z) unstable=true ;; z) unstable=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -42,7 +42,9 @@ repo_action(){
cd "$repo_path" || return cd "$repo_path" || return
if [[ -n "${action}" ]]; then if [[ -n "${action}" ]]; then
repo-"${action}" -R "${dest_repo}"."${pkgdb_ext}" "${packages[@]}" repo-"${action}" -R "${dest_repo}"."${pkgdb_ext}" "${packages[@]}"
${linksdb} && links-"${action}" "${dest_repo}"."${linksdb_ext}" "${packages[@]}" if ${linksdb}; then
links-"${action}" "${dest_repo}"."${linksdb_ext}" "${packages[@]}"
fi
fi fi
} }
@@ -61,14 +63,14 @@ cmd=${0##*/}
dest_repo=${cmd#*-} dest_repo=${cmd#*-}
usage() { usage() {
echo "Usage: ${cmd} [options]" printf "Usage: %s [options]\n" "${cmd}"
echo ' -d <dest> Destination repository' printf ' -d <dest> Destination repository\n'
echo ' -a Add package(s) to repository' printf ' -a Add package(s) to repository\n'
echo ' -r Remove package(s) from repository' printf ' -r Remove package(s) from repository\n'
echo ' -l Use links db' printf ' -l Use links db\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -81,7 +83,6 @@ while getopts "${opts}" arg; do
r) rm_pkg=true; add_pkg=false ;; r) rm_pkg=true; add_pkg=false ;;
l) linksdb=true ;; l) linksdb=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

329
bin/pkg/diffpkg.in Normal file
View File

@@ -0,0 +1,329 @@
#!/bin/bash
#
# SPDX-License-Identifier: GPL-3.0-or-later
m4_include(lib/base/message.sh)
m4_include(lib/pkg/diff.sh)
usage() {
cat <<- _EOF_
Usage: ${BASH_SOURCE[0]##*/} [OPTIONS] [MODES] [FILE|PKGNAME...]
Searches for a locally built package corresponding to the PKGBUILD, and
downloads the last version of that package from the Pacman repositories.
It then compares the package archives using different modes while using
simple tar content list by default.
When given one package, use it to diff against the locally built one.
When given two packages, diff both packages against each other.
In either case, a package name will be converted to a filename from the
cache, and diffpkg will proceed as though this filename was initially
specified.
OPTIONS
-M, --makepkg-config Set an alternate makepkg configuration file
-v, --verbose Provide more detailed/unfiltered output
-h, --help Show this help text
MODES
-l, --list Activate content list diff mode (default)
-d, --diffoscope Activate diffoscope diff mode
-p, --pkginfo Activate .PKGINFO diff mode
-b, --buildinfo Activate .BUILDINFO diff mode
_EOF_
}
MAKEPKG_CONF=/etc/makepkg.conf
POOLDIR=/srv/pkgpool
VERBOSE=0
TARLIST=0
DIFFOSCOPE=0
PKGINFO=0
BUILDINFO=0
DIFFMODE=--side-by-side
DIFFCOLOR=--color=auto
DIFFWIDTH=--width=auto
DIFFOPTIONS=(--expand-tabs)
# option checking
while (( $# )); do
case $1 in
-h|--help)
usage
exit 0
;;
-M|--makepkg-config)
(( $# <= 1 )) && die "missing argument for %s" "$1"
MAKEPKG_CONF="$2"
shift 2
;;
-l|--list)
TARLIST=1
shift
;;
-d|--diffoscope)
DIFFOSCOPE=1
shift
;;
-p|--pkginfo)
PKGINFO=1
shift
;;
-b|--buildinfo)
BUILDINFO=1
shift
;;
-v|--verbose)
VERBOSE=1
shift
;;
-u|-U|--unified)
DIFFMODE=--unified
shift
;;
-y|--side-by-side)
DIFFMODE=--side-by-side
shift
;;
--color|--color=*)
if [[ $2 == never || $2 == always || $2 == auto ]]; then
DIFFCOLOR="--color=$2"
shift 2
continue
fi
if [[ $1 == --color ]]; then
DIFFCOLOR="--color=auto"
else
DIFFCOLOR="$1"
fi
shift
;;
-W|--width)
(( $# <= 1 )) && die "missing argument for %s" "$1"
DIFFWIDTH="--width=$2"
shift 2
;;
--width=*)
DIFFWIDTH="$1"
shift
;;
-P|--pool)
(( $# <= 1 )) && die "missing argument for %s" "$1"
POOLDIR="$2"
shift 2
;;
--pool=*)
POOLDIR="${1#*=}"
shift
;;
--)
shift
break
;;
-*|--*)
die "invalid argument: %s" "$1"
;;
*)
break
;;
esac
done
# Set options based on flags or magic values
if (( VERBOSE )); then
if [[ $DIFFMODE == --unified ]]; then
DIFFMODE="--unified=99999"
fi
else
DIFFOPTIONS+=(--suppress-common-lines)
fi
if [[ $DIFFWIDTH == --width=columns ]]; then
DIFFWIDTH="--width=${COLUMNS:-130}"
fi
if [[ $DIFFWIDTH != --width=auto ]]; then
DIFFOPTIONS+=("${DIFFWIDTH}")
fi
DIFFOPTIONS+=("${DIFFMODE}" "${DIFFCOLOR}")
if ! (( DIFFOSCOPE || TARLIST || PKGINFO || BUILDINFO )); then
TARLIST=1
fi
# Source makepkg.conf; fail if it is not found
if [[ -r "${MAKEPKG_CONF}" ]]; then
# shellcheck source=config/makepkg/x86_64.conf
source "${MAKEPKG_CONF}"
else
die "${MAKEPKG_CONF} not found!"
fi
# Source user-specific makepkg.conf overrides
if [[ -r "${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf" ]]; then
# shellcheck source=/dev/null
source "${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf"
elif [[ -r "$HOME/.makepkg.conf" ]]; then
# shellcheck source=/dev/null
source "$HOME/.makepkg.conf"
fi
STARTDIR=$(pwd)
trap 'rm -rf $TMPDIR' EXIT INT TERM QUIT
TMPDIR=$(mktemp -d --tmpdir diffpkg-script.XXXXXXXX)
export TMPDIR
tar_list() {
bsdtar tf "$*" | if (( VERBOSE )); then
cat
else
sed -E 's|^usr/lib/modules/[0-9][^/]+|usr/lib/modules/[…]|g'
fi | sort
}
file_line_length() {
path="$1"
wc -L "${path}" | tail -n1 | sed -E 's/^ +//g' | cut -d' ' -f1
}
file_diff_columns() {
file1="$1"
file2="$2"
file1_length=$(file_line_length "$file1")
file2_length=$(file_line_length "$file2")
echo $(( file1_length + file2_length + 3 ))
}
diff_pkgs() {
local oldpkg newpkg
oldpkg=$(readlink -m "$1")
newpkg=$(readlink -m "$2")
[[ -f $oldpkg ]] || die "No such file: %s" "${oldpkg}"
[[ -f $newpkg ]] || die "No such file: %s" "${newpkg}"
DIFFOPTIONS+=(--label "${oldpkg}" --label "${newpkg}")
if (( TARLIST )); then
tar_list "$oldpkg" > "$TMPDIR/old"
tar_list "$newpkg" > "$TMPDIR/new"
fi
if (( PKGINFO )); then
bsdtar xOqf "$oldpkg" .PKGINFO > "$TMPDIR/old"
bsdtar xOqf "$newpkg" .PKGINFO > "$TMPDIR/new"
fi
if (( BUILDINFO )); then
bsdtar xOqf "$oldpkg" .BUILDINFO > "$TMPDIR/old"
bsdtar xOqf "$newpkg" .BUILDINFO > "$TMPDIR/new"
fi
if (( TARLIST || PKGINFO || BUILDINFO )); then
# Resolve dynamic auto width one we know the content to diff
if [[ $DIFFWIDTH == --width=auto ]]; then
AUTOLENGTH=$(file_diff_columns "$TMPDIR/old" "$TMPDIR/new")
DIFFOPTIONS+=("--width=${AUTOLENGTH}")
fi
# Print a header for side-by-side view as it lacks labels
if [[ $DIFFMODE == --side-by-side ]]; then
printf -- "--- %s\n+++ %s\n" "${oldpkg}" "${newpkg}"
fi
diff "${DIFFOPTIONS[@]}" "$TMPDIR/old" "$TMPDIR/new"
fi
if (( DIFFOSCOPE )); then
diffoscope "${DIFFCOLOR/--color/--text-color}" "$oldpkg" "$newpkg"
fi
}
shopt -s extglob
fetch_pkg() {
local pkg pkgdest pkgurl
case $1 in
*://*)
pkgurl=$1 ;;
/*|*/*)
pkgurl=$(readlink -m "$1") ;;
*.pkg.tar*)
pkgurl=$1 ;;
'')
;;
*)
pkg=$1 ;;
esac
if [[ -z ${pkgurl} ]]; then
# Try to find latest package in pool dir
if [[ -d ${POOLDIR} ]]; then
shopt -s extglob nullglob
pkgurl=$(printf "%s\n" "${POOLDIR}"/*/"${_pkgname}"-!(*-*)-!(*-*)-!(*-*).pkg.tar!(*.sig)|sort -Vr|head -1)
shopt -u extglob nullglob
fi
# Search via pacman database if no pool file exists
if [[ ! -f ${pkgurl} ]]; then
pkgurl=$(pacman -Spdd --print-format '%l' --noconfirm "$pkg") ||
die "Couldn't download previous package for %s." "$pkg"
fi
fi
pkg=${pkgurl##*/}
pkgdest=$(mktemp -t -d "${pkg}-XXXXXX")/${pkg}
if [[ $pkgurl = file://* || ( $pkgurl = /* && -f $pkgurl ) ]]; then
ln -sf "${pkgurl#file://}" "$pkgdest"
elif [[ -f "$PKGDEST/$pkg" ]]; then
ln -sf "$PKGDEST/$pkg" "$pkgdest"
elif [[ -f "$STARTDIR/$pkg" ]]; then
ln -sf "$STARTDIR/$pkg" "$pkgdest"
elif [[ $pkgurl = *://* ]]; then
curl -fsLC - --retry 3 --retry-delay 3 -o "$pkgdest" "$pkgurl" || \
die "Couldn't download %s" "$pkgurl"
else
die "File not found: %s" "$pkgurl"
fi
echo "$pkgdest"
}
shopt -u extglob
if (( $# < 2 )); then
if [[ ! -f PKGBUILD ]]; then
die "This must be run in the directory of a built package.\nTry '$(basename "$0") --help' for more information."
fi
# shellcheck source=contrib/makepkg/PKGBUILD.proto
. ./PKGBUILD
if [[ ${arch[0]} == 'any' ]]; then
CARCH='any'
fi
for _pkgname in "${pkgname[@]}"; do
comparepkg=$_pkgname
pkgurl=
target_pkgver=$(get_full_version "$_pkgname")
if ! pkgfile=$(find_cached_package "$_pkgname" "$target_pkgver" "$CARCH"); then
die 'tarball not found for package: %s' "${_pkgname}-$target_pkgver"
fi
ln -s "$pkgfile" "$TMPDIR"
if (( $# )); then
comparepkg="$1"
fi
oldpkg=$(fetch_pkg "$comparepkg") || exit 1
diff_pkgs "$oldpkg" "$pkgfile"
done
else
file1=$(fetch_pkg "$1") || exit 1
file2=$(fetch_pkg "$2") || exit 1
diff_pkgs "$file1" "$file2"
fi

View File

@@ -0,0 +1,70 @@
#!/bin/bash
#
# SPDX-License-Identifier: GPL-3.0-or-later
m4_include(lib/base/message.sh)
usage() {
cat <<- _EOF_
Usage: ${BASH_SOURCE[0]##*/}
Export the PGP keys from a PKGBUILDs validpgpkeys array into the keys/pgp/
subdirectory. Useful for distributing packager validated source signing
keys alongside PKGBUILDs.
OPTIONS
-h, --help Show this help text
_EOF_
}
# option checking
while (( $# )); do
case $1 in
-h|--help) usage; exit 0 ;;
*) die "invalid argument: %s" "$1" ;;
esac
done
if [[ ! -f PKGBUILD ]]; then
die "This must be run a directory containing a PKGBUILD."
fi
mapfile -t validpgpkeys < <(
# shellcheck source=PKGBUILD.proto
. ./PKGBUILD
if (( ${#validpgpkeys[@]} )); then
printf "%s\n" "${validpgpkeys[@]}"
fi
)
msg "Exporting ${#validpgpkeys[@]} PGP keys..."
if (( ${#validpgpkeys[@]} == 0 )); then
exit 0
fi
trap 'rm -rf $TEMPDIR' EXIT INT TERM QUIT
TEMPDIR=$(mktemp -d --tmpdir export-pkgbuild-keys.XXXXXXXXXX)
mkdir -p keys/pgp
error=0
for key in "${validpgpkeys[@]}"; do
gpg --output "$TEMPDIR/$key.asc" --armor --export --export-options export-minimal "$key" 2>/dev/null
# gpg does not give a non-zero return value if it fails to export...
if [[ -f $TEMPDIR/$key.asc ]]; then
msg2 "Exported $key"
mv "$TEMPDIR/$key.asc" "keys/pgp/$key.asc"
else
if [[ -f keys/pgp/$key.asc ]]; then
warning "Failed to update key: $key"
else
error "Key unavailable: $key"
error=1
fi
fi
done
if (( error )); then
die "Failed to export all \'validpgpkeys\' entries."
fi

View File

@@ -15,7 +15,6 @@
m4_include(lib/base/message.sh) m4_include(lib/base/message.sh)
set -e set -e
shopt -s extglob
IGNORE_INTERNAL=0 IGNORE_INTERNAL=0
@@ -32,9 +31,9 @@ case $script_mode in
esac esac
if [[ -z $1 ]]; then if [[ -z $1 ]]; then
echo "${0##*/} [options] <package file|extracted package dir>" printf "%s [options] <package file|extracted package dir>\n" "${0##*/}"
echo "Options:" printf "Options:\n"
echo " --ignore-internal ignore internal libraries" printf " --ignore-internal ignore internal libraries\n"
exit 1 exit 1
fi fi
@@ -51,9 +50,13 @@ else
pushd "$WORKDIR" >/dev/null pushd "$WORKDIR" >/dev/null
fi fi
shopt -s extglob
process_sofile() { process_sofile() {
# extract the library name: libfoo.so # extract the library name: libfoo.so
shopt -s extglob nullglob
soname="${sofile%.so?(+(.+([0-9])))}".so soname="${sofile%.so?(+(.+([0-9])))}".so
shopt -u extglob nullglob
# extract the major version: 1 # extract the major version: 1
soversion="${sofile##*\.so\.}" soversion="${sofile##*\.so\.}"
if [[ "$soversion" = "$sofile" ]] && ((IGNORE_INTERNAL)); then if [[ "$soversion" = "$sofile" ]] && ((IGNORE_INTERNAL)); then
@@ -61,11 +64,13 @@ process_sofile() {
fi fi
if ! in_array "${soname}=${soversion}-${soarch}" "${soobjects[@]}"; then if ! in_array "${soname}=${soversion}-${soarch}" "${soobjects[@]}"; then
# libfoo.so=1-64 # libfoo.so=1-64
echo "${soname}=${soversion}-${soarch}" printf "%s\n" "${soname}=${soversion}-${soarch}"
soobjects+=("${soname}=${soversion}-${soarch}") soobjects+=("${soname}=${soversion}-${soarch}")
fi fi
} }
shopt -u extglob
case $script_mode in case $script_mode in
deps) find_args=(-perm -u+x);; deps) find_args=(-perm -u+x);;
provides) find_args=(-name '*.so*');; provides) find_args=(-name '*.so*');;

View File

@@ -17,11 +17,11 @@ m4_include(lib/base/message.sh)
match=$1 match=$1
if [[ -z $match ]]; then if [[ -z $match ]]; then
echo 'Usage: finddeps <depname>' printf 'Usage: finddeps <depname>\n'
echo '' printf '\n'
echo 'Find packages that depend on a given depname.' printf 'Find packages that depend on a given depname.\n'
echo 'Run this script from the top-level directory of your ABS tree.' printf 'Run this script from the top-level directory of your ABS tree.\n'
echo '' printf '\n'
exit 1 exit 1
fi fi

View File

@@ -55,13 +55,13 @@ transfer_repo() {
#}}} #}}}
usage() { usage() {
echo "Usage: ${0##*/} [options]" printf "Usage: %s [options]\n" "${0##*/}"
echo ' -r <repo> Repo name' printf ' -r <repo> Repo name\n'
echo ' -c Create git repo' printf ' -c Create git repo\n'
echo ' -t Transfer git repo to landfill org' printf ' -t Transfer git repo to landfill org\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -76,7 +76,6 @@ while getopts "${opts}" arg; do
c) create=true ;; c) create=true ;;
t) transfer=true ;; t) transfer=true ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

View File

@@ -40,7 +40,7 @@ for tree in $PATH $libdirs $extras; do
# Is an ELF binary. # Is an ELF binary.
if (( $(ldd "$i" 2>/dev/null | grep -c 'not found') != 0 )); then if (( $(ldd "$i" 2>/dev/null | grep -c 'not found') != 0 )); then
# Missing lib. # Missing lib.
echo "$i:" >> "$TEMPDIR/raw.txt" printf "%s\n" "$i:" >> "$TEMPDIR/raw.txt"
ldd "$i" 2>/dev/null | grep 'not found' >> "$TEMPDIR/raw.txt" ldd "$i" 2>/dev/null | grep 'not found' >> "$TEMPDIR/raw.txt"
fi fi
fi fi

View File

@@ -87,7 +87,7 @@ find_pkgentry() {
for pkgentry in "$tmpdir/${REPO_DB_NAME}/$pkgname"*; do for pkgentry in "$tmpdir/${REPO_DB_NAME}/$pkgname"*; do
name=${pkgentry##*/} name=${pkgentry##*/}
if [[ ${name%-*-*} = "$pkgname" ]]; then if [[ ${name%-*-*} = "$pkgname" ]]; then
echo "$pkgentry" printf "%s\n" "$pkgentry"
return 0 return 0
fi fi
done done
@@ -238,7 +238,7 @@ db_remove_entry() {
# remove entries in "links" database # remove entries in "links" database
local linksentry local linksentry
linksentry=$(echo "$pkgentry" | sed 's/\(.*\)\/db\//\1\/links\//') linksentry=$(printf "%s\n" "$pkgentry" | sed 's/\(.*\)\/db\//\1\/links\//')
rm -rf "$linksentry" rm -rf "$linksentry"
pkgentry=$(find_pkgentry "$pkgname") pkgentry=$(find_pkgentry "$pkgname")
@@ -258,7 +258,7 @@ prepare_repo_db() {
fi fi
# check lock file # check lock file
if ( set -o noclobber; echo "$$" > "$LOCKFILE") 2> /dev/null; then if ( set -o noclobber; printf "%s\n" "$$" > "$LOCKFILE") 2> /dev/null; then
CLEAN_LOCK=1 CLEAN_LOCK=1
else else
error "Failed to acquire lockfile: %s." "$LOCKFILE" error "Failed to acquire lockfile: %s." "$LOCKFILE"
@@ -399,7 +399,7 @@ trap_exit() {
# unhook all traps to avoid race conditions # unhook all traps to avoid race conditions
trap '' EXIT TERM HUP QUIT INT ERR trap '' EXIT TERM HUP QUIT INT ERR
echo printf '\n'
error "$@" error "$@"
clean_up 1 clean_up 1
} }

271
bin/pkg/makerepropkg.in Normal file
View File

@@ -0,0 +1,271 @@
#!/bin/bash
#
# makerepropkg - rebuild a package to see if it is reproducible
#
# Copyright (c) 2019 by Eli Schwartz <eschwartz@archlinux.org>
#
# SPDX-License-Identifier: GPL-3.0-or-later
m4_include(lib/util-base.sh)
m4_include(lib/base/message.sh)
m4_include(lib/base/chroot.sh)
m4_include(lib/base/chroot.sh)
declare -A buildinfo
declare -a buildenv buildopts installed installpkgs
archiveurl='https://archive.artixlinux.org/packages'
buildroot="${CHROOTS_DIR}"/reproducible
diffoscope=0
chroot=$USER
[[ -n ${SUDO_USER:-} ]] && chroot=$SUDO_USER
[[ -z "$chroot" || $chroot = root ]] && chroot=copy
parse_buildinfo() {
local line var val
while read -r line; do
var="${line%% = *}"
val="${line#* = }"
case ${var} in
buildenv)
buildenv+=("${val}")
;;
options)
buildopts+=("${val}")
;;
installed)
installed+=("${val}")
;;
*)
buildinfo["${var}"]="${val}"
;;
esac
done
}
get_pkgfile() {
local cdir=${cache_dirs[0]}
local pkgfilebase=${1}
local mode=${2}
local pkgname=${pkgfilebase%-*-*-*}
local pkgfile ext
# try without downloading
if [[ ${mode} != localonly ]] && get_pkgfile "${pkgfilebase}" localonly; then
return 0
fi
for ext in .zst .xz ''; do
pkgfile=${pkgfilebase}.pkg.tar${ext}
for c in "${cache_dirs[@]}"; do
if [[ -f ${c}/${pkgfile} ]]; then
cdir=${c}
break
fi
done
for f in "${pkgfile}" "${pkgfile}.sig"; do
if [[ ! -f "${cdir}/${f}" ]]; then
if [[ ${mode} = localonly ]]; then
continue 2
fi
msg2 "retrieving '%s'..." "${f}" >&2
curl -Llf -# -o "${cdir}/${f}" "${archiveurl}/${pkgname:0:1}/${pkgname}/${f}" || continue 2
fi
done
printf '%s\n' "file://${cdir}/${pkgfile}"
return 0
done
return 1
}
get_makepkg_conf() {
local fname=${1}
local makepkg_conf="${2}"
if ! buildtool_file=$(get_pkgfile "${fname}"); then
error "failed to retrieve ${fname}"
return 1
fi
msg2 "using makepkg.conf from ${fname}"
bsdtar xOqf "${buildtool_file/file:\/\//}" usr/share/artools/makepkg.conf > "${makepkg_conf}"
return 0
}
usage() {
cat << __EOF__
usage: ${BASH_SOURCE[0]##*/} [options] <package_file>
Run this script in a PKGBUILD dir to build a package inside a
clean chroot while attempting to reproduce it. The package file
will be used to derive metadata needed for reproducing the
package, including the .PKGINFO as well as the buildinfo.
For more details see https://reproducible-builds.org/
OPTIONS
-d Run diffoscope if the package is unreproducible
-c <dir> Set pacman cache
-M <file> Location of a makepkg config file
-l <chroot> The directory name to use as the chroot namespace
Useful for maintaining multiple copies
Default: $chroot
-h Show this usage message
__EOF__
}
while getopts 'dM:c:l:h' arg; do
case "$arg" in
d) diffoscope=1 ;;
M) artixroot_args+=(-M "$OPTARG") ;;
c) cache_dirs+=("$OPTARG") ;;
l) chroot="$OPTARG" ;;
h) usage; exit 0 ;;
*|?) usage; exit 1 ;;
esac
done
shift $((OPTIND - 1))
check_root
[[ -f PKGBUILD ]] || { error "No PKGBUILD in current directory."; exit 1; }
# without arguments, get list of packages from PKGBUILD
if [[ -z $1 ]]; then
mapfile -t pkgnames < <(source PKGBUILD; pacman -Sddp --print-format '%r/%n' "${pkgname[@]}")
wait $! || {
error "No package file specified and failed to retrieve package names from './PKGBUILD'."
plain "Try '${BASH_SOURCE[0]##*/} -h' for more information." >&2
exit 1
}
msg "Reproducing all pkgnames listed in ./PKGBUILD"
set -- "${pkgnames[@]}"
fi
# check each package to see if it's a file, and if not, try to download it
# using pacman -Sw, and get the filename from there
splitpkgs=()
for p in "$@"; do
if [[ -f ${p} ]]; then
splitpkgs+=("${p}")
else
pkgfile_remote=$(pacman -Sddp "${p}" 2>/dev/null) || { error "package name '%s' not in repos" "${p}"; exit 1; }
pkgfile=${pkgfile_remote#file://}
if [[ ! -f ${pkgfile} ]]; then
msg "Downloading package '%s' into pacman's cache" "${pkgfile}"
sudo pacman -Swdd --noconfirm --logfile /dev/null "${p}" || exit 1
pkgfile_remote=$(pacman -Sddp "${p}" 2>/dev/null)
pkgfile="${pkgfile_remote#file://}"
fi
splitpkgs+=("${pkgfile}")
fi
done
for f in "${splitpkgs[@]}"; do
if ! bsdtar -tqf "${f}" .BUILDINFO >/dev/null 2>&1; then
error "file is not a valid pacman package: '%s'" "${f}"
exit 1
fi
done
if (( ${#cache_dirs[@]} == 0 )); then
mapfile -t cache_dirs < <(pacman-conf CacheDir)
fi
ORIG_HOME=${HOME}
IFS=: read -r _ _ _ _ _ HOME _ < <(getent passwd "${SUDO_USER:-$USER}")
load_makepkg_config
HOME=${ORIG_HOME}
[[ -d ${SRCDEST} ]] || SRCDEST=${PWD}
parse_buildinfo < <(bsdtar -xOqf "${splitpkgs[0]}" .BUILDINFO)
export SOURCE_DATE_EPOCH="${buildinfo[builddate]}"
PACKAGER="${buildinfo[packager]}"
BUILDDIR="${buildinfo[builddir]}"
BUILDTOOL="${buildinfo[buildtool]}"
BUILDTOOLVER="${buildinfo[buildtoolver]}"
PKGEXT=${splitpkgs[0]#${splitpkgs[0]%.pkg.tar*}}
# nuke and restore reproducible testenv
namespace="$buildroot/$chroot"
lock 9 "${namespace}.lock" "Locking chroot namespace '%s'" "${namespace}"
for copy in "${namespace}"/*/; do
[[ -d ${copy} ]] || continue
subvolume_delete_recursive "${copy}"
done
rm -rf --one-file-system "${namespace}"
(umask 0022; mkdir -p "${namespace}")
for fname in "${installed[@]}"; do
if ! allpkgfiles+=("$(get_pkgfile "${fname}")"); then
error "failed to retrieve ${fname}"
exit 1
fi
done
trap 'rm -rf $TEMPDIR' EXIT INT TERM QUIT
TEMPDIR=$(mktemp -d --tmpdir makerepropkg.XXXXXXXXXX)
makepkg_conf="${TEMPDIR}/makepkg.conf"
# anything before buildtool support is pinned to the last none buildtool aware release
if [[ -z "${BUILDTOOL}" ]]; then
get_makepkg_conf "artools-pkg-0.28.2-1-any" "${makepkg_conf}" || exit 1
# prefere to assume artools-pkg up until matching makepkg version so repository packages remain reproducible
elif [[ "${BUILDTOOL}" = makepkg ]] && (( $(vercmp "${BUILDTOOLVER}" 6.0.1) <= 0 )); then
get_makepkg_conf "artools-pkg-0.28.2-1-any" "${makepkg_conf}" || exit 1
# all artools-pkg builds
elif [[ "${BUILDTOOL}" = artools-pkg ]] && get_makepkg_conf "${BUILDTOOL}-${BUILDTOOLVER}" "${makepkg_conf}"; then
true
# fallback to current makepkg.conf
else
warning "Unknown buildtool (${BUILDTOOL}-${BUILDTOOLVER}), using fallback"
makepkg_conf="${DATADIR}"/makepkg.conf
fi
printf '%s\n' "${allpkgfiles[@]}" | mkchroot -M "${makepkg_conf}" -U "${artixroot_args[@]}" "${namespace}/root" - || exit 1
# use makechrootpkg to prep the build directory
mkchrootpkg -r "${namespace}" -l build -- --packagelist || exit 1
# set detected makepkg.conf options
{
for var in PACKAGER BUILDDIR BUILDTOOL BUILDTOOLVER PKGEXT; do
printf '%s=%s\n' "${var}" "${!var@Q}"
done
printf 'OPTIONS=(%s)\n' "${buildopts[*]@Q}"
printf 'BUILDENV=(%s)\n' "${buildenv[*]@Q}"
} >> "${namespace}/build"/etc/makepkg.conf
install -d -o "${SUDO_UID:-$UID}" -g "$(id -g "${SUDO_UID:-$UID}")" "${namespace}/build/${BUILDDIR}"
bindmounts+=("-B:${PWD}:/startdir" "-B:${SRCDEST}:/srcdest")
# kick off the build
chroot-run \
-b "${bindmounts[*]}" \
"${namespace}/build" \
/chrootbuild -C --noconfirm --log --holdver --skipinteg
ret=$?
if (( ${ret} == 0 )); then
msg2 "built succeeded! built packages can be found in ${namespace}/build/pkgdest"
msg "comparing artifacts..."
for pkgfile in "${splitpkgs[@]}"; do
comparefiles=("${pkgfile}" "${namespace}/build/pkgdest/${pkgfile##*/}")
if cmp -s "${comparefiles[@]}"; then
msg2 "Package '%s' successfully reproduced!" "${pkgfile}"
else
ret=1
warning "Package '%s' is not reproducible. :(" "${pkgfile}"
sha256sum "${comparefiles[@]}"
if (( diffoscope )); then
diffoscope "${comparefiles[@]}"
fi
fi
done
fi
# return failure from chrootbuild, or the reproducibility status
exit ${ret}

View File

@@ -44,43 +44,43 @@ copy=$USER
src_owner=${SUDO_USER:-$USER} src_owner=${SUDO_USER:-$USER}
usage() { usage() {
echo "Usage: ${0##*/} [options] -r <chrootdir> [--] [makepkg args]" printf 'Usage: %s [options] -r <chrootdir> [--] [makepkg args]\n' "${0##*/}"
echo ' Run this script in a PKGBUILD dir to build a package inside a' printf ' Run this script in a PKGBUILD dir to build a package inside a\n'
echo ' clean chroot. Arguments passed to this script after the' printf ' clean chroot. Arguments passed to this script after the\n'
echo ' end-of-options marker (--) will be passed to makepkg.' printf ' end-of-options marker (--) will be passed to makepkg.\n'
echo '' printf '\n'
echo ' The chroot dir consists of the following directories:' printf ' The chroot dir consists of the following directories:\n'
echo ' <chrootdir>/{root, copy} but only "root" is required' printf ' <chrootdir>/{root, copy} but only "root" is required\n'
echo ' by default. The working copy will be created as needed' printf ' by default. The working copy will be created as needed\n'
echo '' printf '\n'
echo 'The chroot "root" directory must be created via the following' printf "The chroot 'root' directory must be created via the following\n"
echo 'command:' printf 'command:\n'
echo ' mkchroot <chrootdir>/root base-devel' printf ' mkchroot <chrootdir>/root base-devel\n'
echo '' printf '\n'
echo 'This script reads {SRC,SRCPKG,PKG,LOG}DEST, MAKEFLAGS and PACKAGER' printf 'This script reads {SRC,SRCPKG,PKG,LOG}DEST, MAKEFLAGS and PACKAGER\n'
echo 'from makepkg.conf(5), if those variables are not part of the' printf 'from makepkg.conf(5), if those variables are not part of the\n'
echo 'environment.' printf 'environment.\n'
echo '' printf '\n'
echo "Default makepkg args: ${default_makepkg_args[*]}" printf 'Default makepkg args: %s\n' "${default_makepkg_args[*]}"
echo '' printf '\n'
echo 'Flags:' printf 'Flags:\n'
echo '-h This help' printf ' -h This help\n'
echo '-c Clean the chroot before building' printf ' -c Clean the chroot before building\n'
echo '-d <dir> Bind directory into build chroot as read-write' printf ' -d <dir> Bind directory into build chroot as read-write\n'
echo '-D <dir> Bind directory into build chroot as read-only' printf ' -D <dir> Bind directory into build chroot as read-only\n'
echo '-u Update the working copy of the chroot before building' printf ' -u Update the working copy of the chroot before building\n'
echo ' This is useful for rebuilds without dirtying the pristine' printf ' This is useful for rebuilds without dirtying the pristine\n'
echo ' chroot' printf ' chroot\n'
echo '-r <dir> The chroot dir to use' printf ' -r <dir> The chroot dir to use\n'
echo '-I <pkg> Install a package into the working copy of the chroot' printf ' -I <pkg> Install a package into the working copy of the chroot\n'
echo '-l <copy> The directory to use as the working copy of the chroot' printf ' -l <copy> The directory to use as the working copy of the chroot\n'
echo ' Useful for maintaining multiple copies' printf ' Useful for maintaining multiple copies\n'
echo " Default: $copy" printf ' Default: %s\n' "$copy"
echo '-n Run namcap on the package' printf ' -n Run namcap on the package\n'
echo '-C Run checkpkg on the package' printf ' -C Run checkpkg on the package\n'
echo '-N Disable check() function' printf ' -N Disable check() function\n'
echo '-T Build in a temporary directory' printf ' -T Build in a temporary directory\n'
echo '-U Run makepkg as a specified user' printf ' -U Run makepkg as a specified user\n'
exit 1 exit 1
} }
@@ -182,7 +182,7 @@ prepare_chroot() {
"MAKEFLAGS='${MAKEFLAGS:-}'" "PACKAGER='${PACKAGER:-}'" "MAKEFLAGS='${MAKEFLAGS:-}'" "PACKAGER='${PACKAGER:-}'"
do do
grep -q "^$x" "$copydir/etc/makepkg.conf" && continue grep -q "^$x" "$copydir/etc/makepkg.conf" && continue
echo "$x" >>"$copydir/etc/makepkg.conf" printf "%s\n" "$x" >>"$copydir/etc/makepkg.conf"
done done
cat > "$copydir/etc/sudoers.d/builduser-pacman" <<EOF cat > "$copydir/etc/sudoers.d/builduser-pacman" <<EOF
@@ -239,7 +239,7 @@ _chrootbuild() {
_chrootnamcap() { _chrootnamcap() {
pacman -S --needed --noconfirm namcap pacman -S --needed --noconfirm namcap
for pkgfile in /startdir/PKGBUILD /pkgdest/*; do for pkgfile in /startdir/PKGBUILD /pkgdest/*; do
echo "Checking ${pkgfile##*/}" printf "Checking %s\n" "${pkgfile##*/}"
sudo -u builduser namcap "$pkgfile" 2>&1 | tee "/logdest/${pkgfile##*/}-namcap.log" sudo -u builduser namcap "$pkgfile" 2>&1 | tee "/logdest/${pkgfile##*/}-namcap.log"
done done
} }
@@ -329,13 +329,14 @@ fi
# Pass all arguments after -- right to makepkg # Pass all arguments after -- right to makepkg
makepkg_args+=("${@:$OPTIND}") makepkg_args+=("${@:$OPTIND}")
# See if -R or -e was passed to makepkg # See if -R, -e or -A was passed to makepkg
for arg in "${@:$OPTIND}"; do for arg in "${@:$OPTIND}"; do
case ${arg%%=*} in case ${arg%%=*} in
--skip*|--holdver) verifysource_args+=("$arg") ;; --skip*|--holdver|--ignorearch) verifysource_args+=("$arg") ;;
--repackage|--noextract) keepbuilddir=1 ;; --repackage|--noextract) keepbuilddir=1 ;;
--*) ;; --*) ;;
-*R*|-*e*) keepbuilddir=1 ;; -*A*) verifysource_args+=(-A) ;;&
-*R*|-*e*) keepbuilddir=1 ;;&
esac esac
done done

77
bin/pkg/mkdepgraph.in Normal file
View File

@@ -0,0 +1,77 @@
#!/bin/bash
#
# Copyright (C) 2018-19 artoo@artixlinux.org
# Copyright (C) 2018 Artix Linux Developers
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
mk_tree_graph(){
printf "%s\n" "$(pactree "${tree_args[@]}" "${package}")" \
| dot -T "${ext}" > "${graph_dir}/${package}.${ext}"
}
mk_rebuild_graph(){
local tmpfile
tmpfile=/tmp/rebuild.dot
rebuild_args+=(-d "${tmpfile}")
artix-rebuild-order "${packages[@]}" "${rebuild_args[@]}"
dot -T "${ext}" "${tmpfile}" > "${graph_dir}/rebuild.${ext}"
rm -f "${tmpfile}"
}
usage() {
printf "Usage: %s [options] <package|packages>\n" "${0##*/}"
printf " -m <tree|rebuild> default mode: [%s]\n" "$mode"
printf " rebuild mode accepts packages input\n"
printf " -r list packages that depend on the named package (tree)\n"
printf " -u show dependencies with no duplicates (tree)\n"
printf " -d <#> limit the depth of recursion (tree)\n"
printf " default: [%s]\n" "$depth"
printf " -o <#> controls at which depth to stop printing optional deps\n"
printf " default: [%s]\n" "$optdepth"
printf " (-1 for no limit) (tree)\n"
printf " -i only use the pkgnames provided as input (rebuild)\n"
printf " -h display this help message\n"
exit "$1"
}
graph_dir=${XDG_PICTURES_DIR:-$(xdg-user-dir PICTURES)/artix}
ext="png"
mode=tree
tree_args=(-gs)
rebuild_args=()
depth=0
optdepth=-1
opts=':m:d:o:iruh'
while getopts "$opts" arg; do
case "${arg}" in
m) mode="$OPTARG" ;;
r) tree_args+=(-r) ;;
u) tree_args+=(-ul) ;;
d) depth="$OPTARG"; tree_args+=(-d "$depth") ;;
o) optdepth="$OPTARG"; tree_args+=(-o"$optdepth") ;;
i) rebuild_args+=(--no-reverse-depends) ;;
h|?) usage 0 ;;
esac
done
shift $(( OPTIND - 1 ))
[[ -d "${graph_dir}" ]] || mkdir -p "${graph_dir}"
case "$mode" in
tree) package=("$@"); mk_tree_graph ;;
rebuild) packages=("$@"); mk_rebuild_graph ;;
*) usage 1 ;;
esac

View File

@@ -146,16 +146,16 @@ write_srcyaml(){
yaml_write_global yaml_write_global
yaml_write_package yaml_write_package
yaml_write_fileinfo yaml_write_fileinfo
printf '%s' "${Yaml}" printf '%s\n' "${Yaml}"
} }
#}}} #}}}
usage() { usage() {
echo "Usage: ${0##*/} [options]" printf 'Usage: %s [options]\n' "${0##*/}"
echo " -d Don't include details" printf ' -d Do not include details\n'
echo ' -h This help' printf ' -h This help\n'
echo '' printf '\n'
exit "$1" exit "$1"
} }
@@ -167,7 +167,6 @@ while getopts "${opts}" arg; do
case "${arg}" in case "${arg}" in
d) details=false ;; d) details=false ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done

202
bin/pkg/tidyarch.in Normal file
View File

@@ -0,0 +1,202 @@
#!/bin/bash
#
# Copyright (C) 2018-20 artoo@artixlinux.org
# Copyright (C) 2018 Artix Linux Developers
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
m4_include(lib/util-base.sh)
m4_include(lib/util-pkg.sh)
m4_include(lib/base/message.sh)
m4_include(lib/pkg/repo.sh)
git_rm() {
local r="$1"
if ! "$run_f"; then
printf "git rm -r %s\n" "$r"
printf "git commit -m 'remove %s'\n" "${r##*/}"
else
git rm -r "$r"
git commit -m "remove ${r##*/}"
fi
}
compare_ver() {
local a="$1" b="$2" tree="$3" func="$4" va vb
# shellcheck disable=1090
source "$a"/PKGBUILD 2>/dev/null
va=$(get_full_version)
unset pkgver epoch pkgrel arch
# shellcheck disable=1090
source "$b"/PKGBUILD 2>/dev/null
vb=$(get_full_version)
unset pkgver epoch pkgrel arch
msg2 "a: %s b: %s" "$va" "$vb"
local ret
ret=$(vercmp "$va" "$vb")
msg2 "ret: %s" "$ret"
if [ "$ret" -gt 0 ]; then
git_rm "$b"
elif [ "$ret" -lt 0 ]; then
git_rm "$a"
else
case "$tree" in
"${ARCH_TREE[0]}") git_rm "$a" ;;
"${ARCH_TREE[1]}") git_rm "$b" ;;
esac
fi
}
check_duplicates() {
mapfile -t duplicates < <(find "${TREE_DIR_ARCH}" -mindepth 2 -maxdepth 2 -type d -not -path "*.git" -printf '%f\n' | sort | uniq -d)
for p in "${duplicates[@]}"; do
msg "%s" "$p"
local av bv a b
a="${TREE_DIR_ARCH}/${ARCH_TREE[0]}"
# shellcheck disable=1090
source "$a/$p"/trunk/PKGBUILD 2>/dev/null
av=$(get_full_version)
b="${TREE_DIR_ARCH}/${ARCH_TREE[1]}"
# shellcheck disable=1090
source "$b/$p"/trunk/PKGBUILD 2>/dev/null
bv=$(get_full_version)
msg2 "a: %s b: %s" "$av" "$bv"
ret=$(vercmp "$av" "$bv")
msg2 "ret: %s" "$ret"
if [ "$ret" -gt 0 ]; then
cd "$b"
msg2 "%s" "${b##*/}"
git_rm "$p"
elif [ "$ret" -lt 0 ]; then
cd "$a"
msg2 "%s" "${a##*/}"
git_rm "$p"
fi
done
}
# git config core.mergeoptions --no-edit
check_tree() {
for tree in "${ARCH_TREE[@]}"; do
cd "${TREE_DIR_ARCH}/$tree" || exit
mapfile -t pkgs < <(find . -mindepth 2 -maxdepth 2 -type d -name repos | sort)
for p in "${pkgs[@]}"; do
mapfile -t repos < <(find "$p" -mindepth 1 -maxdepth 1 -type d -printf '%f\n' | sort)
local repos_dir=$p
p=${p%/*}
p=${p##*/}
local size=${#repos[@]}
if (( "$size" > 1 )); then
if [[ "${repos[1]}" != "${valid_names[11]}"-* ]] || [[ "${repos[1]}" != "${valid_names[12]}"-* ]]; then
local a="$repos_dir/${repos[0]}" b="$repos_dir/${repos[1]}"
# repo mismatches
if [[ "${repos[0]}" == "${valid_names[2]}"-* ]] && [[ "${repos[1]}" == "${valid_names[1]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[2]}"-* ]] && [[ "${repos[1]}" == "${valid_names[7]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[2]}"-* ]] && [[ "${repos[1]}" == "${valid_names[4]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[0]}"-* ]] && [[ "${repos[1]}" == "${valid_names[1]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[2]}"-* ]] && [[ "${repos[1]}" == "${valid_names[0]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[3]}"-* ]] && [[ "${repos[1]}" == "${valid_names[7]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[3]}"-* ]] && [[ "${repos[1]}" == "${valid_names[4]}"-* ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
fi
# same repo name but different arch
if [[ "${repos[0]}" == "${valid_names[0]}"-any ]] && [[ "${repos[1]}" == "${valid_names[0]}"-"$CARCH" ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[1]}"-any ]] && [[ "${repos[1]}" == "${valid_names[1]}"-"$CARCH" ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
elif [[ "${repos[0]}" == "${valid_names[2]}"-any ]] && [[ "${repos[1]}" == "${valid_names[2]}"-"$CARCH" ]]; then
msg "%s: %s" "$p" "${repos[*]}"
msg2 "%s" "$tree"
compare_ver "$a" "$b" "$tree"
fi
fi
fi
done
done
}
usage() {
printf 'Usage: %s\n' "${0##*/}"
printf ' -f Apply filter\n'
printf ' -r Run removal\n'
printf ' -d Check for duplicates\n'
printf ' -h This help\n'
printf '\n'
printf '\n'
exit "$1"
}
load_makepkg_config
load_valid_names
filter=false
dupl=false
run_f=false
opts='hrfd'
while getopts ${opts} arg; do
case "${arg}" in
f) filter=true ;;
r) run_f=true ;;
d) dupl=true ;;
h|?) usage 0 ;;
esac
done
shift $(( OPTIND - 1 ))
"$filter" && check_tree
"$dupl" && check_duplicates

View File

@@ -7,41 +7,13 @@
# TREE_DIR_ARTIX=${WORKSPACE_DIR}/artixlinux # TREE_DIR_ARTIX=${WORKSPACE_DIR}/artixlinux
# customize buildtree; uncomment to include # customize buildtree
# TREE_NAMES_ARTIX=( # ARTIX_TREE=(
# packages-kernel # main
# packages-llvm # initsys
# packages-openrc # desktop
# packages-runit # addons
# packages-s6 # lib32
# packages-suite66
# packages-dinit
# packages-perl
# packages-java
# packages-ruby
# packages-gtk
# packages-qt5
# packages-qt6
# packages-xorg
# packages-plasma
# packages-kde
# packages-gnome
# packages-cinnamon
# packages-lxqt
# packages-lxde
# packages-mate
# packages-xfce
# packages-wm
# packages-devel
# packages-qt6
# packages-office
# packages-misc
# python-world
# python-galaxy
# python-galaxy-groups
# python-misc
# packages-python
# packages-lib32
# ) # )
# TREE_DIR_ARCH=${WORKSPACE_DIR}/archlinux # TREE_DIR_ARCH=${WORKSPACE_DIR}/archlinux

View File

@@ -45,13 +45,14 @@ CFLAGS="-march=x86-64 -mtune=generic -O2 -pipe -fno-plt -fexceptions \
-fstack-clash-protection -fcf-protection" -fstack-clash-protection -fcf-protection"
CXXFLAGS="$CFLAGS -Wp,-D_GLIBCXX_ASSERTIONS" CXXFLAGS="$CFLAGS -Wp,-D_GLIBCXX_ASSERTIONS"
LDFLAGS="-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now" LDFLAGS="-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now"
#RUSTFLAGS="-C opt-level=2" LTOFLAGS="-flto=auto"
RUSTFLAGS=""
#-- Make Flags: change this for DistCC/SMP systems #-- Make Flags: change this for DistCC/SMP systems
#MAKEFLAGS="-j2" #MAKEFLAGS="-j2"
#-- Debugging flags #-- Debugging flags
DEBUG_CFLAGS="-g" DEBUG_CFLAGS="-g"
DEBUG_CXXFLAGS="-g" DEBUG_CXXFLAGS="$DEBUG_CFLAGS"
#DEBUG_RUSTFLAGS="-C debuginfo=2" DEBUG_RUSTFLAGS="-C debuginfo=2"
######################################################################### #########################################################################
# BUILD ENVIRONMENT # BUILD ENVIRONMENT

View File

@@ -9,8 +9,6 @@
export LANG=C export LANG=C
shopt -s extglob
if [[ -t 2 && "$TERM" != dumb ]]; then if [[ -t 2 && "$TERM" != dumb ]]; then
colorize colorize
else else

View File

@@ -3,11 +3,11 @@
#{{{ yaml #{{{ yaml
write_yaml_header(){ write_yaml_header(){
printf '%s' '---' printf '%s\n' '---'
} }
write_empty_line(){ write_empty_line(){
printf '\n%s\n' ' ' printf '\n'
} }
write_yaml_map(){ write_yaml_map(){

View File

@@ -13,7 +13,7 @@ write_services_conf(){
yaml+=$(write_yaml_seq 2 "$svc") yaml+=$(write_yaml_seq 2 "$svc")
done done
yaml+=$(write_empty_line) yaml+=$(write_empty_line)
printf '%s' "${yaml}" printf '%s\n' "${yaml}"
} }
write_services_openrc_conf(){ write_services_openrc_conf(){
@@ -29,6 +29,7 @@ write_services_runit_conf(){
write_services_s6_conf(){ write_services_s6_conf(){
local conf="$1"/services-s6.conf local conf="$1"/services-s6.conf
write_services_conf 'svDir' '/etc/s6/sv' 'dbDir' '/etc/s6/rc/compiled' > "$conf" write_services_conf 'svDir' '/etc/s6/sv' 'dbDir' '/etc/s6/rc/compiled' > "$conf"
printf '%s\n' "defaultBundle: default" >> "$conf"
} }
write_services_suite66_conf(){ write_services_suite66_conf(){

View File

@@ -5,13 +5,13 @@
get_disturl(){ get_disturl(){
# shellcheck disable=1091 # shellcheck disable=1091
. /usr/lib/os-release . /usr/lib/os-release
echo "${HOME_URL}" printf "%s\n" "${HOME_URL}"
} }
get_osname(){ get_osname(){
# shellcheck disable=1091 # shellcheck disable=1091
. /usr/lib/os-release . /usr/lib/os-release
echo "${NAME}" printf "%s\n" "${NAME}"
} }
assemble_iso(){ assemble_iso(){

View File

@@ -56,7 +56,8 @@ read_from_list() {
read_from_services() { read_from_services() {
for svc in "${SERVICES[@]}"; do for svc in "${SERVICES[@]}"; do
case "$svc" in case "$svc" in
sddm|gdm|lightdm|mdm|greetd|lxdm|xdm) packages+=("$svc-${INITSYS}") ;; sddm|gdm|lightdm|mdm|greetd|lxdm|xdm)
packages+=("$svc-${INITSYS}"); display_manager="$svc" ;;
NetworkManager) packages+=("networkmanager-${INITSYS}") ;; NetworkManager) packages+=("networkmanager-${INITSYS}") ;;
connmand) packages+=("connman-${INITSYS}") ;; connmand) packages+=("connman-${INITSYS}") ;;
cupsd) packages+=("cups-${INITSYS}") ;; cupsd) packages+=("cups-${INITSYS}") ;;

View File

@@ -23,25 +23,26 @@ add_svc_runit(){
} }
add_svc_s6(){ add_svc_s6(){
local mnt="$1" names="$2" rlvl="${3:-default}" error ret local mnt="$1" names="$2" rlvl="${3:-default}" dep
local db=/etc/s6/rc/compiled dep="$mnt"/etc/s6/sv/"$display_manager"-srv/dependencies.d
for svc in $names; do for svc in $names; do
error=false msg2 "Setting %s: [%s]" "${INITSYS}" "$svc"
chroot "$mnt" s6-rc-db -c "$db" type "$svc" &> /dev/null || error=true chroot "$mnt" s6-service add "$rlvl" "$svc"
ret="$?" if [[ "$svc" == "$display_manager" ]]; then
if [ $ret -eq 0 ] && [[ "$error" == false ]]; then if [[ -d "$dep" ]]; then
msg2 "Setting %s: [%s]" "${INITSYS}" "$svc" touch "$dep"/artix-live
chroot "$mnt" touch /etc/s6/adminsv/default/contents.d/"$svc" fi
fi fi
done done
chroot "$mnt" s6-db-reload
local rlvl=/etc/s6/current chroot "$mnt" s6-db-reload -r
local src=/etc/s6/current skel=/etc/s6/skel getty='/usr/bin/agetty -L -8 tty7 115200'
# rebuild s6-linux-init binaries # rebuild s6-linux-init binaries
chroot "$mnt" rm -r "$rlvl" chroot "$mnt" rm -r "$src"
chroot "$mnt" s6-linux-init-maker -1 -N -f /etc/s6/skel -G "/usr/bin/agetty -L -8 tty7 115200" -c "$rlvl" "$rlvl" chroot "$mnt" s6-linux-init-maker -1 -N -f "$skel" -G "$getty" -c "$src" "$src"
chroot "$mnt" mv "$rlvl"/bin/init "$rlvl"/bin/s6-init chroot "$mnt" mv "$src"/bin/init "$src"/bin/s6-init
chroot "$mnt" cp -a "$rlvl"/bin /usr chroot "$mnt" cp -a "$src"/bin /usr
} }
add_svc_suite66(){ add_svc_suite66(){

View File

@@ -5,9 +5,10 @@
get_compliant_name(){ get_compliant_name(){
local gitname="$1" local gitname="$1"
case "$gitname" in case "$gitname" in
*+) gitname=${gitname//+/plus} *+) gitname=${gitname//+/plus} ;;
*+*) gitname=${gitname//+/-} ;;
esac esac
echo "$gitname" printf "%s\n" "$gitname"
} }
get_pkg_org(){ get_pkg_org(){
@@ -18,7 +19,7 @@ get_pkg_org(){
python-*|python2-*) org="packagesPython" ;; python-*|python2-*) org="packagesPython" ;;
*) sub=${pkg:0:1}; org="packages${sub^^}" ;; *) sub=${pkg:0:1}; org="packages${sub^^}" ;;
esac esac
echo "$org" printf "%s\n" "$org"
} }
api_put() { api_put() {

View File

@@ -2,6 +2,8 @@
#{{{ functions #{{{ functions
shopt -s extglob
find_cached_pkgfile() { find_cached_pkgfile() {
local searchdirs=("$PKGDEST" "$PWD") results=() local searchdirs=("$PKGDEST" "$PWD") results=()
local pkg="$1" local pkg="$1"
@@ -25,13 +27,15 @@ find_cached_pkgfile() {
esac esac
} }
shopt -u extglob
get_pkgbasename() { get_pkgbasename() {
local name="$1" local name="$1"
local rm_pkg=${name%.pkg.tar*} local rm_pkg=${name%.pkg.tar*}
rm_pkg=${rm_pkg%-*} rm_pkg=${rm_pkg%-*}
rm_pkg=${rm_pkg%-*} rm_pkg=${rm_pkg%-*}
rm_pkg=${rm_pkg%-*} rm_pkg=${rm_pkg%-*}
echo "$rm_pkg" printf "%s\n" "$rm_pkg"
} }
#}}} #}}}

75
lib/pkg/diff.sh Normal file
View File

@@ -0,0 +1,75 @@
#!/hint/bash
#{{{ functions
pkgver_equal() {
if [[ $1 = *-* && $2 = *-* ]]; then
# if both versions have a pkgrel, then they must be an exact match
[[ $1 = "$2" ]]
else
# otherwise, trim any pkgrel and compare the bare version.
[[ ${1%%-*} = "${2%%-*}" ]]
fi
}
shopt -s extglob
find_cached_package() {
local searchdirs=("$PWD" "$PKGDEST") results=()
local targetname=$1 targetver=$2 targetarch=$3
local dir pkg packages pkgbasename name ver rel arch r results
for dir in "${searchdirs[@]}"; do
[[ -d $dir ]] || continue
shopt -s extglob nullglob
mapfile -t packages < <(printf "%s\n" "$dir"/"${targetname}"-"${targetver}"-*"${targetarch}".pkg.tar?(.!(sig|*.*)))
shopt -u extglob nullglob
for pkg in "${packages[@]}"; do
[[ -f $pkg ]] || continue
# avoid adding duplicates of the same inode
for r in "${results[@]}"; do
[[ $r -ef $pkg ]] && continue 2
done
# split apart package filename into parts
pkgbasename=${pkg##*/}
pkgbasename=${pkgbasename%.pkg.tar*}
arch=${pkgbasename##*-}
pkgbasename=${pkgbasename%-"$arch"}
rel=${pkgbasename##*-}
pkgbasename=${pkgbasename%-"$rel"}
ver=${pkgbasename##*-}
name=${pkgbasename%-"$ver"}
if [[ $targetname = "$name" && $targetarch = "$arch" ]] &&
pkgver_equal "$targetver" "$ver-$rel"; then
results+=("$pkg")
fi
done
done
case ${#results[*]} in
0)
return 1
;;
1)
printf '%s\n' "${results[0]}"
return 0
;;
*)
error 'Multiple packages found:'
printf '\t%s\n' "${results[@]}" >&2
return 1
;;
esac
}
shopt -u extglob
#}}}

View File

@@ -22,12 +22,9 @@ has_changeset(){
} }
pull_tree(){ pull_tree(){
local tree="$1" local_head="$2" os="${3:-Artix}" local tree="$1" lh="$2" rh
local remote_head rh=$(get_remote_head)
remote_head=$(get_remote_head) if has_changeset "${lh}" "${rh}";then
msg "Checking (%s) (%s)" "${tree}" "$os"
if has_changeset "${local_head}" "${remote_head}";then
git pull origin master git pull origin master
fi fi
} }

View File

@@ -6,11 +6,11 @@ write_jenkinsfile(){
local pkg="$1" local pkg="$1"
local jenkins=$pkg/Jenkinsfile local jenkins=$pkg/Jenkinsfile
echo "@Library('artix-ci') import org.artixlinux.RepoPackage" > "$jenkins" printf "@Library('artix-ci') import org.artixlinux.RepoPackage\n" > "$jenkins"
{ {
echo '' printf '\n'
echo 'PackagePipeline(new RepoPackage(this))' printf 'PackagePipeline(new RepoPackage(this))\n'
echo '' printf '\n'
} >> "$jenkins" } >> "$jenkins"
git add "$jenkins" git add "$jenkins"
@@ -21,23 +21,23 @@ write_agentyaml(){
local agent="$pkg"/.artixlinux/agent.yaml label='master' local agent="$pkg"/.artixlinux/agent.yaml label='master'
[[ -d $pkg/.artixlinux ]] || mkdir "$pkg"/.artixlinux [[ -d $pkg/.artixlinux ]] || mkdir "$pkg"/.artixlinux
echo '---' > "$agent" printf '%s\n' '---' > "$agent"
{ {
echo '' printf '\n'
echo "label: $label" printf "label: %s\n" "$label"
echo '' printf '\n'
} >> "$agent" } >> "$agent"
git add "$agent" git add "$agent"
} }
commit_jenkins_files(){ commit_ci(){
local pkg="$1" local pkg="$1"
write_jenkinsfile "$pkg" write_jenkinsfile "$pkg"
write_agentyaml "$pkg" write_agentyaml "$pkg"
git commit -m "initial commit" git commit -m "initial ci commit"
} }
#}}} #}}}

View File

@@ -25,25 +25,25 @@ set_arch_repos(){
find_repo(){ find_repo(){
local pkg="$1" pkgarch="${2:-${CARCH}}" repo local pkg="$1" pkgarch="${2:-${CARCH}}" repo
for r in "${ARCH_REPOS[@]}"; do for r in "${ARCH_REPOS[@]}"; do
[[ -f $pkg/repos/$r-$pkgarch/PKGBUILD ]] && repo=repos/"$r-$pkgarch" [[ -f $pkg/repos/$r-$pkgarch/PKGBUILD ]] && repo="$r-$pkgarch"
[[ -f $pkg/repos/$r-any/PKGBUILD ]] && repo=repos/"$r"-any [[ -f $pkg/repos/$r-any/PKGBUILD ]] && repo="$r"-any
[[ -f $pkg/$pkgarch/$r/PKGBUILD ]] && repo="$pkgarch/$r" [[ -f $pkg/$pkgarch/$r/PKGBUILD ]] && repo="$r"
done done
echo "$repo" printf "%s\n" "$repo"
} }
find_pkg(){ find_pkg(){
local searchdir="$1" pkg="$2" result local searchdir="$1" pkg="$2" result
result=$(find "$searchdir" -mindepth 2 -maxdepth 2 -type d -name "$pkg") result=$(find "$searchdir" -mindepth 2 -maxdepth 2 -type d -name "$pkg")
echo "$result" printf "%s\n" "$result"
} }
tree_loop(){ tree_loop(){
local func="$1" pkgs local func="$1" pkgs
for tree in "${ARTIX_TREE[@]}"; do for tree in "${ARTIX_TREE[@]}"; do
pkgs=$(find "${TREE_DIR_ARTIX}/$tree" -name "$CARCH" | sort) mapfile -t pkgs < <(find "${TREE_DIR_ARTIX}/$tree" -name "$CARCH" | sort)
for _package in ${pkgs}; do for p in "${pkgs[@]}"; do
"$func" "$_package" "$func" "$p"
done done
done done
} }

View File

@@ -21,34 +21,8 @@ load_pkg_config(){
TREE_DIR_ARTIX=${TREE_DIR_ARTIX:-"${WORKSPACE_DIR}/artixlinux"} TREE_DIR_ARTIX=${TREE_DIR_ARTIX:-"${WORKSPACE_DIR}/artixlinux"}
ARTIX_TREE=( [[ -z ${ARTIX_TREE[*]} ]] && \
packages community ARTIX_TREE=(main initsys desktop addons lib32)
packages-{gfx,media,net}
)
local dev_tree=(
packages-{llvm,python,perl,java,ruby,misc}
python-{world,galaxy,galaxy-groups,misc}
)
local init_tree=(packages-{openrc,runit,s6,suite66,dinit})
local desktop_tree=(
packages-{kf5,plasma,kde,qt5,qt6,xorg,gtk}
packages-{lxqt,gnome,cinnamon,mate,xfce,wm,lxde}
)
[[ -z ${TREE_NAMES_ARTIX[*]} ]] && \
TREE_NAMES_ARTIX=(
packages-kernel
"${init_tree[@]}"
"${dev_tree[@]}"
"${desktop_tree[@]}"
packages-devel
packages-lib32
)
ARTIX_TREE+=("${TREE_NAMES_ARTIX[@]}")
TREE_DIR_ARCH=${TREE_DIR_ARCH:-"${WORKSPACE_DIR}/archlinux"} TREE_DIR_ARCH=${TREE_DIR_ARCH:-"${WORKSPACE_DIR}/archlinux"}