forked from artix/artools
		
	Compare commits
	
		
			36 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 1d85f8000c | |||
| 21c44dba79 | |||
| f4e3abae46 | |||
| a7cef500ad | |||
| f7c29d1c98 | |||
| f1b2af947b | |||
| 5637ba0f8f | |||
| a383531e5d | |||
| 6b4acbdd94 | |||
| b7fd0a4e41 | |||
| b734357ea9 | |||
| 74d44873e7 | |||
| 91e038c3f5 | |||
| 8548a584f3 | |||
| 38fb213e13 | |||
| fade611ae7 | |||
| 
						
						
							
						
						8cdb68ce6a
	
				 | 
					
					
						|||
| 7d949afeb7 | |||
| 6f037f6faf | |||
| ba1e6644ea | |||
| 3f90082cc1 | |||
| 915db85b7d | |||
| a5a29259e5 | |||
| c5f8bc7e20 | |||
| 11dd9be3f1 | |||
| f058b9155b | |||
| 7c3d1343e8 | |||
| 80b14b7f1f | |||
| 29a1e98c0e | |||
| 8bcb311bbd | |||
| 0c5816fac2 | |||
| 4b802be860 | |||
| 8621191465 | |||
| b019f42ee1 | |||
| 205d668630 | |||
| 3ae2972d2b | 
							
								
								
									
										21
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								Makefile
									
									
									
									
									
								
							@@ -1,11 +1,10 @@
 | 
				
			|||||||
VERSION=0.24
 | 
					V=0.26
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TOOLS = artools
 | 
					TOOLS = artools
 | 
				
			||||||
PREFIX ?= /usr
 | 
					PREFIX ?= /usr
 | 
				
			||||||
SYSCONFDIR = /etc
 | 
					SYSCONFDIR = /etc
 | 
				
			||||||
BINDIR = $(PREFIX)/bin
 | 
					BINDIR = $(PREFIX)/bin
 | 
				
			||||||
DATADIR = $(PREFIX)/share
 | 
					DATADIR = $(PREFIX)/share
 | 
				
			||||||
CPIODIR = $(SYSCONFDIR)/initcpio
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
BASE_CONF = \
 | 
					BASE_CONF = \
 | 
				
			||||||
	data/conf/artools-base.conf
 | 
						data/conf/artools-base.conf
 | 
				
			||||||
@@ -23,6 +22,8 @@ BASE_DATA = \
 | 
				
			|||||||
PKG_CONF = \
 | 
					PKG_CONF = \
 | 
				
			||||||
	data/conf/artools-pkg.conf
 | 
						data/conf/artools-pkg.conf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SETARCH_ALIASES = \
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_BIN = \
 | 
					PKG_BIN = \
 | 
				
			||||||
	bin/pkg/buildpkg \
 | 
						bin/pkg/buildpkg \
 | 
				
			||||||
	bin/pkg/deploypkg \
 | 
						bin/pkg/deploypkg \
 | 
				
			||||||
@@ -88,9 +89,6 @@ PKG_DATA = \
 | 
				
			|||||||
	data/pacman/makepkg.conf \
 | 
						data/pacman/makepkg.conf \
 | 
				
			||||||
	data/valid-names.conf
 | 
						data/valid-names.conf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PROTO = \
 | 
					 | 
				
			||||||
	$(wildcard data/proto/*.proto)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
PATCHES = \
 | 
					PATCHES = \
 | 
				
			||||||
	$(wildcard data/patches/*.patch)
 | 
						$(wildcard data/patches/*.patch)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -109,7 +107,7 @@ FILEMODE = -m0644
 | 
				
			|||||||
MODE =  -m0755
 | 
					MODE =  -m0755
 | 
				
			||||||
LN = ln -sf
 | 
					LN = ln -sf
 | 
				
			||||||
RM = rm -f
 | 
					RM = rm -f
 | 
				
			||||||
M4 = m4 -P
 | 
					M4 = m4 -P --define=m4_artools_pkg_version=$V
 | 
				
			||||||
CHMODAW = chmod a-w
 | 
					CHMODAW = chmod a-w
 | 
				
			||||||
CHMODX = chmod +x
 | 
					CHMODX = chmod +x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -141,6 +139,9 @@ install_base:
 | 
				
			|||||||
	install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)
 | 
						install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)
 | 
				
			||||||
	install $(FILEMODE) $(BASE_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS)
 | 
						install $(FILEMODE) $(BASE_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/setarch-aliases.d
 | 
				
			||||||
 | 
						for a in ${SETARCH_ALIASES}; do install $(FILEMODE) setarch-aliases.d/$$a $(DESTDIR)$(DATADIR)/$(TOOLS)/setarch-aliases.d; done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install_pkg:
 | 
					install_pkg:
 | 
				
			||||||
	install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
						install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
				
			||||||
	install $(FILEMODE) $(PKG_CONF) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
						install $(FILEMODE) $(PKG_CONF) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
				
			||||||
@@ -164,13 +165,7 @@ install_pkg:
 | 
				
			|||||||
	install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/patches
 | 
						install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/patches
 | 
				
			||||||
	install $(FILEMODE) $(PATCHES) $(DESTDIR)$(DATADIR)/$(TOOLS)/patches
 | 
						install $(FILEMODE) $(PATCHES) $(DESTDIR)$(DATADIR)/$(TOOLS)/patches
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/proto
 | 
					install_iso:
 | 
				
			||||||
	install $(FILEMODE) $(PROTO) $(DESTDIR)$(DATADIR)/$(TOOLS)/proto
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install_cpio:
 | 
					 | 
				
			||||||
	+make CPIODIR=$(CPIODIR) DESTDIR=$(DESTDIR) -C initcpio install
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install_iso: install_cpio
 | 
					 | 
				
			||||||
	install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
						install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
				
			||||||
	install $(FILEMODE) $(ISO_CONF) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
						install $(FILEMODE) $(ISO_CONF) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -30,7 +30,6 @@ artools
 | 
				
			|||||||
  * dosfstools
 | 
					  * dosfstools
 | 
				
			||||||
  * libisoburn
 | 
					  * libisoburn
 | 
				
			||||||
  * squashfs-tools
 | 
					  * squashfs-tools
 | 
				
			||||||
  * mkinitcpio
 | 
					 | 
				
			||||||
  * grub
 | 
					  * grub
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Configuration
 | 
					#### Configuration
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -32,6 +32,7 @@ kill_chroot_process(){
 | 
				
			|||||||
            fi
 | 
					            fi
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
 | 
					    sleep 1
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# umask might have been changed in /etc/profile
 | 
					# umask might have been changed in /etc/profile
 | 
				
			||||||
@@ -84,14 +85,12 @@ shift 1
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
[[ -z $working_dir ]] && die 'Please specify a working directory.'
 | 
					[[ -z $working_dir ]] && die 'Please specify a working directory.'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
pacconf_cmd=$(command -v pacman-conf || command -v pacconf)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if (( ${#cache_dirs[@]} == 0 )); then
 | 
					if (( ${#cache_dirs[@]} == 0 )); then
 | 
				
			||||||
    mapfile -t cache_dirs < <($pacconf_cmd --config "${pac_conf:-$working_dir/etc/pacman.conf}" CacheDir)
 | 
					    mapfile -t cache_dirs < <(pacman-conf --config "${pac_conf:-$working_dir/etc/pacman.conf}" CacheDir)
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# shellcheck disable=2016
 | 
					# shellcheck disable=2016
 | 
				
			||||||
host_mirrors=($("$pacconf_cmd" --repo world Server 2> /dev/null | sed -r 's#(.*/)world/os/.*#\1$repo/os/$arch#'))
 | 
					host_mirrors=($(pacman-conf --repo world Server 2> /dev/null | sed -r 's#(.*/)world/os/.*#\1$repo/os/$arch#'))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
for host_mirror in "${host_mirrors[@]}"; do
 | 
					for host_mirror in "${host_mirrors[@]}"; do
 | 
				
			||||||
    if [[ $host_mirror == *file://* ]]; then
 | 
					    if [[ $host_mirror == *file://* ]]; then
 | 
				
			||||||
@@ -103,7 +102,7 @@ done
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
while read -r line; do
 | 
					while read -r line; do
 | 
				
			||||||
    # shellcheck disable=2016
 | 
					    # shellcheck disable=2016
 | 
				
			||||||
    mapfile -t lines < <($pacconf_cmd --config "${pac_conf:-$working_dir/etc/pacman.conf}" \
 | 
					    mapfile -t lines < <(pacman-conf --config "${pac_conf:-$working_dir/etc/pacman.conf}" \
 | 
				
			||||||
        --repo "$line" Server | sed -r 's#(.*/)[^/]+/os/.+#\1#')
 | 
					        --repo "$line" Server | sed -r 's#(.*/)[^/]+/os/.+#\1#')
 | 
				
			||||||
    for line in "${lines[@]}"; do
 | 
					    for line in "${lines[@]}"; do
 | 
				
			||||||
        if [[ $line = file://* ]]; then
 | 
					        if [[ $line = file://* ]]; then
 | 
				
			||||||
@@ -111,7 +110,7 @@ while read -r line; do
 | 
				
			|||||||
            in_array "$line" "${cache_dirs[@]}" || cache_dirs+=("$line")
 | 
					            in_array "$line" "${cache_dirs[@]}" || cache_dirs+=("$line")
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
done < <("$pacconf_cmd" --config "${pac_conf:-$working_dir/etc/pacman.conf}" --repo-list)
 | 
					done < <(pacman-conf --config "${pac_conf:-$working_dir/etc/pacman.conf}" --repo-list)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
copy_hostconf () {
 | 
					copy_hostconf () {
 | 
				
			||||||
    unshare --fork --pid gpg --homedir "$working_dir"/etc/pacman.d/gnupg/ --no-permission-warning --quiet --batch --import --import-options import-local-sigs "$(pacman-conf GpgDir)"/pubring.gpg >/dev/null 2>&1
 | 
					    unshare --fork --pid gpg --homedir "$working_dir"/etc/pacman.d/gnupg/ --no-permission-warning --quiet --batch --import --import-options import-local-sigs "$(pacman-conf GpgDir)"/pubring.gpg >/dev/null 2>&1
 | 
				
			||||||
@@ -167,7 +166,13 @@ eval "$(grep '^CARCH=' "$working_dir/etc/makepkg.conf")"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
[[ -z $nosetarch ]] || unset CARCH
 | 
					[[ -z $nosetarch ]] || unset CARCH
 | 
				
			||||||
 | 
					
 | 
				
			||||||
${CARCH:+setarch "$CARCH"} chroot "${working_dir}" "$@"
 | 
					if [[ -f "@datadir@/artools/setarch-aliases.d/${CARCH}" ]]; then
 | 
				
			||||||
 | 
						read -r set_arch < "@datadir@/artools/setarch-aliases.d/${CARCH}"
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
						set_arch="${CARCH}"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					${CARCH:+setarch "${set_arch}"} chroot "${working_dir}" "$@"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ret=$?
 | 
					ret=$?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -64,10 +64,8 @@ shift 1
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
[[ -z $working_dir ]] && die 'Please specify a working directory.'
 | 
					[[ -z $working_dir ]] && die 'Please specify a working directory.'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
pacconf_cmd=$(command -v pacman-conf || command -v pacconf)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if (( ${#cache_dirs[@]} == 0 )); then
 | 
					if (( ${#cache_dirs[@]} == 0 )); then
 | 
				
			||||||
	mapfile -t cache_dirs < <($pacconf_cmd CacheDir)
 | 
						mapfile -t cache_dirs < <(pacman-conf CacheDir)
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
umask 0022
 | 
					umask 0022
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -138,7 +138,7 @@ make_bootfs() {
 | 
				
			|||||||
        if "${use_dracut}"; then
 | 
					        if "${use_dracut}"; then
 | 
				
			||||||
            prepare_initramfs_dracut "${bootfs}"
 | 
					            prepare_initramfs_dracut "${bootfs}"
 | 
				
			||||||
        else
 | 
					        else
 | 
				
			||||||
            prepare_initramfs "${bootfs}"
 | 
					            prepare_initramfs_mkinitcpio "${bootfs}"
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        umount_overlayfs
 | 
					        umount_overlayfs
 | 
				
			||||||
@@ -161,7 +161,7 @@ make_grub(){
 | 
				
			|||||||
        if ${use_dracut}; then
 | 
					        if ${use_dracut}; then
 | 
				
			||||||
            configure_grub_dracut
 | 
					            configure_grub_dracut
 | 
				
			||||||
        else
 | 
					        else
 | 
				
			||||||
            configure_grub
 | 
					            configure_grub_mkinitcpio
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        : > "${work_dir}"/grub.lock
 | 
					        : > "${work_dir}"/grub.lock
 | 
				
			||||||
@@ -207,6 +207,10 @@ prepare_build(){
 | 
				
			|||||||
    live_dir=/LiveOS
 | 
					    live_dir=/LiveOS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    mnt_dir=${chroots_iso}/${profile}/mnt
 | 
					    mnt_dir=${chroots_iso}/${profile}/mnt
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if [[ -n "${GPG_KEY}" ]]; then
 | 
				
			||||||
 | 
					        ${use_dracut} || export_gpg_publickey
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
display_settings(){
 | 
					display_settings(){
 | 
				
			||||||
@@ -217,6 +221,8 @@ display_settings(){
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    msg "ISO SETTINGS:"
 | 
					    msg "ISO SETTINGS:"
 | 
				
			||||||
    msg2 "ISO_VERSION: %s" "${ISO_VERSION}"
 | 
					    msg2 "ISO_VERSION: %s" "${ISO_VERSION}"
 | 
				
			||||||
 | 
					    msg2 "COMPRESSION: %s" "${COMPRESSION}"
 | 
				
			||||||
 | 
					    [[ "${COMPRESSION}" == 'zstd' ]] && msg2 "COMPRESSION_LEVEL: %s" "${COMPRESSION_LEVEL}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg "BUILD:"
 | 
					    msg "BUILD:"
 | 
				
			||||||
    show_profile
 | 
					    show_profile
 | 
				
			||||||
@@ -328,7 +334,7 @@ usage() {
 | 
				
			|||||||
    echo '    -i <name>          Init system to use'
 | 
					    echo '    -i <name>          Init system to use'
 | 
				
			||||||
    echo "                       [default: ${INITSYS}]"
 | 
					    echo "                       [default: ${INITSYS}]"
 | 
				
			||||||
    echo '    -g <key>           The gpg key for img signing'
 | 
					    echo '    -g <key>           The gpg key for img signing'
 | 
				
			||||||
    echo "                       [default: ${GPG_KEY}]"
 | 
					    echo "                       [default: none]"
 | 
				
			||||||
    echo '    -m                 Set SquashFS image mode to persistence'
 | 
					    echo '    -m                 Set SquashFS image mode to persistence'
 | 
				
			||||||
    echo '    -c                 Disable clean work dir'
 | 
					    echo '    -c                 Disable clean work dir'
 | 
				
			||||||
    echo '    -x                 Build chroot only'
 | 
					    echo '    -x                 Build chroot only'
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -72,6 +72,12 @@ get_pacman_conf "${repo}"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
get_makepkg_conf
 | 
					get_makepkg_conf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [[ -f "${DATADIR}/setarch-aliases.d/${arch}" ]]; then
 | 
				
			||||||
 | 
						read -r set_arch < "${DATADIR}/setarch-aliases.d/${arch}"
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
						set_arch="${arch}"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
check_root SOURCE_DATE_EPOCH,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER,GNUPGHOME
 | 
					check_root SOURCE_DATE_EPOCH,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER,GNUPGHOME
 | 
				
			||||||
 | 
					
 | 
				
			||||||
mkchrootpkg_args+=("${@:$OPTIND}")
 | 
					mkchrootpkg_args+=("${@:$OPTIND}")
 | 
				
			||||||
@@ -92,7 +98,7 @@ if ${create_first} || [[ ! -d "${chroots_pkg}/${repo}-${arch}" ]];then
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    rm -rf --one-file-system "${chroots_pkg}/${repo}-${arch}"
 | 
					    rm -rf --one-file-system "${chroots_pkg}/${repo}-${arch}"
 | 
				
			||||||
    (umask 0022; mkdir -p "${chroots_pkg}/${repo}-${arch}")
 | 
					    (umask 0022; mkdir -p "${chroots_pkg}/${repo}-${arch}")
 | 
				
			||||||
    setarch "${arch}" mkchroot \
 | 
					    setarch "${set_arch}" mkchroot \
 | 
				
			||||||
        -C "${pacman_conf}" \
 | 
					        -C "${pacman_conf}" \
 | 
				
			||||||
        -M "${makepkg_conf}" \
 | 
					        -M "${makepkg_conf}" \
 | 
				
			||||||
        "${chroots_pkg}/${repo}-${arch}/root" \
 | 
					        "${chroots_pkg}/${repo}-${arch}/root" \
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -117,6 +117,7 @@ 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
 | 
				
			||||||
    case $pkg in
 | 
					    case $pkg in
 | 
				
			||||||
        glibc)
 | 
					        glibc)
 | 
				
			||||||
            msg2 "Patching %s" "$pkg"
 | 
					            msg2 "Patching %s" "$pkg"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,19 +18,42 @@ m4_include(lib/base/message.sh)
 | 
				
			|||||||
m4_include(lib/pkg/repo.sh)
 | 
					m4_include(lib/pkg/repo.sh)
 | 
				
			||||||
m4_include(lib/pkg/table.sh)
 | 
					m4_include(lib/pkg/table.sh)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#{{{ db libs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extract_db() {
 | 
				
			||||||
 | 
					    local u="$1" cdir="$2"
 | 
				
			||||||
 | 
					    rm -rf "$cdir"
 | 
				
			||||||
 | 
					    mkdir -p "$cdir"
 | 
				
			||||||
 | 
					    msg2 "%s" "${cdir##*/}"
 | 
				
			||||||
 | 
					    curl -L -s "$u" | bsdtar -xf - -C "$cdir"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					update_db_cache(){
 | 
				
			||||||
 | 
					    msg "Updating database cache ..."
 | 
				
			||||||
 | 
					    local cachedir url
 | 
				
			||||||
 | 
					    for repo in "${searchrepos[@]}"; do
 | 
				
			||||||
 | 
					        cachedir=${db_cache_dir}/linksdb/$repo
 | 
				
			||||||
 | 
					        url=${REPOS_MIRROR}/$repo/os/${CARCH}/$repo.${linksdb_ext}
 | 
				
			||||||
 | 
					        extract_db "$url" "$cachedir"
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					    msg "Done"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#}}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#{{{ sogrep
 | 
					#{{{ sogrep
 | 
				
			||||||
 | 
					
 | 
				
			||||||
query_db() {
 | 
					query_db() {
 | 
				
			||||||
    for repo in "${searchrepos[@]}"; do
 | 
					    for repo in "${searchrepos[@]}"; do
 | 
				
			||||||
        local db
 | 
					        local db
 | 
				
			||||||
        db=${db_cache_dir}/${linksdb_ext}/${CARCH}/${repo}/
 | 
					        db=${db_cache_dir}/linksdb/$repo/
 | 
				
			||||||
        if [[ -d ${db} ]]; then
 | 
					        if [[ -d ${db} ]]; then
 | 
				
			||||||
            while read -rd '' pkg; do
 | 
					            while read -rd '' pkg; do
 | 
				
			||||||
                read -r match
 | 
					                read -r match
 | 
				
			||||||
                pkg=${pkg#${db}}
 | 
					                pkg=${pkg#${db}}
 | 
				
			||||||
                pkg="${pkg%/*}"
 | 
					                pkg="${pkg%/*}"
 | 
				
			||||||
                msg_row "${tableQ}" "${repo}" "${pkg}" "${match}"
 | 
					                msg_row "${tableQ}" "$repo" "$pkg" "${match}"
 | 
				
			||||||
            done < <(grep -rZ "${library}" "${db}") | sort -u
 | 
					            done < <(grep -rZ "$library" "$db") | sort -u
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -41,7 +64,7 @@ query_db() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
is_db_entry() {
 | 
					is_db_entry() {
 | 
				
			||||||
    local pkgname="$1" repo="${REPOS[$2]}" entry
 | 
					    local pkgname="$1" repo="${REPOS[$2]}" entry
 | 
				
			||||||
    entry=${db_cache_dir}/${linksdb_ext}/${CARCH}/$repo/$pkgname
 | 
					    entry=${db_cache_dir}/linksdb/$repo/$pkgname
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [[ -d "$entry" ]];then
 | 
					    if [[ -d "$entry" ]];then
 | 
				
			||||||
        return 0
 | 
					        return 0
 | 
				
			||||||
@@ -50,26 +73,74 @@ is_db_entry() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
check_db(){
 | 
					check_db(){
 | 
				
			||||||
    local pkgpath="${1%/*}"
 | 
					    local pkgpath="${1}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    for repo in "${!REPOS[@]}"; do
 | 
					    for repo in "${!REPOS[@]}"; do
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        local pkgbuild artixver
 | 
					        local pkgbuild artixver
 | 
				
			||||||
        [[ -f $pkgpath/$CARCH/$repo/PKGBUILD ]] && pkgbuild=$pkgpath/$CARCH/$repo/PKGBUILD
 | 
					        if [[ -f $pkgpath/$repo/PKGBUILD ]]; then
 | 
				
			||||||
        [[ -f $pkgpath/repos/$repo-$CARCH/PKGBUILD ]] && pkgbuild=$pkgpath/repos/$repo-$CARCH/PKGBUILD
 | 
					            pkgbuild=$pkgpath/$repo/PKGBUILD
 | 
				
			||||||
        [[ -f $pkgpath/repos/$repo-any/PKGBUILD ]] && pkgbuild=$pkgpath/repos/$repo-any/PKGBUILD
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # shellcheck disable=1090
 | 
					            # shellcheck disable=1090
 | 
				
			||||||
        . "$pkgbuild" 2>/dev/null
 | 
					            . "$pkgbuild" 2>/dev/null
 | 
				
			||||||
        artixver=$(get_full_version)
 | 
					            artixver=$(get_full_version)
 | 
				
			||||||
 | 
					            for name in "${pkgname[@]}"; do
 | 
				
			||||||
 | 
					                if ! is_db_entry "$name-$artixver" "$repo"; then
 | 
				
			||||||
 | 
					                    msg_row_red "${tableU}" "$repo" "$name" "$artixver" "false"
 | 
				
			||||||
 | 
					                else
 | 
				
			||||||
 | 
					                    ${all_db} && msg_row "${tableU}" "$repo" "$name" "$artixver" "true"
 | 
				
			||||||
 | 
					                fi
 | 
				
			||||||
 | 
					            done
 | 
				
			||||||
 | 
					            unset artixver pkgbuild pkgver epoch pkgname pkgbase
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for name in "${pkgname[@]}"; do
 | 
					#}}}
 | 
				
			||||||
            if ! is_db_entry "$name-$artixver" "$repo"; then
 | 
					
 | 
				
			||||||
                msg_row_red "${tableU}" "$repo" "$name" "$artixver" "false"
 | 
					# {{{ check obsolete
 | 
				
			||||||
            else
 | 
					
 | 
				
			||||||
                ${all_db} && msg_row "${tableU}" "$repo" "$name" "$artixver" "true"
 | 
					show_obsolete_table() {
 | 
				
			||||||
 | 
					    local arch_mirror='https://mirror.f4st.host/archlinux'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    local arch_repo artix_repo artix_db arch_db url
 | 
				
			||||||
 | 
					    arch_repo="${searchrepos[@]}"
 | 
				
			||||||
 | 
					    artix_repo="${REPOS[$arch_repo]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    artix_db="${db_cache_dir}/artixdb/${artix_repo}"
 | 
				
			||||||
 | 
					    arch_db="${db_cache_dir}/archdb/${arch_repo}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg "Updating database cache ..."
 | 
				
			||||||
 | 
					    url=${REPOS_MIRROR}/${artix_repo}/os/$CARCH/${artix_repo}.${db_ext}
 | 
				
			||||||
 | 
					    extract_db "$url" "${artix_db}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    url=${arch_mirror}/${arch_repo}/os/$CARCH/${arch_repo}.${db_ext}
 | 
				
			||||||
 | 
					    extract_db "$url" "${arch_db}"
 | 
				
			||||||
 | 
					    msg "Done"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_table_header "${tableQ}" "Repo" "Package" "Obsolete"
 | 
				
			||||||
 | 
					    for p in "${artix_db}"/*; do
 | 
				
			||||||
 | 
					        local pkg rel
 | 
				
			||||||
 | 
					        pkg=${p##*/}
 | 
				
			||||||
 | 
					        rel=${pkg##*-}
 | 
				
			||||||
 | 
					        rel=${rel%.*}
 | 
				
			||||||
 | 
					        pkg=${pkg%-*}
 | 
				
			||||||
 | 
					        local p="$pkg-$rel"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if [[ "$p" != *openrc* ]] && [[ "$p" != *runit* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *s6* ]] && [[ "$p" != *suite66* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *udev* ]] && [[ "$p" != *elogind* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *sysusers* ]] && [[ "$p" != *tmpfiles* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *execline* ]] && [[ "$p" != *skalibs* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *netifrc* ]] && [[ "$p" != *bootlogd* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *pam_rundir* ]] && [[ "$p" != *artools* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *archlinux* ]] && [[ "$p" != *iso-profiles* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *calamares* ]] && [[ "$p" != *iso-initcpio* ]] \
 | 
				
			||||||
 | 
					        && [[ "$p" != *dinit* ]] && [[ "$p" != *artix* ]] && [[ "$p" != *blocaled* ]]; then
 | 
				
			||||||
 | 
					            if [[ ! -d "${arch_db}/$p" ]]; then
 | 
				
			||||||
 | 
					                msg_row "${tableQ}" "${artix_repo}" "$p" "true"
 | 
				
			||||||
            fi
 | 
					            fi
 | 
				
			||||||
        done
 | 
					        fi
 | 
				
			||||||
        unset artixver pkgbuild pkgver epoch pkgname pkgbase
 | 
					 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -85,23 +156,10 @@ show_db_table(){
 | 
				
			|||||||
    tree_loop check_db
 | 
					    tree_loop check_db
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
update_db_cache(){
 | 
					 | 
				
			||||||
    msg "Updating database cache ..."
 | 
					 | 
				
			||||||
    local cachedir url
 | 
					 | 
				
			||||||
    for repo in "${searchrepos[@]}"; do
 | 
					 | 
				
			||||||
        cachedir=${db_cache_dir}/${linksdb_ext}/${CARCH}/${repo}
 | 
					 | 
				
			||||||
        rm -rf "$cachedir"
 | 
					 | 
				
			||||||
        mkdir -p "$cachedir"
 | 
					 | 
				
			||||||
        msg2 "%s" "$repo"
 | 
					 | 
				
			||||||
        url=${REPOS_MIRROR}/${repo}/os/${CARCH}/${repo}.${linksdb_ext}
 | 
					 | 
				
			||||||
        curl -L -s "$url" | bsdtar -xf - -C "$cachedir"
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
    msg "Done"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
db_cache_dir="${XDG_CACHE_HOME:-$USER_HOME/.cache}/artools"
 | 
					db_cache_dir="${XDG_CACHE_HOME:-$USER_HOME/.cache}/artools"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
linksdb_ext="links.tar.${DBEXT}"
 | 
					linksdb_ext="links.tar.${DBEXT}"
 | 
				
			||||||
 | 
					db_ext="db.tar.${DBEXT}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
load_makepkg_config
 | 
					load_makepkg_config
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -109,9 +167,10 @@ sync=false
 | 
				
			|||||||
check=false
 | 
					check=false
 | 
				
			||||||
query=false
 | 
					query=false
 | 
				
			||||||
all_db=false
 | 
					all_db=false
 | 
				
			||||||
 | 
					obsolete=false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
readonly tableU="%-20s %-35s %-30s %-10s"
 | 
					readonly tableU="%-20s %-35s %-30s %-10s"
 | 
				
			||||||
readonly tableQ="%-20s %-45s %s"
 | 
					readonly tableQ="%-20s %-55s %s"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
load_valid_names
 | 
					load_valid_names
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -156,6 +215,7 @@ usage() {
 | 
				
			|||||||
    echo "    -s            Sync repo databases"
 | 
					    echo "    -s            Sync repo databases"
 | 
				
			||||||
    echo '    -c            Check repos'
 | 
					    echo '    -c            Check repos'
 | 
				
			||||||
    echo '    -a            Show repo db (-c)'
 | 
					    echo '    -a            Show repo db (-c)'
 | 
				
			||||||
 | 
					    echo '    -o            Check for obsolete packages'
 | 
				
			||||||
    echo "    -q            Query repo databases for so libs"
 | 
					    echo "    -q            Query repo databases for so libs"
 | 
				
			||||||
    echo '    -h            This help'
 | 
					    echo '    -h            This help'
 | 
				
			||||||
    echo ''
 | 
					    echo ''
 | 
				
			||||||
@@ -163,7 +223,7 @@ usage() {
 | 
				
			|||||||
    exit "$1"
 | 
					    exit "$1"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
opts='r:qcsah'
 | 
					opts='r:qcsaoh'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
while getopts "${opts}" arg; do
 | 
					while getopts "${opts}" arg; do
 | 
				
			||||||
    case "${arg}" in
 | 
					    case "${arg}" in
 | 
				
			||||||
@@ -172,6 +232,7 @@ while getopts "${opts}" arg; do
 | 
				
			|||||||
        c) check=true ;;
 | 
					        c) check=true ;;
 | 
				
			||||||
        a) all_db=true ;;
 | 
					        a) all_db=true ;;
 | 
				
			||||||
        q) query=true ;;
 | 
					        q) query=true ;;
 | 
				
			||||||
 | 
					        o) obsolete=true ;;
 | 
				
			||||||
        h|?) usage 0 ;;
 | 
					        h|?) usage 0 ;;
 | 
				
			||||||
        *) echo "invalid argument '${arg}'"; usage 1 ;;
 | 
					        *) echo "invalid argument '${arg}'"; usage 1 ;;
 | 
				
			||||||
    esac
 | 
					    esac
 | 
				
			||||||
@@ -186,3 +247,5 @@ ${sync} && update_db_cache
 | 
				
			|||||||
${check} && show_db_table
 | 
					${check} && show_db_table
 | 
				
			||||||
 | 
					
 | 
				
			||||||
${query} && show_lib_table
 | 
					${query} && show_lib_table
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					${obsolete} && show_obsolete_table
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -46,33 +46,6 @@ subrepo_pull(){
 | 
				
			|||||||
    git subrepo pull "$pkg"
 | 
					    git subrepo pull "$pkg"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
prepare_commit(){
 | 
					 | 
				
			||||||
    # create new layout, copy & remove repos
 | 
					 | 
				
			||||||
    if [[ -d repos ]]; then
 | 
					 | 
				
			||||||
        msg2 "Switching to new layout ..."
 | 
					 | 
				
			||||||
        [[ ! -d "$CARCH" ]] && mkdir "$CARCH"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        for r in repos/*; do
 | 
					 | 
				
			||||||
            local name noarch
 | 
					 | 
				
			||||||
            name=${r#*/}
 | 
					 | 
				
			||||||
            noarch=${name%-*}
 | 
					 | 
				
			||||||
            mkdir "$CARCH/${noarch}"
 | 
					 | 
				
			||||||
            cp repos/"${name}"/* "$CARCH/${noarch}/"
 | 
					 | 
				
			||||||
            git add "$CARCH/${noarch}"
 | 
					 | 
				
			||||||
        done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        git rm -r repos
 | 
					 | 
				
			||||||
        git commit -m "switch to new repo layout"
 | 
					 | 
				
			||||||
        msg2 "Done switch"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ $action == 'add' ]] || [[ $action == 'move' ]] ;then
 | 
					 | 
				
			||||||
        [[ -d "$CARCH/${repo_dest}" ]] && git rm -r "$CARCH/${repo_dest}"
 | 
					 | 
				
			||||||
        [[ ! -d "$CARCH" ]] && mkdir "$CARCH"
 | 
					 | 
				
			||||||
        [[ ! -d "$CARCH/${repo_dest}" ]] && mkdir "$CARCH/${repo_dest}"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
check_rebuild(){
 | 
					check_rebuild(){
 | 
				
			||||||
    if [[ -d "$CARCH"/"${valid_names[10]}" ]] \
 | 
					    if [[ -d "$CARCH"/"${valid_names[10]}" ]] \
 | 
				
			||||||
    && [[ "${repo_dest}" == "${valid_names[7]}" ]]; then
 | 
					    && [[ "${repo_dest}" == "${valid_names[7]}" ]]; then
 | 
				
			||||||
@@ -86,14 +59,12 @@ check_rebuild(){
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
check_team(){
 | 
					check_team(){
 | 
				
			||||||
    if [[ "${repo_src}" == "${valid_names[0]}" \
 | 
					    if [[ "${repo_src}" == "${valid_names[0]}" && "${repo_dest}" == "${valid_names[1]}" ]] || \
 | 
				
			||||||
        && "${repo_dest}" == "${valid_names[1]}" ]] || \
 | 
					        [[ "${repo_src}" == "${valid_names[1]}" && "${repo_dest}" == "${valid_names[0]}" ]] || \
 | 
				
			||||||
        [[ "${repo_src}" == "${valid_names[1]}" \
 | 
					        [[ "${repo_src}" == "${valid_names[1]}" && "${repo_dest}" == "${valid_names[2]}" ]] || \
 | 
				
			||||||
        && "${repo_dest}" == "${valid_names[0]}" ]] || \
 | 
					        [[ "${repo_src}" == "${valid_names[2]}" && "${repo_dest}" == "${valid_names[1]}" ]] || \
 | 
				
			||||||
        [[ "${repo_src}" == "${valid_names[1]}" \
 | 
					        [[ "${repo_src}" == "${valid_names[0]}" && "${repo_dest}" == "${valid_names[2]}" ]] || \
 | 
				
			||||||
        && "${repo_dest}" == "${valid_names[2]}" ]] || \
 | 
					        [[ "${repo_src}" == "${valid_names[2]}" && "${repo_dest}" == "${valid_names[0]}" ]]; then
 | 
				
			||||||
        [[ "${repo_src}" == "${valid_names[2]}" \
 | 
					 | 
				
			||||||
        && "${repo_dest}" == "${valid_names[1]}" ]] ;then
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        local org gitname
 | 
					        local org gitname
 | 
				
			||||||
        org=$(get_pkg_org "${package}")
 | 
					        org=$(get_pkg_org "${package}")
 | 
				
			||||||
@@ -106,36 +77,32 @@ check_team(){
 | 
				
			|||||||
path_config() {
 | 
					path_config() {
 | 
				
			||||||
    [[ "${repo_src}" != 'trunk' ]] && pkgbuild="$CARCH/${repo_src}"/PKGBUILD
 | 
					    [[ "${repo_src}" != 'trunk' ]] && pkgbuild="$CARCH/${repo_src}"/PKGBUILD
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [[ ! -f "$pkgbuild" ]]; then
 | 
					 | 
				
			||||||
        pkgbuild=repos/"${repo_src}-${CARCH}"/PKGBUILD
 | 
					 | 
				
			||||||
        [[ -f repos/"${repo_src}"-any/PKGBUILD ]] && pkgbuild=repos/"${repo_src}"-any/PKGBUILD
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    # shellcheck disable=1090
 | 
					    # shellcheck disable=1090
 | 
				
			||||||
    . "$pkgbuild"
 | 
					    . "$pkgbuild"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
get_commit_msg() {
 | 
					get_repo_commit_msg() {
 | 
				
			||||||
    echo "[${repo_src}] -> [${repo_dest}] '${package}-$(get_full_version)' ${action}"
 | 
					    echo "[${repo_src}] -> [${repo_dest}] '${package}-$(get_full_version)' ${action}"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					get_commit_msg() {
 | 
				
			||||||
 | 
					    echo "[${repo_src}] '${package}-$(get_full_version)' ${action}"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
commit_pkg() {
 | 
					commit_pkg() {
 | 
				
			||||||
    local commit_msg pkg
 | 
					    local commit_msg pkg
 | 
				
			||||||
    if ${remove}; then
 | 
					    if ${remove}; then
 | 
				
			||||||
        action='remove'
 | 
					        action='remove'
 | 
				
			||||||
        commit_msg="[${repo_src}] '$pkg' ${action}"
 | 
					        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
 | 
				
			||||||
            pkg=${package}
 | 
					 | 
				
			||||||
            git rm -r trunk
 | 
					            git rm -r trunk
 | 
				
			||||||
        else
 | 
					        else
 | 
				
			||||||
            pkg="${package}-$(get_full_version)"
 | 
					 | 
				
			||||||
            prepare_commit
 | 
					 | 
				
			||||||
            git rm -r "$CARCH/${repo_src}"
 | 
					            git rm -r "$CARCH/${repo_src}"
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    else
 | 
					    else
 | 
				
			||||||
        action='modify'
 | 
					        action='modify'
 | 
				
			||||||
        commit_msg="[${repo_src}] '${package}-$(get_full_version)' ${action}"
 | 
					        commit_msg=$(get_commit_msg)
 | 
				
			||||||
        msg "Action: %s" "$commit_msg"
 | 
					        msg "Action: %s" "$commit_msg"
 | 
				
			||||||
        git add .
 | 
					        git add .
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
@@ -144,19 +111,22 @@ 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 "$CARCH" ]] && mkdir "$CARCH"
 | 
				
			||||||
 | 
					    [[ ! -d "$CARCH/${repo_dest}" ]] && mkdir "$CARCH/${repo_dest}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [[ "${repo_src}" == 'trunk' ]]; then
 | 
					    if [[ "${repo_src}" == 'trunk' ]]; then
 | 
				
			||||||
        action='add'
 | 
					        action='add'
 | 
				
			||||||
        commit_msg=$(get_commit_msg)
 | 
					        commit_msg=$(get_repo_commit_msg)
 | 
				
			||||||
        msg "Action: %s" "$commit_msg"
 | 
					        msg "Action: %s" "$commit_msg"
 | 
				
			||||||
        prepare_commit
 | 
					 | 
				
			||||||
        check_rebuild
 | 
					        check_rebuild
 | 
				
			||||||
        cp trunk/* "$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_commit_msg)
 | 
					        commit_msg=$(get_repo_commit_msg)
 | 
				
			||||||
        msg "Action: %s" "$commit_msg"
 | 
					        msg "Action: %s" "$commit_msg"
 | 
				
			||||||
        prepare_commit
 | 
					 | 
				
			||||||
        cp "$CARCH/${repo_src}"/* "$CARCH/${repo_dest}"/
 | 
					        cp "$CARCH/${repo_src}"/* "$CARCH/${repo_dest}"/
 | 
				
			||||||
        git rm -r "$CARCH/${repo_src}"
 | 
					        git rm -r "$CARCH/${repo_src}"
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -52,6 +52,9 @@ compare_m(){
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
compare_u(){
 | 
					compare_u(){
 | 
				
			||||||
    if [ "$result" -eq -1 ];then
 | 
					    if [ "$result" -eq -1 ];then
 | 
				
			||||||
 | 
					#         local arel=${archver##*-} brel=${artixver##*-}
 | 
				
			||||||
 | 
					#         local reldiff
 | 
				
			||||||
 | 
					#         reldiff=$(( $arel-${brel%.*} ))
 | 
				
			||||||
        msg_row_red "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}"
 | 
					        msg_row_red "${table}" "${a}" "${b}" "$pkg" "$archver" "$artixver" "${group#*-}"
 | 
				
			||||||
        write_list "${a}:$pkg" pkg_upgrades
 | 
					        write_list "${a}:$pkg" pkg_upgrades
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -35,7 +35,6 @@ REPO_DB_PREFIX=
 | 
				
			|||||||
REPO_DB_SUFFIX=
 | 
					REPO_DB_SUFFIX=
 | 
				
			||||||
LOCKFILE=
 | 
					LOCKFILE=
 | 
				
			||||||
CLEAN_LOCK=0
 | 
					CLEAN_LOCK=0
 | 
				
			||||||
PREVENT_DOWNGRADE=0
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# ensure we have a sane umask set
 | 
					# ensure we have a sane umask set
 | 
				
			||||||
umask 0022
 | 
					umask 0022
 | 
				
			||||||
@@ -53,7 +52,6 @@ Multiple packages to add can be specified on the command line.\n"
 | 
				
			|||||||
        printf -- "\n"
 | 
					        printf -- "\n"
 | 
				
			||||||
        printf -- "Options:\n"
 | 
					        printf -- "Options:\n"
 | 
				
			||||||
        printf -- "  -n, --new         only add packages that are not already in the database\n"
 | 
					        printf -- "  -n, --new         only add packages that are not already in the database\n"
 | 
				
			||||||
        printf -- "  -p, --prevent-downgrade  do not add package to database if a newer version is already present\n"
 | 
					 | 
				
			||||||
    elif [[ $cmd == "links-remove" ]] ; then
 | 
					    elif [[ $cmd == "links-remove" ]] ; then
 | 
				
			||||||
        printf -- "Usage: links-remove [options] <path-to-db> <packagename> ...\n"
 | 
					        printf -- "Usage: links-remove [options] <path-to-db> <packagename> ...\n"
 | 
				
			||||||
        printf -- "\n"
 | 
					        printf -- "\n"
 | 
				
			||||||
@@ -193,18 +191,6 @@ db_write_entry() {
 | 
				
			|||||||
        if (( ONLYADDNEW )); then
 | 
					        if (( ONLYADDNEW )); then
 | 
				
			||||||
            return 0
 | 
					            return 0
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        pkgentry=$(find_pkgentry "$pkgname")
 | 
					 | 
				
			||||||
        if [[ -n $pkgentry ]]; then
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            local version=$(sed -n '/^%VERSION%$/ {n;p;q}' "$pkgentry/desc")
 | 
					 | 
				
			||||||
            if (( $(vercmp "$version" "$pkgver") > 0 )); then
 | 
					 | 
				
			||||||
                warning "A newer version for '%s' is already present in database" "$pkgname"
 | 
					 | 
				
			||||||
                if (( PREVENT_DOWNGRADE )); then
 | 
					 | 
				
			||||||
                    return 0
 | 
					 | 
				
			||||||
                fi
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # remove an existing entry if it exists, ignore failures
 | 
					    # remove an existing entry if it exists, ignore failures
 | 
				
			||||||
@@ -467,7 +453,6 @@ while (( $# )); do
 | 
				
			|||||||
        -s|--sign) SIGN=1 ;;
 | 
					        -s|--sign) SIGN=1 ;;
 | 
				
			||||||
        -k|--key) KEY=1 ; shift; GPGKEY=$1 ;;
 | 
					        -k|--key) KEY=1 ; shift; GPGKEY=$1 ;;
 | 
				
			||||||
        -v|--verify) VERIFY=1 ;;
 | 
					        -v|--verify) VERIFY=1 ;;
 | 
				
			||||||
        -p|--prevent-downgrade) PREVENT_DOWNGRADE=1 ;;
 | 
					 | 
				
			||||||
        *) args+=("$1") ;;
 | 
					        *) args+=("$1") ;;
 | 
				
			||||||
    esac
 | 
					    esac
 | 
				
			||||||
    shift
 | 
					    shift
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -15,6 +15,9 @@
 | 
				
			|||||||
m4_include(lib/base/message.sh)
 | 
					m4_include(lib/base/message.sh)
 | 
				
			||||||
m4_include(lib/base/chroot.sh)
 | 
					m4_include(lib/base/chroot.sh)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export BUILDTOOL=artools-pkg
 | 
				
			||||||
 | 
					export BUILDTOOLVER=m4_artools_pkg_version
 | 
				
			||||||
 | 
					
 | 
				
			||||||
shopt -s nullglob
 | 
					shopt -s nullglob
 | 
				
			||||||
 | 
					
 | 
				
			||||||
default_makepkg_args=(--syncdeps --noconfirm --log --holdver --skipinteg)
 | 
					default_makepkg_args=(--syncdeps --noconfirm --log --holdver --skipinteg)
 | 
				
			||||||
@@ -193,6 +196,8 @@ EOF
 | 
				
			|||||||
        printf '#!/bin/bash\n'
 | 
					        printf '#!/bin/bash\n'
 | 
				
			||||||
        declare -f _chrootbuild
 | 
					        declare -f _chrootbuild
 | 
				
			||||||
        declare -p SOURCE_DATE_EPOCH 2>/dev/null || true
 | 
					        declare -p SOURCE_DATE_EPOCH 2>/dev/null || true
 | 
				
			||||||
 | 
					        declare -p BUILDTOOL 2>/dev/null
 | 
				
			||||||
 | 
							declare -p BUILDTOOLVER 2>/dev/null
 | 
				
			||||||
        printf '_chrootbuild "$@" || exit\n'
 | 
					        printf '_chrootbuild "$@" || exit\n'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (( run_namcap )); then
 | 
					        if (( run_namcap )); then
 | 
				
			||||||
@@ -218,7 +223,10 @@ _chrootbuild() {
 | 
				
			|||||||
    # use "$" in arguments to commands with "sudo -i".  ${foo} or
 | 
					    # use "$" in arguments to commands with "sudo -i".  ${foo} or
 | 
				
			||||||
    # ${1} is OK, but $foo or $1 isn't.
 | 
					    # ${1} is OK, but $foo or $1 isn't.
 | 
				
			||||||
    # https://bugzilla.sudo.ws/show_bug.cgi?id=765
 | 
					    # https://bugzilla.sudo.ws/show_bug.cgi?id=765
 | 
				
			||||||
    sudo --preserve-env=SOURCE_DATE_EPOCH -iu builduser bash -c 'cd /startdir; makepkg "$@"' -bash "$@"
 | 
					    sudo --preserve-env=SOURCE_DATE_EPOCH \
 | 
				
			||||||
 | 
					        -preserve-env=BUILDTOOL \
 | 
				
			||||||
 | 
							--preserve-env=BUILDTOOLVER \
 | 
				
			||||||
 | 
					        -iu builduser bash -c 'cd /startdir; makepkg "$@"' -bash "$@"
 | 
				
			||||||
    ret=$?
 | 
					    ret=$?
 | 
				
			||||||
    case $ret in
 | 
					    case $ret in
 | 
				
			||||||
        0|14)
 | 
					        0|14)
 | 
				
			||||||
@@ -241,7 +249,7 @@ download_sources() {
 | 
				
			|||||||
    chown "$makepkg_user:" "$WORKDIR"
 | 
					    chown "$makepkg_user:" "$WORKDIR"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Ensure sources are downloaded
 | 
					    # Ensure sources are downloaded
 | 
				
			||||||
    sudo -u "$makepkg_user" --preserve-env=GNUPGHOME \
 | 
					    sudo -u "$makepkg_user" --preserve-env=GNUPGHOME,SSH_AUTH_SOCK \
 | 
				
			||||||
        env SRCDEST="$SRCDEST" BUILDDIR="$WORKDIR" \
 | 
					        env SRCDEST="$SRCDEST" BUILDDIR="$WORKDIR" \
 | 
				
			||||||
        makepkg --config="$copydir/etc/makepkg.conf" --verifysource -o "${verifysource_args[@]}" ||
 | 
					        makepkg --config="$copydir/etc/makepkg.conf" --verifysource -o "${verifysource_args[@]}" ||
 | 
				
			||||||
        die "Could not download sources."
 | 
					        die "Could not download sources."
 | 
				
			||||||
@@ -305,7 +313,7 @@ done
 | 
				
			|||||||
[[ -n $makepkg_user && -z $(id -u "$makepkg_user") ]] && die 'Invalid makepkg user.'
 | 
					[[ -n $makepkg_user && -z $(id -u "$makepkg_user") ]] && die 'Invalid makepkg user.'
 | 
				
			||||||
makepkg_user=${makepkg_user:-${SUDO_USER:-$USER}}
 | 
					makepkg_user=${makepkg_user:-${SUDO_USER:-$USER}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
check_root SOURCE_DATE_EPOCH,GNUPGHOME,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER
 | 
					check_root SOURCE_DATE_EPOCH,BUILDTOOL,BUILDTOOLVER,GNUPGHOME,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Canonicalize chrootdir, getting rid of trailing /
 | 
					# Canonicalize chrootdir, getting rid of trailing /
 | 
				
			||||||
chrootdir=$(readlink -e "$passeddir")
 | 
					chrootdir=$(readlink -e "$passeddir")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,6 +17,24 @@ m4_include(lib/base/yaml.sh)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#{{{ functions
 | 
					#{{{ functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					print_package_names() {
 | 
				
			||||||
 | 
					    local version=$(get_full_version)
 | 
				
			||||||
 | 
					    local architecture pkg
 | 
				
			||||||
 | 
					    for pkg in ${pkgname[@]}; do
 | 
				
			||||||
 | 
					        architecture=$(get_pkg_arch $pkg)
 | 
				
			||||||
 | 
					        printf "%s/%s-%s-%s%s\n" "$PKGDEST" "$pkg" "$version" "$architecture" "$PKGEXT"
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					print_debug_package_names() {
 | 
				
			||||||
 | 
					    local version=$(get_full_version)
 | 
				
			||||||
 | 
					    local architecture
 | 
				
			||||||
 | 
					    if check_option "debug" "y" && check_option "strip" "y"; then
 | 
				
			||||||
 | 
					        architecture=$(get_pkg_arch)
 | 
				
			||||||
 | 
					        printf "%s/%s-%s-%s-%s%s\n" "$PKGDEST" "$pkgbase" "debug" "$version" "$architecture" "$PKGEXT"
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
srcyaml_write_attr(){
 | 
					srcyaml_write_attr(){
 | 
				
			||||||
    local ident1="$1" ident2="$2" ident3="$3"
 | 
					    local ident1="$1" ident2="$2" ident3="$3"
 | 
				
			||||||
    local attrname=$4 attrvalues=("${@:5}")
 | 
					    local attrname=$4 attrvalues=("${@:5}")
 | 
				
			||||||
@@ -108,13 +126,19 @@ yaml_write_fileinfo(){
 | 
				
			|||||||
    pkgbase=${pkgbase:-$pkgname}
 | 
					    pkgbase=${pkgbase:-$pkgname}
 | 
				
			||||||
    Yaml+=$(write_yaml_map 0 "version" "${version:-0}")
 | 
					    Yaml+=$(write_yaml_map 0 "version" "${version:-0}")
 | 
				
			||||||
    Yaml+=$(write_empty_line)
 | 
					    Yaml+=$(write_empty_line)
 | 
				
			||||||
    local pkgfile
 | 
					    local pkgfile debug_pkg
 | 
				
			||||||
    pkgfile=$(print_all_package_names)
 | 
					    pkgfile=$(print_package_names)
 | 
				
			||||||
    Yaml+=$(write_yaml_map 0 "files")
 | 
					    Yaml+=$(write_yaml_map 0 "files")
 | 
				
			||||||
    for f in ${pkgfile}; do
 | 
					    for f in ${pkgfile}; do
 | 
				
			||||||
        Yaml+=$(write_yaml_seq 2 "${f##*/}")
 | 
					        Yaml+=$(write_yaml_seq 2 "${f##*/}")
 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
    Yaml+=$(write_empty_line)
 | 
					    Yaml+=$(write_empty_line)
 | 
				
			||||||
 | 
					    debug_pkg=$(print_debug_package_names)
 | 
				
			||||||
 | 
					    Yaml+=$(write_yaml_map 0 "debug")
 | 
				
			||||||
 | 
					    for d in ${debug_pkg}; do
 | 
				
			||||||
 | 
					        Yaml+=$(write_yaml_seq 2 "${d##*/}")
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					    Yaml+=$(write_empty_line)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
write_srcyaml(){
 | 
					write_srcyaml(){
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -8,8 +8,14 @@
 | 
				
			|||||||
# the dist release; default: auto
 | 
					# the dist release; default: auto
 | 
				
			||||||
# ISO_VERSION=$(date +%Y%m%d)
 | 
					# ISO_VERSION=$(date +%Y%m%d)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# possible values: openrc, runit, s6, 66
 | 
					# possible values: openrc, runit, s6, suite66, dinit
 | 
				
			||||||
# INITSYS="openrc"
 | 
					# INITSYS="openrc"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# gpg key; leave empty or commented to skip img signing
 | 
					# gpg key; leave empty or commented to skip img signing
 | 
				
			||||||
# GPG_KEY=""
 | 
					# GPG_KEY=""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# possible values: zstd (default), xz
 | 
				
			||||||
 | 
					# COMPRESSION="zstd"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# zstd only: range 1..22
 | 
				
			||||||
 | 
					# COMPRESSION_LEVEL=15
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -10,26 +10,38 @@
 | 
				
			|||||||
# customize buildtree; uncomment to include
 | 
					# customize buildtree; uncomment to include
 | 
				
			||||||
# TREE_NAMES_ARTIX=(
 | 
					# TREE_NAMES_ARTIX=(
 | 
				
			||||||
#         packages-kernel
 | 
					#         packages-kernel
 | 
				
			||||||
 | 
					#         packages-llvm
 | 
				
			||||||
#         packages-openrc
 | 
					#         packages-openrc
 | 
				
			||||||
#         packages-runit
 | 
					#         packages-runit
 | 
				
			||||||
#         packages-s6
 | 
					#         packages-s6
 | 
				
			||||||
#         packages-66
 | 
					#         packages-suite66
 | 
				
			||||||
#         packages-python
 | 
					#         packages-dinit
 | 
				
			||||||
#         packages-perl
 | 
					#         packages-perl
 | 
				
			||||||
#         packages-java
 | 
					#         packages-java
 | 
				
			||||||
#         packages-ruby
 | 
					#         packages-ruby
 | 
				
			||||||
#         packages-kf5
 | 
					#         packages-gtk
 | 
				
			||||||
 | 
					#         packages-qt5
 | 
				
			||||||
 | 
					#         packages-qt6
 | 
				
			||||||
 | 
					#         packages-xorg
 | 
				
			||||||
#         packages-plasma
 | 
					#         packages-plasma
 | 
				
			||||||
#         packages-kde
 | 
					#         packages-kde
 | 
				
			||||||
#         packages-gnome
 | 
					#         packages-gnome
 | 
				
			||||||
#         packages-cinnamon
 | 
					#         packages-cinnamon
 | 
				
			||||||
#         packages-lxqt
 | 
					#         packages-lxqt
 | 
				
			||||||
 | 
					#         packages-lxde
 | 
				
			||||||
#         packages-mate
 | 
					#         packages-mate
 | 
				
			||||||
#         packages-xfce
 | 
					#         packages-xfce
 | 
				
			||||||
#         packages-wm
 | 
					#         packages-wm
 | 
				
			||||||
#         packages-devel
 | 
					#         packages-devel
 | 
				
			||||||
#         packages-lib32
 | 
					 | 
				
			||||||
#         packages-qt6
 | 
					#         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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,10 +11,10 @@
 | 
				
			|||||||
#
 | 
					#
 | 
				
			||||||
#-- The download utilities that makepkg should use to acquire sources
 | 
					#-- The download utilities that makepkg should use to acquire sources
 | 
				
			||||||
#  Format: 'protocol::agent'
 | 
					#  Format: 'protocol::agent'
 | 
				
			||||||
DLAGENTS=('file::/usr/bin/curl -gqC - -o %o %u'
 | 
					DLAGENTS=('file::/usr/bin/curl -qgC - -o %o %u'
 | 
				
			||||||
          'ftp::/usr/bin/curl -gqfC - --ftp-pasv --retry 3 --retry-delay 3 -o %o %u'
 | 
					          'ftp::/usr/bin/curl -qgfC - --ftp-pasv --retry 3 --retry-delay 3 -o %o %u'
 | 
				
			||||||
          'http::/usr/bin/curl -gqb "" -fLC - --retry 3 --retry-delay 3 -o %o %u'
 | 
					          'http::/usr/bin/curl -qgb "" -fLC - --retry 3 --retry-delay 3 -o %o %u'
 | 
				
			||||||
          'https::/usr/bin/curl -gqb "" -fLC - --retry 3 --retry-delay 3 -o %o %u'
 | 
					          'https::/usr/bin/curl -qgb "" -fLC - --retry 3 --retry-delay 3 -o %o %u'
 | 
				
			||||||
          'rsync::/usr/bin/rsync --no-motd -z %u %o'
 | 
					          'rsync::/usr/bin/rsync --no-motd -z %u %o'
 | 
				
			||||||
          'scp::/usr/bin/scp -C %u %o')
 | 
					          'scp::/usr/bin/scp -C %u %o')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -49,8 +49,8 @@ LDFLAGS="-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now"
 | 
				
			|||||||
#-- 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 -fvar-tracking-assignments"
 | 
					DEBUG_CFLAGS="-g"
 | 
				
			||||||
DEBUG_CXXFLAGS="-g -fvar-tracking-assignments"
 | 
					DEBUG_CXXFLAGS="-g"
 | 
				
			||||||
#DEBUG_RUSTFLAGS="-C debuginfo=2"
 | 
					#DEBUG_RUSTFLAGS="-C debuginfo=2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#########################################################################
 | 
					#########################################################################
 | 
				
			||||||
@@ -93,7 +93,7 @@ BUILDENV=(!distcc color !ccache check !sign)
 | 
				
			|||||||
#-- debug:      Add debugging flags as specified in DEBUG_* variables
 | 
					#-- debug:      Add debugging flags as specified in DEBUG_* variables
 | 
				
			||||||
#-- lto:        Add compile flags for building with link time optimization
 | 
					#-- lto:        Add compile flags for building with link time optimization
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !debug !lto)
 | 
					OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !debug lto)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#-- File integrity checks to use. Valid: md5, sha1, sha224, sha256, sha384, sha512, b2
 | 
					#-- File integrity checks to use. Valid: md5, sha1, sha224, sha256, sha384, sha512, b2
 | 
				
			||||||
INTEGRITY_CHECK=(sha256)
 | 
					INTEGRITY_CHECK=(sha256)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,38 +0,0 @@
 | 
				
			|||||||
# Maintainer: Your Name <youremail@domain.com>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
pkgname=NAME-openrc
 | 
					 | 
				
			||||||
pkgver=VERSION
 | 
					 | 
				
			||||||
pkgrel=1
 | 
					 | 
				
			||||||
epoch=
 | 
					 | 
				
			||||||
pkgdesc="Openrc NAME init script"
 | 
					 | 
				
			||||||
arch=('any')
 | 
					 | 
				
			||||||
url="https://gitea.artixlinux.org/artixlinux/packages-openrc"
 | 
					 | 
				
			||||||
license=('GPL2')
 | 
					 | 
				
			||||||
groups=()
 | 
					 | 
				
			||||||
depends=("openrc" "NAME")
 | 
					 | 
				
			||||||
makedepends=()
 | 
					 | 
				
			||||||
checkdepends=()
 | 
					 | 
				
			||||||
optdepends=()
 | 
					 | 
				
			||||||
provides=("init-NAME")
 | 
					 | 
				
			||||||
conflicts=("init-NAME")
 | 
					 | 
				
			||||||
replaces=()
 | 
					 | 
				
			||||||
backup=()
 | 
					 | 
				
			||||||
options=()
 | 
					 | 
				
			||||||
install=
 | 
					 | 
				
			||||||
changelog=
 | 
					 | 
				
			||||||
source=(NAME.{confd,initd})
 | 
					 | 
				
			||||||
sha256sums=()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_inst_openrc() {
 | 
					 | 
				
			||||||
    local sv="$1"
 | 
					 | 
				
			||||||
    if [ -f "${srcdir}/$sv".confd ]; then
 | 
					 | 
				
			||||||
        install -Dm644 "${srcdir}/$sv".confd "${pkgdir}"/etc/conf.d/"$sv"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
    if [ -f "${srcdir}/$sv".initd ]; then
 | 
					 | 
				
			||||||
        install -Dm755 "${srcdir}/$sv".initd "${pkgdir}"/etc/init.d/"$sv"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
package() {
 | 
					 | 
				
			||||||
    _inst_openrc "NAME"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,41 +0,0 @@
 | 
				
			|||||||
# Maintainer: Your Name <youremail@domain.com>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
pkgname=NAME-runit
 | 
					 | 
				
			||||||
pkgver=VERSION
 | 
					 | 
				
			||||||
pkgrel=1
 | 
					 | 
				
			||||||
epoch=
 | 
					 | 
				
			||||||
pkgdesc="Runit NAME init script"
 | 
					 | 
				
			||||||
arch=('any')
 | 
					 | 
				
			||||||
url="https://gitea.artixlinux.org/artixlinux/packages-runit"
 | 
					 | 
				
			||||||
license=('GPL2')
 | 
					 | 
				
			||||||
groups=()
 | 
					 | 
				
			||||||
depends=("runit" "NAME")
 | 
					 | 
				
			||||||
makedepends=()
 | 
					 | 
				
			||||||
checkdepends=()
 | 
					 | 
				
			||||||
optdepends=()
 | 
					 | 
				
			||||||
provides=("init-NAME")
 | 
					 | 
				
			||||||
conflicts=("init-NAME")
 | 
					 | 
				
			||||||
replaces=()
 | 
					 | 
				
			||||||
backup=()
 | 
					 | 
				
			||||||
options=()
 | 
					 | 
				
			||||||
install=
 | 
					 | 
				
			||||||
changelog=
 | 
					 | 
				
			||||||
source=(NAME.{run,finish,check})
 | 
					 | 
				
			||||||
sha256sums=()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_inst_runit() {
 | 
					 | 
				
			||||||
    local sv="$1"
 | 
					 | 
				
			||||||
    if [ -f "${srcdir}/$sv".conf ]; then
 | 
					 | 
				
			||||||
        install -Dm644 "${srcdir}/$sv".conf "${pkgdir}"/etc/runit/sv/"$sv"/conf
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    for f in run finish check; do
 | 
					 | 
				
			||||||
        if [ -f "${srcdir}/$sv.$f" ]; then
 | 
					 | 
				
			||||||
            install -Dm755 "${srcdir}/$sv.$f" "${pkgdir}"/etc/runit/sv/"$sv/$f"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
package() {
 | 
					 | 
				
			||||||
    _inst_runit "NAME"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,39 +0,0 @@
 | 
				
			|||||||
# Maintainer: Your Name <youremail@domain.com>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
pkgname=NAME-s6
 | 
					 | 
				
			||||||
pkgver=VERSION
 | 
					 | 
				
			||||||
pkgrel=1
 | 
					 | 
				
			||||||
epoch=
 | 
					 | 
				
			||||||
pkgdesc="S6 NAME init script"
 | 
					 | 
				
			||||||
arch=('any')
 | 
					 | 
				
			||||||
url="https://gitea.artixlinux.org/artixlinux/packages-s6"
 | 
					 | 
				
			||||||
license=('GPL2')
 | 
					 | 
				
			||||||
groups=()
 | 
					 | 
				
			||||||
depends=("s6-base" "NAME")
 | 
					 | 
				
			||||||
makedepends=()
 | 
					 | 
				
			||||||
checkdepends=()
 | 
					 | 
				
			||||||
optdepends=()
 | 
					 | 
				
			||||||
provides=("init-NAME")
 | 
					 | 
				
			||||||
conflicts=("init-NAME")
 | 
					 | 
				
			||||||
replaces=()
 | 
					 | 
				
			||||||
backup=()
 | 
					 | 
				
			||||||
options=()
 | 
					 | 
				
			||||||
install=
 | 
					 | 
				
			||||||
changelog=
 | 
					 | 
				
			||||||
source=(NAME.{dependencies,down,up,type})
 | 
					 | 
				
			||||||
sha256sums=()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_inst_s6(){
 | 
					 | 
				
			||||||
    local sv="$1"
 | 
					 | 
				
			||||||
    for f in dependencies down type up; do
 | 
					 | 
				
			||||||
        if [ -f "${srcdir}/$sv.$f" ]; then
 | 
					 | 
				
			||||||
            install -Dm644 "${srcdir}/$sv.$f" "${pkgdir}"/etc/s6/sv/"$sv/$f"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
package() {
 | 
					 | 
				
			||||||
    _inst_s6 "NAME"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -1,34 +0,0 @@
 | 
				
			|||||||
# Maintainer: Your Name <youremail@domain.com>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
pkgname=NAME-66
 | 
					 | 
				
			||||||
pkgver=VERSION
 | 
					 | 
				
			||||||
pkgrel=1
 | 
					 | 
				
			||||||
epoch=
 | 
					 | 
				
			||||||
pkgdesc="Suite66 NAME init script"
 | 
					 | 
				
			||||||
arch=('any')
 | 
					 | 
				
			||||||
url="https://gitea.artixlinux.org/artixlinux/packages-66"
 | 
					 | 
				
			||||||
license=('GPL2')
 | 
					 | 
				
			||||||
groups=()
 | 
					 | 
				
			||||||
depends=("suite66-base" "NAME")
 | 
					 | 
				
			||||||
makedepends=()
 | 
					 | 
				
			||||||
checkdepends=()
 | 
					 | 
				
			||||||
optdepends=()
 | 
					 | 
				
			||||||
provides=("init-NAME")
 | 
					 | 
				
			||||||
conflicts=("init-NAME")
 | 
					 | 
				
			||||||
replaces=()
 | 
					 | 
				
			||||||
backup=()
 | 
					 | 
				
			||||||
options=()
 | 
					 | 
				
			||||||
install=
 | 
					 | 
				
			||||||
changelog=
 | 
					 | 
				
			||||||
source=(NAME)
 | 
					 | 
				
			||||||
sha256sums=()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_inst_66() {
 | 
					 | 
				
			||||||
    local sv="$1"
 | 
					 | 
				
			||||||
    install -Dm644 "$sv" -t "${pkgdir}"/etc/66/service
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
package() {
 | 
					 | 
				
			||||||
    _inst_66 "NAME"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
DIRMODE = -dm0755
 | 
					 | 
				
			||||||
MODE =  -m0755
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CPIOHOOKS = \
 | 
					 | 
				
			||||||
	$(wildcard hooks/*)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CPIOINST = \
 | 
					 | 
				
			||||||
	$(wildcard install/*)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
SCRIPT = \
 | 
					 | 
				
			||||||
	$(wildcard script/*)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install_initcpio:
 | 
					 | 
				
			||||||
	install $(DIRMODE) $(DESTDIR)$(CPIODIR)/hooks
 | 
					 | 
				
			||||||
	install $(MODE) $(CPIOHOOKS) $(DESTDIR)$(CPIODIR)/hooks
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	install $(DIRMODE) $(DESTDIR)$(CPIODIR)/install
 | 
					 | 
				
			||||||
	install $(MODE) $(CPIOINST) $(DESTDIR)$(CPIODIR)/install
 | 
					 | 
				
			||||||
	install $(MODE) $(SCRIPT) $(DESTDIR)$(CPIODIR)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
install: install_initcpio
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
.PHONY: install
 | 
					 | 
				
			||||||
@@ -1,275 +0,0 @@
 | 
				
			|||||||
# args: source, newroot, mountpoint
 | 
					 | 
				
			||||||
_mnt_dmsnapshot() {
 | 
					 | 
				
			||||||
    local img="${1}"
 | 
					 | 
				
			||||||
    local mnt="${2}"
 | 
					 | 
				
			||||||
    local img_fullname="${img##*/}";
 | 
					 | 
				
			||||||
    local img_name="${img_fullname%%.*}"
 | 
					 | 
				
			||||||
    local dm_snap_name="${dm_snap_prefix}_${img_name}"
 | 
					 | 
				
			||||||
    local ro_dev ro_dev_size rw_dev
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    ro_dev=$(losetup --find --show --read-only "${img}")
 | 
					 | 
				
			||||||
    echo ${ro_dev} >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
    ro_dev_size=$(blockdev --getsz ${ro_dev})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${cow_persistent}" == "P" ]]; then
 | 
					 | 
				
			||||||
        if [[ -f "${cow}/${cow_directory}/${img_name}.cow" ]]; then
 | 
					 | 
				
			||||||
            msg ":: Found '${cow}/${cow_directory}/${img_name}.cow', using as persistent."
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            msg ":: Creating '${cow}/${cow_directory}/${img_name}.cow' as persistent."
 | 
					 | 
				
			||||||
            truncate -s "${cow_spacesize}" "${cow}/${cow_directory}/${img_name}.cow"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        if [[ -f "${cow}/${cow_directory}/${img_name}.cow" ]]; then
 | 
					 | 
				
			||||||
            msg ":: Found '${cow}/${cow_directory}/${img_name}.cow' but non-persistent requested, removing."
 | 
					 | 
				
			||||||
            rm -f "${cow}/${cow_directory}/${img_name}.cow"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        msg ":: Creating '${cow}/${cow_directory}/${img_name}.cow' as non-persistent."
 | 
					 | 
				
			||||||
        truncate -s "${cow_spacesize}" "${cow}/${cow_directory}/${img_name}.cow"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    rw_dev=$(losetup --find --show "${cow}/${cow_directory}/${img_name}.cow")
 | 
					 | 
				
			||||||
    echo ${rw_dev} >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    dmsetup create ${dm_snap_name} --table "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} ${cow_chunksize}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${cow_persistent}" != "P" ]]; then
 | 
					 | 
				
			||||||
        rm -f "${cow}/${cow_directory}/${img_name}.cow"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    _mnt_dev "/dev/mapper/${dm_snap_name}" "${mnt}" "-w" "defaults"
 | 
					 | 
				
			||||||
    echo $(readlink -f /dev/mapper/${dm_snap_name}) >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# args: source, newroot, mountpoint
 | 
					 | 
				
			||||||
_mnt_overlayfs() {
 | 
					 | 
				
			||||||
    local src="${1}"
 | 
					 | 
				
			||||||
    local newroot="${2}"
 | 
					 | 
				
			||||||
    local mnt="${3}"
 | 
					 | 
				
			||||||
    local work_dir="${overlay_root}/work"
 | 
					 | 
				
			||||||
    local upper_dir="${overlay_root}/upper"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    mkdir -p "${upper_dir}" "${work_dir}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    mount -t overlay overlay -o lowerdir="${src}",upperdir="${upper_dir}",workdir="${work_dir}" "${newroot}${mnt}"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# args: /path/to/image_file, mountpoint
 | 
					 | 
				
			||||||
_mnt_sfs() {
 | 
					 | 
				
			||||||
    local img="${1}"
 | 
					 | 
				
			||||||
    local mnt="${2}"
 | 
					 | 
				
			||||||
    local img_fullname="${img##*/}"
 | 
					 | 
				
			||||||
    local sfs_dev
 | 
					 | 
				
			||||||
    local oper=$( [[ -n "${ip}" && -n "${miso_http_srv}" ]] && echo "mv" || echo "cp" )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
        msg -n ":: Copying squashfs image to RAM..."
 | 
					 | 
				
			||||||
        if ! "${oper}" "${img}" "${cp2ram}/${img_fullname}" ; then
 | 
					 | 
				
			||||||
            echo "ERROR: while copy '${img}' to '${cp2ram}/${img_fullname}'"
 | 
					 | 
				
			||||||
            launch_interactive_shell
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        img="${cp2ram}/${img_fullname}"
 | 
					 | 
				
			||||||
        msg "done."
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
    sfs_dev=$(losetup --find --show --read-only "${img}")
 | 
					 | 
				
			||||||
    echo ${sfs_dev} >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
    _mnt_dev "${sfs_dev}" "${mnt}" "-r" "defaults"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# args: device, mountpoint, flags, opts
 | 
					 | 
				
			||||||
_mnt_dev() {
 | 
					 | 
				
			||||||
    local dev="${1}"
 | 
					 | 
				
			||||||
    local mnt="${2}"
 | 
					 | 
				
			||||||
    local flg="${3}"
 | 
					 | 
				
			||||||
    local opts="${4}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    mkdir -p "${mnt}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Mounting '${dev}' to '${mnt}'"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    while ! poll_device "${dev}" 30; do
 | 
					 | 
				
			||||||
        echo "ERROR: '${dev}' device did not show up after 30 seconds..."
 | 
					 | 
				
			||||||
        echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
        echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if mount -o "${opts}" "${flg}" "${dev}" "${mnt}"; then
 | 
					 | 
				
			||||||
        msg ":: Device '${dev}' mounted successfully."
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        echo "ERROR; Failed to mount '${dev}'"
 | 
					 | 
				
			||||||
        echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
        echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_verify_checksum() {
 | 
					 | 
				
			||||||
    local _status
 | 
					 | 
				
			||||||
    cd "${bootmnt}/${root}"
 | 
					 | 
				
			||||||
    sha512sum -c $1.img.sha512 > /tmp/checksum.log 2>&1
 | 
					 | 
				
			||||||
    _status=$?
 | 
					 | 
				
			||||||
    cd "${OLDPWD}"
 | 
					 | 
				
			||||||
    return ${_status}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_verify_signature() {
 | 
					 | 
				
			||||||
    local _status
 | 
					 | 
				
			||||||
    cd "${bootmnt}/${root}"
 | 
					 | 
				
			||||||
    gpg --homedir /gpg --status-fd 1 --verify $1.img.sig 2>/dev/null | grep -qE '^\[GNUPG:\] GOODSIG'
 | 
					 | 
				
			||||||
    _status=$?
 | 
					 | 
				
			||||||
    cd "${OLDPWD}"
 | 
					 | 
				
			||||||
    return ${_status}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook() {
 | 
					 | 
				
			||||||
    [[ -z "${copytoram_size}" ]] && copytoram_size="75%"
 | 
					 | 
				
			||||||
    [[ -z "${root}" ]] && root="LiveOS"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    [[ -z "${dm_snap_prefix}" ]] && dm_snap_prefix="artix"
 | 
					 | 
				
			||||||
    [[ -z "${artixdevice}" ]] && artixdevice="/dev/disk/by-label/${label}"
 | 
					 | 
				
			||||||
    [[ -z "${cow_spacesize}" ]] && cow_spacesize="256M"
 | 
					 | 
				
			||||||
    [[ -z "${overlay_root_size}" ]] && overlay_root_size="75%"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ -n "${cow_label}" ]]; then
 | 
					 | 
				
			||||||
        cow_device="/dev/disk/by-label/${cow_label}"
 | 
					 | 
				
			||||||
        [[ -z "${cow_persistent}" ]] && cow_persistent="P"
 | 
					 | 
				
			||||||
    elif [[ -n "${cow_device}" ]]; then
 | 
					 | 
				
			||||||
        [[ -z "${cow_persistent}" ]] && cow_persistent="P"
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        cow_persistent="N"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    [[ -z "${cow_flags}" ]] && cow_flags="defaults"
 | 
					 | 
				
			||||||
    [[ -z "${cow_directory}" ]] && cow_directory="persistent_${label}"
 | 
					 | 
				
			||||||
    [[ -z "${cow_chunksize}" ]] && cow_chunksize="8"
 | 
					 | 
				
			||||||
    [[ -z "${overlay}" ]] && overlay=""
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    lower_dir=''
 | 
					 | 
				
			||||||
    live_root="/run/artix"
 | 
					 | 
				
			||||||
    bootmnt="${live_root}/bootmnt"
 | 
					 | 
				
			||||||
    overlay_root="${live_root}/overlay_root"
 | 
					 | 
				
			||||||
    cow="${live_root}/cowspace"
 | 
					 | 
				
			||||||
    cp2ram="${live_root}/copytoram"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    # set mount handler for artix
 | 
					 | 
				
			||||||
    mount_handler="artix_mount_handler"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_check_sum() {
 | 
					 | 
				
			||||||
    local fs="${1}"
 | 
					 | 
				
			||||||
    if [[ -f "${bootmnt}/${root}/${fs}.img" ]]; then
 | 
					 | 
				
			||||||
        if [[ -f "${bootmnt}/${root}/${fs}.img.md5" ]]; then
 | 
					 | 
				
			||||||
            msg -n ":: Self-test requested, please wait..."
 | 
					 | 
				
			||||||
            if _verify_checksum "${fs}"; then
 | 
					 | 
				
			||||||
                msg "done. Checksum is OK, continue booting."
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
                echo "ERROR: one or more files are corrupted"
 | 
					 | 
				
			||||||
                echo "see /tmp/checksum.log for details"
 | 
					 | 
				
			||||||
                launch_interactive_shell
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            echo "ERROR: checksum=y option specified but ${root}/${fs}.img.md5 not found"
 | 
					 | 
				
			||||||
            launch_interactive_shell
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_check_sig() {
 | 
					 | 
				
			||||||
    local fs="${1}"
 | 
					 | 
				
			||||||
    if [[ -f "${bootmnt}/${root}/${fs}.img" ]]; then
 | 
					 | 
				
			||||||
        if [[ -f "${bootmnt}/${root}/${fs}.img.sig" ]]; then
 | 
					 | 
				
			||||||
            msg -n ":: Signature verification requested, please wait..."
 | 
					 | 
				
			||||||
            if _verify_signature "${fs}"; then
 | 
					 | 
				
			||||||
                msg "done. Signature is OK, continue booting."
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
                echo "ERROR: one or more files are corrupted"
 | 
					 | 
				
			||||||
                launch_interactive_shell
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            echo "ERROR: verify=y option specified but ${root}/${fs}.img.sig not found"
 | 
					 | 
				
			||||||
            launch_interactive_shell
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_gen_arg() {
 | 
					 | 
				
			||||||
    local arg="${1}"
 | 
					 | 
				
			||||||
    echo "${lower_dir:-}${lower_dir:+:}${arg}"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_mount_root_overlayfs() {
 | 
					 | 
				
			||||||
    local sfs="${1}"
 | 
					 | 
				
			||||||
    local src="${bootmnt}/${root}"
 | 
					 | 
				
			||||||
    local dest_sfs="${live_root}/sfs"
 | 
					 | 
				
			||||||
    local dest_img="${live_root}/img"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ -f "${src}/${sfs}.img" ]]; then
 | 
					 | 
				
			||||||
        _mnt_sfs "${src}/${sfs}.img" "${dest_sfs}/${sfs}"
 | 
					 | 
				
			||||||
        local find_img="${dest_sfs}/${sfs}/LiveOS/${sfs}.img"
 | 
					 | 
				
			||||||
        if [[ -f "${find_img}" ]]; then
 | 
					 | 
				
			||||||
            mkdir -p ${dest_img}
 | 
					 | 
				
			||||||
            lower_dir=$(_gen_arg "${dest_img}/${sfs}")
 | 
					 | 
				
			||||||
            _mnt_dmsnapshot "${find_img}" "${dest_img}/${sfs}"
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            lower_dir=$(_gen_arg "${dest_sfs}/${sfs}")
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This function is called normally from init script, but it can be called
 | 
					 | 
				
			||||||
# as chain from other mount handlers.
 | 
					 | 
				
			||||||
# args: /path/to/newroot
 | 
					 | 
				
			||||||
artix_mount_handler() {
 | 
					 | 
				
			||||||
    local newroot="${1}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if ! mountpoint -q "${bootmnt}"; then
 | 
					 | 
				
			||||||
        _mnt_dev "${artixdevice}" "${bootmnt}" "-r" "defaults"
 | 
					 | 
				
			||||||
        if [[ "${copytoram}" != "y" ]]; then
 | 
					 | 
				
			||||||
            echo $(readlink -f ${artixdevice}) >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${checksum}" == "y" ]]; then
 | 
					 | 
				
			||||||
        _check_sum "rootfs"
 | 
					 | 
				
			||||||
        [[ -n "${overlay}" ]] && _check_sum "${overlay}"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${verify}" == "y" ]]; then
 | 
					 | 
				
			||||||
        _check_sig "rootfs"
 | 
					 | 
				
			||||||
        [[ -n "${overlay}" ]] && _check_sig "${overlay}"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
        msg ":: Mounting ${cp2ram} (tmpfs) filesystem, size=${copytoram_size}"
 | 
					 | 
				
			||||||
        mkdir -p ${cp2ram}
 | 
					 | 
				
			||||||
        mount -t tmpfs -o "size=${copytoram_size}",mode=0755 copytoram ${cp2ram}
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ -n "${cow_device}" ]]; then
 | 
					 | 
				
			||||||
        _mnt_dev "${cow_device}" "${cow}" "-r" "${cow_flags}"
 | 
					 | 
				
			||||||
        echo $(readlink -f ${cow_device}) >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
        mount -o remount,rw "${cow}"
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        msg ":: Mounting ${cow} (tmpfs) filesystem, size=${cow_spacesize}..."
 | 
					 | 
				
			||||||
        mkdir -p ${cow}
 | 
					 | 
				
			||||||
        mount -t tmpfs -o "size=${cow_spacesize}",mode=0755 cowspace ${cow}
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
    mkdir -p -m 0700 "${cow}/${cow_directory}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg -n ":: Mounting overlay root (tmpfs) filesystem, size=${overlay_root_size}..."
 | 
					 | 
				
			||||||
    mkdir -p ${overlay_root}
 | 
					 | 
				
			||||||
    mount -t tmpfs -o "size=${overlay_root_size}",mode=0755 overlay_root ${overlay_root}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    [[ -n "${overlay}" ]] && _mount_root_overlayfs "${overlay}"
 | 
					 | 
				
			||||||
    _mount_root_overlayfs "rootfs"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    _mnt_overlayfs "${lower_dir}" "${newroot}" "/"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
        umount -d ${bootmnt}
 | 
					 | 
				
			||||||
        mkdir -p ${bootmnt}/${root}
 | 
					 | 
				
			||||||
        mount -o bind ${cp2ram} ${bootmnt}/${root}
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim:ft=sh:ts=4:sw=4:et:
 | 
					 | 
				
			||||||
@@ -1,35 +0,0 @@
 | 
				
			|||||||
# vim: set ft=sh:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook () {
 | 
					 | 
				
			||||||
    [[ -n "${img_label}" ]] && img_dev="/dev/disk/by-label/${img_label}"
 | 
					 | 
				
			||||||
    [[ -z "${img_flags}" ]] && img_flags="defaults"
 | 
					 | 
				
			||||||
    if [[ -n "${img_dev}" && -n "${img_loop}" ]]; then
 | 
					 | 
				
			||||||
        mount_handler="artix_loop_mount_handler"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
artix_loop_mount_handler () {
 | 
					 | 
				
			||||||
    newroot="${1}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    local _dev_loop
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Setup a loop device from ${img_loop} located at device ${img_dev}"
 | 
					 | 
				
			||||||
    _mnt_dev "${img_dev}" "${live_root}/img_dev" "-r" "${img_flags}"
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" != "y" ]]; then
 | 
					 | 
				
			||||||
        echo $(readlink -f ${img_dev}) >> ${live_root}/used_block_devices
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if _dev_loop=$(losetup --find --show --read-only "${live_root}/img_dev/${img_loop}"); then
 | 
					 | 
				
			||||||
        artixdevice="${_dev_loop}"
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        echo "ERROR: Setting loopback device for file '${live_root}/img_dev/${img_loop}'"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    artix_mount_handler ${newroot}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
        losetup -d ${_dev_loop} 2>/dev/null
 | 
					 | 
				
			||||||
        umount ${live_root}/img_dev
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,72 +0,0 @@
 | 
				
			|||||||
# vim: set ft=sh:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook () {
 | 
					 | 
				
			||||||
    # Do *not* declare 'bootif_dev' local! We need it in run_latehook().
 | 
					 | 
				
			||||||
    local i net_mac bootif_mac
 | 
					 | 
				
			||||||
    # These variables will be parsed from /tmp/net-*.conf generated by ipconfig
 | 
					 | 
				
			||||||
    local DEVICE
 | 
					 | 
				
			||||||
    local IPV4ADDR IPV4BROADCAST IPV4NETMASK IPV4GATEWAY IPV4DNS0 IPV4DNS1
 | 
					 | 
				
			||||||
    local HOSTNAME DNSDOMAIN NISDOMAIN ROOTSERVER ROOTPATH
 | 
					 | 
				
			||||||
    local filename
 | 
					 | 
				
			||||||
    # /tmp/net-*.conf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" ]]; then
 | 
					 | 
				
			||||||
        if [[ -n "${BOOTIF}" ]]; then
 | 
					 | 
				
			||||||
            bootif_mac=${BOOTIF#01-}
 | 
					 | 
				
			||||||
            bootif_mac=${bootif_mac//-/:}
 | 
					 | 
				
			||||||
            for i in /sys/class/net/*/address; do
 | 
					 | 
				
			||||||
                read net_mac < ${i}
 | 
					 | 
				
			||||||
                if [[ "${bootif_mac}" == "${net_mac}" ]]; then
 | 
					 | 
				
			||||||
                    bootif_dev=${i#/sys/class/net/}
 | 
					 | 
				
			||||||
                    bootif_dev=${bootif_dev%/address}
 | 
					 | 
				
			||||||
                    break
 | 
					 | 
				
			||||||
                fi
 | 
					 | 
				
			||||||
            done
 | 
					 | 
				
			||||||
            if [[ "${ip}" == "dhcp" ]]; then
 | 
					 | 
				
			||||||
               ip=":::::${bootif_dev}:dhcp"
 | 
					 | 
				
			||||||
            else
 | 
					 | 
				
			||||||
               ip="${ip}::${bootif_dev}"
 | 
					 | 
				
			||||||
           fi
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # setup network and save some values
 | 
					 | 
				
			||||||
        if ! ipconfig -t 20 "ip=${ip}"; then
 | 
					 | 
				
			||||||
                echo "ERROR; Failed to configure network"
 | 
					 | 
				
			||||||
                echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
                echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
                launch_interactive_shell
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        . /tmp/net-*.conf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        pxeserver=${ROOTSERVER}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # setup DNS resolver
 | 
					 | 
				
			||||||
        if [[ "${IPV4DNS0}" != "0.0.0.0" ]]; then
 | 
					 | 
				
			||||||
            echo "# added by artix_pxe_common hook" > /etc/resolv.conf
 | 
					 | 
				
			||||||
            echo "nameserver ${IPV4DNS0}" >> /etc/resolv.conf
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        if [[ "${IPV4DNS1}" != "0.0.0.0" ]]; then
 | 
					 | 
				
			||||||
            echo "nameserver ${IPV4DNS1}" >> /etc/resolv.conf
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        if [[ -n "${DNSDOMAIN}" ]]; then
 | 
					 | 
				
			||||||
            echo "search ${DNSDOMAIN}" >> /etc/resolv.conf
 | 
					 | 
				
			||||||
            echo "domain ${DNSDOMAIN}" >> /etc/resolv.conf
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_latehook () {
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" ]]; then
 | 
					 | 
				
			||||||
        [[ -z "${copy_resolvconf}" ]] && copy_resolvconf="y"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
            if [[ -n "${bootif_dev}" ]]; then
 | 
					 | 
				
			||||||
                ip addr flush dev "${bootif_dev}"
 | 
					 | 
				
			||||||
                ip link set "${bootif_dev}" down
 | 
					 | 
				
			||||||
            fi
 | 
					 | 
				
			||||||
        elif [[ "${copy_resolvconf}" != "n" && -f /etc/resolv.conf ]]; then
 | 
					 | 
				
			||||||
            cp /etc/resolv.conf /new_root/etc/resolv.conf
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,63 +0,0 @@
 | 
				
			|||||||
# vim: set ft=sh:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook() {
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" && -n "${artix_http_srv}" ]]; then
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        # booting with http is always copy-to-ram, so set here to make sure
 | 
					 | 
				
			||||||
        # addresses are flushed and interface is set down
 | 
					 | 
				
			||||||
        copytoram="y"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        artix_http_srv=$(eval echo ${artix_http_srv})
 | 
					 | 
				
			||||||
        [[ -z "${artix_http_spc}" ]] && artix_http_spc="75%"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        mount_handler="artix_pxe_http_mount_handler"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Fetch a file with CURL
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# $1 URL
 | 
					 | 
				
			||||||
# $2 Destination directory inside httpspace/${root}
 | 
					 | 
				
			||||||
_curl_get() {
 | 
					 | 
				
			||||||
    local _url="${1}"
 | 
					 | 
				
			||||||
    local _dst="${2}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Downloading '${_url}'"
 | 
					 | 
				
			||||||
    if ! curl -L -f -o "${live_root}/httpspace/${root}${_dst}/${_url##*/}" --create-dirs "${_url}"; then
 | 
					 | 
				
			||||||
        echo "ERROR: Downloading '${_url}'"
 | 
					 | 
				
			||||||
        echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
        echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
_get_sfs() {
 | 
					 | 
				
			||||||
    local _sfs="${2}"
 | 
					 | 
				
			||||||
    local _src=${artix_http_srv}${root}
 | 
					 | 
				
			||||||
    if [[ ! -z "$( curl -s --head "${_src}/${_sfs}.img" | grep "OK" )" ]]; then
 | 
					 | 
				
			||||||
        _curl_get "${_src}/${_sfs}.img" "/"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if [[ "${checksum}" == "y" ]]; then
 | 
					 | 
				
			||||||
            _curl_get "${_src}/${_sfs}.md5" "/"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
        if [[ "${verify}" == "y" ]]; then
 | 
					 | 
				
			||||||
            _curl_get "${_src}/${_sfs}.img.sig" "/"
 | 
					 | 
				
			||||||
        fi
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
artix_pxe_http_mount_handler () {
 | 
					 | 
				
			||||||
    newroot="${1}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Mounting ${live_root}/httpspace (tmpfs) filesystem, size='${artix_http_spc}'"
 | 
					 | 
				
			||||||
    mkdir -p "${live_root}/httpspace"
 | 
					 | 
				
			||||||
    mount -t tmpfs -o size="${artix_http_spc}",mode=0755 httpspace "${live_root}/httpspace"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    _get_sfs "rootfs"
 | 
					 | 
				
			||||||
    [[ -n "${overlay}" ]] && _mount_root_overlayfs "${overlay}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    mkdir -p "${bootmnt}"
 | 
					 | 
				
			||||||
    mount -o bind ${live_root}/httpspace ${bootmnt}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    artix_mount_handler ${newroot}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,47 +0,0 @@
 | 
				
			|||||||
# vim: set ft=sh:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_earlyhook() {
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" && -n "${artix_nbd_srv}" ]]; then
 | 
					 | 
				
			||||||
        # Module autoloading like with loop devices does not work, doing manually...
 | 
					 | 
				
			||||||
        modprobe nbd 2> /dev/null
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook() {
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" && -n "${artix_nbd_srv}" ]]; then
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        artix_nbd_srv=$(eval echo ${artix_nbd_srv})
 | 
					 | 
				
			||||||
        [[ -z "${artix_nbd_name}" ]] && artix_nbd_name="artix"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        mount_handler="artix_pxe_nbd_mount_handler"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
artix_pxe_nbd_mount_handler () {
 | 
					 | 
				
			||||||
    newroot="${1}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Waiting for boot device..."
 | 
					 | 
				
			||||||
    while ! poll_device /dev/nbd0 30; do
 | 
					 | 
				
			||||||
        echo "ERROR: boot device didn't show up after 30 seconds..."
 | 
					 | 
				
			||||||
        echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
        echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    msg ":: Setup NBD from ${artix_nbd_srv} at /dev/nbd0"
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" != "n" ]]; then
 | 
					 | 
				
			||||||
        nbd-client ${artix_nbd_srv} -N ${artix_nbd_name} /dev/nbd0
 | 
					 | 
				
			||||||
        copytoram="y"
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        nbd-client ${artix_nbd_srv} -N ${artix_nbd_name} -persist /dev/nbd0
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    artixdevice=/dev/nbd0
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    artix_mount_handler ${newroot}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" == "y" ]]; then
 | 
					 | 
				
			||||||
        msg ":: Disconnect NBD from ${artix_nbd_srv} at /dev/nbd0"
 | 
					 | 
				
			||||||
        nbd-client -d /dev/nbd0
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,30 +0,0 @@
 | 
				
			|||||||
# vim: set ft=sh:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
run_hook() {
 | 
					 | 
				
			||||||
    if [[ -n "${ip}" && -n "${artix_nfs_srv}" ]]; then
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        artix_nfs_srv=$(eval echo ${artix_nfs_srv})
 | 
					 | 
				
			||||||
        [[ -n "${artix_nfs_opt}" ]] && artix_nfs_opt="-o ${artix_nfs_opt}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        mount_handler="artix_nfs_mount_handler"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
artix_nfs_mount_handler() {
 | 
					 | 
				
			||||||
    newroot="${1}"
 | 
					 | 
				
			||||||
    mkdir -p "${bootmnt}"
 | 
					 | 
				
			||||||
    msg ":: Mounting '${artix_nfs_srv}'"
 | 
					 | 
				
			||||||
    # Do not put "${artix_nfs_opt}" nfsmount fails!
 | 
					 | 
				
			||||||
    if ! nfsmount ${artix_nfs_opt} "${artix_nfs_srv}" "${bootmnt}"; then
 | 
					 | 
				
			||||||
        echo "ERROR: Mounting '${artix_nfs_srv}'"
 | 
					 | 
				
			||||||
        echo "   Falling back to interactive prompt"
 | 
					 | 
				
			||||||
        echo "   You can try to fix the problem manually, log out when you are finished"
 | 
					 | 
				
			||||||
        launch_interactive_shell
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if [[ "${copytoram}" != "n" ]]; then
 | 
					 | 
				
			||||||
        copytoram="y"
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    artix_mount_handler ${newroot}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,6 +0,0 @@
 | 
				
			|||||||
run_cleanuphook() {
 | 
					 | 
				
			||||||
    rm -rf /usr/lib/modules
 | 
					 | 
				
			||||||
    cp -ax / /run/initramfs
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,30 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_module "cdrom"
 | 
					 | 
				
			||||||
    add_module "loop"
 | 
					 | 
				
			||||||
    add_module "dm-snapshot"
 | 
					 | 
				
			||||||
    add_module "overlay"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_binary /usr/lib/udev/cdrom_id
 | 
					 | 
				
			||||||
    add_binary blockdev
 | 
					 | 
				
			||||||
    add_binary dmsetup
 | 
					 | 
				
			||||||
    add_binary losetup
 | 
					 | 
				
			||||||
    add_binary mountpoint
 | 
					 | 
				
			||||||
    add_binary truncate
 | 
					 | 
				
			||||||
    add_binary gpg
 | 
					 | 
				
			||||||
    add_binary grep
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_file /usr/lib/udev/rules.d/60-cdrom_id.rules
 | 
					 | 
				
			||||||
    add_file /usr/lib/udev/rules.d/10-dm.rules
 | 
					 | 
				
			||||||
    add_file /usr/lib/udev/rules.d/95-dm-notify.rules
 | 
					 | 
				
			||||||
    add_file /usr/lib/initcpio/udev/11-dm-initramfs.rules /usr/lib/udev/rules.d/11-dm-initramfs.rules
 | 
					 | 
				
			||||||
    if [[ $ARTIX_GNUPG_FD ]]; then
 | 
					 | 
				
			||||||
        mkdir -p "$BUILDROOT$dest"/gpg
 | 
					 | 
				
			||||||
        gpg --homedir "$BUILDROOT$dest"/gpg --import <&$ARTIX_GNUPG_FD
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,16 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_module "radeon"
 | 
					 | 
				
			||||||
    add_module "nouveau"
 | 
					 | 
				
			||||||
    add_module "i915"
 | 
					 | 
				
			||||||
    add_module "via-agp"
 | 
					 | 
				
			||||||
    add_module "sis-agp"
 | 
					 | 
				
			||||||
    add_module "intel-agp"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
    cat << HELPEOF
 | 
					 | 
				
			||||||
Adds all common KMS drivers to the initramfs image.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,13 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
cat<<HELPEOF
 | 
					 | 
				
			||||||
  This hook loads the necessary modules for boot via loop device.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,26 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_checked_modules -f "(irda|phy|wimax|wireless|ppp_|plip|pppoe)" "/drivers/net/"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_binary /usr/lib/initcpio/ipconfig /bin/ipconfig
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    # Add hosts support files+dns
 | 
					 | 
				
			||||||
    add_symlink /usr/lib/libnss_files.so.2 $(readlink /usr/lib/libnss_files.so.2)
 | 
					 | 
				
			||||||
    add_binary $(readlink -f /usr/lib/libnss_files.so.2)
 | 
					 | 
				
			||||||
    add_symlink /usr/lib/libnss_dns.so.2 $(readlink /usr/lib/libnss_dns.so.2)
 | 
					 | 
				
			||||||
    add_binary $(readlink -f /usr/lib/libnss_dns.so.2)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_dir /etc
 | 
					 | 
				
			||||||
    echo "hosts: files dns" > $BUILDROOT/etc/nsswitch.conf
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
cat<<HELPEOF
 | 
					 | 
				
			||||||
  This hook loads the necessary modules for boot via PXE.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,17 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_binary curl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_file $(readlink -f /etc/ssl/certs/ca-certificates.crt) /etc/ssl/certs/ca-certificates.crt
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
cat<<HELPEOF
 | 
					 | 
				
			||||||
  This hook loads the necessary modules for boot via PXE and HTTP.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,17 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_module "nbd"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_binary nbd-client
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
cat<<HELPEOF
 | 
					 | 
				
			||||||
  This hook loads the necessary modules for boot via PXE and NBD.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,17 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_module "nfs"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_binary /usr/lib/initcpio/nfsmount /bin/nfsmount
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
    cat <<HELPEOF
 | 
					 | 
				
			||||||
  This hook loads the necessary modules for boot via PXE and NFS.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,20 +0,0 @@
 | 
				
			|||||||
#!/bin/bash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build() {
 | 
					 | 
				
			||||||
    add_binary cp
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_runscript
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    add_file /etc/initcpio/artix_shutdown /shutdown
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
help() {
 | 
					 | 
				
			||||||
    cat <<HELPEOF
 | 
					 | 
				
			||||||
This hook will create a shutdown initramfs in /run/initramfs
 | 
					 | 
				
			||||||
that we can pivot to on shutdown in order to unmount / and
 | 
					 | 
				
			||||||
and others mount points, dm-snapshot devices and loopback devices.
 | 
					 | 
				
			||||||
Mostly usefull for dm-snapshot persistent.
 | 
					 | 
				
			||||||
HELPEOF
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# vim: set ft=sh ts=4 sw=4 et:
 | 
					 | 
				
			||||||
@@ -1,37 +0,0 @@
 | 
				
			|||||||
#!/bin/ash
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# /oldroot depends on things inside /oldroot/run/artix...
 | 
					 | 
				
			||||||
mkdir /oldrun
 | 
					 | 
				
			||||||
mount -n --move /oldroot/run /oldrun
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Unmount all mounts now.
 | 
					 | 
				
			||||||
umount $(mount | awk '$3 ~/^\/oldroot/ {print $3}' | sort -r)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Remove all dm-snapshot devices.
 | 
					 | 
				
			||||||
dmsetup remove_all
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Remove all loopback devices.
 | 
					 | 
				
			||||||
for _lup in $(grep ^/dev/loop /oldrun/artix/used_block_devices | tac); do
 | 
					 | 
				
			||||||
    if ! losetup -d ${_lup} 2> /dev/null; then
 | 
					 | 
				
			||||||
        umount -d ${_lup}
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Unmount the space used to store *.cow.
 | 
					 | 
				
			||||||
umount /oldrun/artix/cowspace
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Unmount boot device if needed (no copytoram=y used)
 | 
					 | 
				
			||||||
if [[ ! -d /oldrun/artix/copytoram ]]; then
 | 
					 | 
				
			||||||
    if [[ -d /oldrun/artix/img_dev ]]; then
 | 
					 | 
				
			||||||
        umount /oldrun/artix/img_dev
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
        umount /oldrun/bootmnt
 | 
					 | 
				
			||||||
    fi
 | 
					 | 
				
			||||||
fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# reboot / poweroff / halt, depending on the argument passed by init
 | 
					 | 
				
			||||||
# if something invalid is passed, we halt
 | 
					 | 
				
			||||||
case "$1" in
 | 
					 | 
				
			||||||
  reboot|poweroff|halt) "$1" -f ;;
 | 
					 | 
				
			||||||
  *) halt -f;;
 | 
					 | 
				
			||||||
esac
 | 
					 | 
				
			||||||
@@ -29,13 +29,20 @@ 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' "" >> "$conf"
 | 
				
			||||||
 | 
					    printf '%s\n' "defaultBundle: default" >> "$conf"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
write_services_66_conf(){
 | 
					write_services_suite66_conf(){
 | 
				
			||||||
    local conf="$1"/services-66.conf
 | 
					    local conf="$1"/services-suite66.conf
 | 
				
			||||||
    write_services_conf 'svDir' '/etc/66/service' 'runsvDir' '/var/lib/66/system' > "$conf"
 | 
					    write_services_conf 'svDir' '/etc/66/service' 'runsvDir' '/var/lib/66/system' > "$conf"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					write_services_dinit_conf(){
 | 
				
			||||||
 | 
					    local conf="$1"/services-dinit.conf
 | 
				
			||||||
 | 
					    write_services_conf 'initdDir' '/etc/dinit.d' 'runsvDir' '/etc/dinit.d/boot.d' > "$conf"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
configure_calamares(){
 | 
					configure_calamares(){
 | 
				
			||||||
    local mods="$1/etc/calamares/modules"
 | 
					    local mods="$1/etc/calamares/modules"
 | 
				
			||||||
    if [[ -d "$mods" ]];then
 | 
					    if [[ -d "$mods" ]];then
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -10,7 +10,7 @@ prepare_initramfs_dracut(){
 | 
				
			|||||||
    printf "%s\n" 'add_dracutmodules+=" dmsquash-live"' > "$mnt"/etc/dracut.conf.d/50-live.conf
 | 
					    printf "%s\n" 'add_dracutmodules+=" dmsquash-live"' > "$mnt"/etc/dracut.conf.d/50-live.conf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg "Starting build: %s" "${kver}"
 | 
					    msg "Starting build: %s" "${kver}"
 | 
				
			||||||
    artools-chroot "$mnt" dracut -fqM /boot/initramfs.img "$kver"
 | 
					    artix-chroot "$mnt" dracut -fqM /boot/initramfs.img "$kver"
 | 
				
			||||||
    msg "Image generation successful"
 | 
					    msg "Image generation successful"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    cp "$mnt"/boot/initramfs.img "${iso_root}"/boot/initramfs-"${arch}".img
 | 
					    cp "$mnt"/boot/initramfs.img "${iso_root}"/boot/initramfs-"${arch}".img
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,20 +2,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#{{{ grub
 | 
					#{{{ grub
 | 
				
			||||||
 | 
					
 | 
				
			||||||
configure_grub(){
 | 
					 | 
				
			||||||
    msg "Configuring grub kernel options ..."
 | 
					 | 
				
			||||||
    local ro_opts=()
 | 
					 | 
				
			||||||
    local rw_opts=()
 | 
					 | 
				
			||||||
    local kopts=("label=${iso_label}")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    [[ "${profile}" != 'base' ]] && kopts+=('overlay=livefs')
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    sed -e "s|@kopts@|${kopts[*]}|" \
 | 
					 | 
				
			||||||
        -e "s|@ro_opts@|${ro_opts[*]}|" \
 | 
					 | 
				
			||||||
        -e "s|@rw_opts@|${rw_opts[*]}|" \
 | 
					 | 
				
			||||||
        -i "${iso_root}"/boot/grub/kernels.cfg
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
prepare_grub(){
 | 
					prepare_grub(){
 | 
				
			||||||
    local platform=i386-pc img='core.img' prefix=/boot/grub
 | 
					    local platform=i386-pc img='core.img' prefix=/boot/grub
 | 
				
			||||||
    local lib="$1"/usr/lib/grub
 | 
					    local lib="$1"/usr/lib/grub
 | 
				
			||||||
@@ -23,7 +9,6 @@ prepare_grub(){
 | 
				
			|||||||
    local livecfg="$2"/usr/share/grub
 | 
					    local livecfg="$2"/usr/share/grub
 | 
				
			||||||
    local grub=${iso_root}/boot/grub efi=${iso_root}/efi/boot
 | 
					    local grub=${iso_root}/boot/grub efi=${iso_root}/efi/boot
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
    prepare_dir "${grub}/${platform}"
 | 
					    prepare_dir "${grub}/${platform}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    cp "${livecfg}"/cfg/*.cfg "${grub}"
 | 
					    cp "${livecfg}"/cfg/*.cfg "${grub}"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,56 +2,71 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#{{{ initcpio
 | 
					#{{{ initcpio
 | 
				
			||||||
 | 
					
 | 
				
			||||||
write_mkinitcpio_conf() {
 | 
					make_checksum(){
 | 
				
			||||||
    msg2 "Writing mkinitcpio.conf ..."
 | 
					    local file="$1"
 | 
				
			||||||
    local conf="$1/etc/mkinitcpio-artix.conf"
 | 
					    msg2 "Creating md5sum ..."
 | 
				
			||||||
    printf "%s\n" 'MODULES=(loop dm-snapshot)' > "$conf"
 | 
					    cd "${iso_root}${live_dir}"
 | 
				
			||||||
    printf "%s\n" 'COMPRESSION="xz"' >> "$conf"
 | 
					    md5sum "$file" > "$file".md5
 | 
				
			||||||
    if [[ "${profile}" == 'base' ]];then
 | 
					    cd "${OLDPWD}"
 | 
				
			||||||
        printf "%s\n" 'HOOKS=(base udev artix_shutdown artix artix_loop_mnt
 | 
					}
 | 
				
			||||||
                            artix_pxe_common artix_pxe_http artix_pxe_nbd artix_pxe_nfs
 | 
					
 | 
				
			||||||
                            artix_kms modconf block filesystems keyboard keymap)' >> "$conf"
 | 
					make_sig () {
 | 
				
			||||||
    else
 | 
					    local file="$1"
 | 
				
			||||||
        printf "%s\n" 'HOOKS=(base udev artix_shutdown artix artix_loop_mnt
 | 
					    msg2 "Creating signature file..."
 | 
				
			||||||
                            artix_kms modconf block filesystems keyboard keymap)' >> "$conf"
 | 
					    chown "${owner}:$(id --group "${owner}")" "${iso_root}${live_dir}"
 | 
				
			||||||
 | 
					    su "${owner}" -c "gpg --detach-sign --output $file.sig --default-key ${GPG_KEY} $file"
 | 
				
			||||||
 | 
					    chown "root:root" "${iso_root}${live_dir}"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export_gpg_publickey() {
 | 
				
			||||||
 | 
					    key_export=${WORKSPACE_DIR}/pubkey.gpg
 | 
				
			||||||
 | 
					    if [[ ! -e "${key_export}" ]]; then
 | 
				
			||||||
 | 
					        gpg --batch --output "${key_export}" --export "${GPG_KEY}"
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
prepare_initcpio(){
 | 
					prepare_initramfs_mkinitcpio() {
 | 
				
			||||||
    msg2 "Copying initcpio ..."
 | 
					    local mnt="$1" packages=() mkinitcpio_conf k
 | 
				
			||||||
    local dest="$1"
 | 
					 | 
				
			||||||
    cp /etc/initcpio/hooks/artix* "$dest"/etc/initcpio/hooks
 | 
					 | 
				
			||||||
    cp /etc/initcpio/install/artix* "$dest"/etc/initcpio/install
 | 
					 | 
				
			||||||
    cp /etc/initcpio/artix_shutdown "$dest"/etc/initcpio
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
prepare_initramfs(){
 | 
					    mkinitcpio_conf=mkinitcpio-default.conf
 | 
				
			||||||
    local mnt="$1"
 | 
					    [[ "${profile}" == 'base' ]] && mkinitcpio_conf=mkinitcpio-pxe.conf
 | 
				
			||||||
 | 
					    k=$(<"$mnt"/usr/src/linux/version)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    prepare_initcpio "$mnt"
 | 
					    read_from_list "${common_dir}/Packages-boot"
 | 
				
			||||||
 | 
					    basestrap "${basestrap_args[@]}" "$mnt" "${packages[@]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    write_mkinitcpio_conf "$mnt"
 | 
					    if [[ -n "${GPG_KEY}" ]]; then
 | 
				
			||||||
 | 
					        exec {ARTIX_GNUPG_FD}<>"${key_export}"
 | 
				
			||||||
    if [[ -n ${GPG_KEY} ]]; then
 | 
					        export ARTIX_GNUPG_FD
 | 
				
			||||||
        su "${owner}" -c "gpg --export ${GPG_KEY} >/tmp/GPG_KEY"
 | 
					 | 
				
			||||||
        exec 17<>/tmp/GPG_KEY
 | 
					 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
    local _kernel
 | 
					
 | 
				
			||||||
     _kernel=$(<"$mnt"/usr/src/linux/version)
 | 
					    artix-chroot "$mnt" mkinitcpio -k "$k" \
 | 
				
			||||||
    ARTIX_GNUPG_FD=${GPG_KEY:+17} artools-chroot "$mnt" \
 | 
					        -c /etc/"$mkinitcpio_conf" \
 | 
				
			||||||
        /usr/bin/mkinitcpio -k "${_kernel}" \
 | 
					 | 
				
			||||||
        -c /etc/mkinitcpio-artix.conf \
 | 
					 | 
				
			||||||
        -g /boot/initramfs.img
 | 
					        -g /boot/initramfs.img
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [[ -n "${GPG_KEY}" ]]; then
 | 
					    if [[ -n "${GPG_KEY}" ]]; then
 | 
				
			||||||
        exec 17<&-
 | 
					        exec {ARTIX_GNUPG_FD}<&-
 | 
				
			||||||
 | 
					        unset ARTIX_GNUPG_FD
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
    if [[ -f /tmp/GPG_KEY ]]; then
 | 
					    if [[ -f "${key_export}" ]]; then
 | 
				
			||||||
        rm /tmp/GPG_KEY
 | 
					        rm "${key_export}"
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 | 
					 | 
				
			||||||
    cp "$mnt"/boot/initramfs.img "${iso_root}"/boot/initramfs-"${arch}".img
 | 
					    cp "$mnt"/boot/initramfs.img "${iso_root}"/boot/initramfs-"${arch}".img
 | 
				
			||||||
    prepare_boot_extras "$mnt"
 | 
					    prepare_boot_extras "$mnt"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					configure_grub_mkinitcpio() {
 | 
				
			||||||
 | 
					    msg "Configuring grub kernel options ..."
 | 
				
			||||||
 | 
					    local ro_opts=()
 | 
				
			||||||
 | 
					    local rw_opts=()
 | 
				
			||||||
 | 
					    local kopts=("label=${iso_label}")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    [[ "${profile}" != 'base' ]] && kopts+=('overlay=livefs')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    sed -e "s|@kopts@|${kopts[*]}|" \
 | 
				
			||||||
 | 
					        -e "s|@ro_opts@|${ro_opts[*]}|" \
 | 
				
			||||||
 | 
					        -e "s|@rw_opts@|${rw_opts[*]}|" \
 | 
				
			||||||
 | 
					        -i "${iso_root}"/boot/grub/kernels.cfg
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#}}}
 | 
					#}}}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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}") ;;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -23,27 +23,29 @@ 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" s6-rc-bundle-update -c "$db" add "$rlvl" "$svc"
 | 
					            fi
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
    done
 | 
					    done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    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_66(){
 | 
					add_svc_suite66(){
 | 
				
			||||||
    local mnt="$1" names="$2"
 | 
					    local mnt="$1" names="$2"
 | 
				
			||||||
    for svc in $names; do
 | 
					    for svc in $names; do
 | 
				
			||||||
        if [[ -f "$mnt"/etc/66/service/"$svc" ]]; then
 | 
					        if [[ -f "$mnt"/etc/66/service/"$svc" ]]; then
 | 
				
			||||||
@@ -53,4 +55,14 @@ add_svc_66(){
 | 
				
			|||||||
    done
 | 
					    done
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					add_svc_dinit(){
 | 
				
			||||||
 | 
					    local mnt="$1" names="$2"
 | 
				
			||||||
 | 
					    for svc in $names; do
 | 
				
			||||||
 | 
					        if [[ -d $mnt/etc/dinit.d/boot.d ]]; then
 | 
				
			||||||
 | 
					            msg2 "Setting %s: [%s]" "${INITSYS}" "$svc"
 | 
				
			||||||
 | 
					            chroot "$mnt" ln -s ../"$svc" /etc/dinit.d/boot.d/"$svc" &>/dev/null
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#}}}
 | 
					#}}}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,24 +2,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#{{{ squash
 | 
					#{{{ squash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
make_sig () {
 | 
					 | 
				
			||||||
    local file="$1"
 | 
					 | 
				
			||||||
    msg2 "Creating signature file..."
 | 
					 | 
				
			||||||
    cd "${iso_root}${live_dir}"
 | 
					 | 
				
			||||||
    chown "${owner}:$(id --group "${owner}")" "${iso_root}${live_dir}"
 | 
					 | 
				
			||||||
    su "${owner}" -c "gpg --detach-sign --default-key ${GPG_KEY} $file"
 | 
					 | 
				
			||||||
    chown -R root "${iso_root}${live_dir}"
 | 
					 | 
				
			||||||
    cd "${OLDPWD}"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make_checksum(){
 | 
					 | 
				
			||||||
    local file="$1"
 | 
					 | 
				
			||||||
    msg2 "Creating md5sum ..."
 | 
					 | 
				
			||||||
    cd "${iso_root}${live_dir}"
 | 
					 | 
				
			||||||
    md5sum "$file" > "$file".md5
 | 
					 | 
				
			||||||
    cd "${OLDPWD}"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
make_ext_img(){
 | 
					make_ext_img(){
 | 
				
			||||||
    local src="$1"
 | 
					    local src="$1"
 | 
				
			||||||
    local size=32G
 | 
					    local size=32G
 | 
				
			||||||
@@ -85,14 +67,14 @@ make_sfs() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        mksfs_args+=("${sfs_out}")
 | 
					        mksfs_args+=("${sfs_out}")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        mksfs_args+=(-comp xz -b 256K -Xbcj x86 -noappend)
 | 
					        mksfs_args+=(-comp "${COMPRESSION}" "${COMPRESSION_ARGS[@]}" -noappend)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        mksquashfs "${mksfs_args[@]}"
 | 
					        mksquashfs "${mksfs_args[@]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if ! ${use_dracut}; then
 | 
					        if ! ${use_dracut}; then
 | 
				
			||||||
            make_checksum "${img_name}"
 | 
					            make_checksum "${img_name}"
 | 
				
			||||||
            if [[ -n ${GPG_KEY} ]];then
 | 
					            if [[ -n ${GPG_KEY} ]];then
 | 
				
			||||||
                make_sig "${img_name}"
 | 
					                make_sig "${iso_root}${live_dir}/${img_name}"
 | 
				
			||||||
            fi
 | 
					            fi
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
        if ${persist}; then
 | 
					        if ${persist}; then
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -41,7 +41,7 @@ find_pkg(){
 | 
				
			|||||||
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 repos -o -name "$CARCH" | sort)
 | 
					        pkgs=$(find "${TREE_DIR_ARTIX}/$tree" -name "$CARCH" | sort)
 | 
				
			||||||
        for _package in ${pkgs}; do
 | 
					        for _package in ${pkgs}; do
 | 
				
			||||||
            "$func" "$_package"
 | 
					            "$func" "$_package"
 | 
				
			||||||
        done
 | 
					        done
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,32 +5,31 @@
 | 
				
			|||||||
msg_table_header(){
 | 
					msg_table_header(){
 | 
				
			||||||
    local mesg=$1; shift
 | 
					    local mesg=$1; shift
 | 
				
			||||||
    # shellcheck disable=2059
 | 
					    # shellcheck disable=2059
 | 
				
			||||||
    printf "${BLUE} ${mesg} ${ALL_OFF}\n" "$@" >&2
 | 
					    printf "${BLUE} ${mesg} ${ALL_OFF}\n" "$@"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_row_yellow(){
 | 
					msg_row_yellow(){
 | 
				
			||||||
    local mesg=$1; shift
 | 
					    local mesg=$1; shift
 | 
				
			||||||
    # shellcheck disable=2059
 | 
					    # shellcheck disable=2059
 | 
				
			||||||
    printf "${YELLOW} ${mesg}${ALL_OFF}\n" "$@" >&2
 | 
					    printf "${YELLOW} ${mesg}${ALL_OFF}\n" "$@"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_row_green(){
 | 
					msg_row_green(){
 | 
				
			||||||
    local mesg=$1; shift
 | 
					    local mesg=$1; shift
 | 
				
			||||||
    # shellcheck disable=2059
 | 
					    # shellcheck disable=2059
 | 
				
			||||||
    printf "${GREEN} ${mesg}${ALL_OFF}\n" "$@" >&2
 | 
					    printf "${GREEN} ${mesg}${ALL_OFF}\n" "$@"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_row(){
 | 
					msg_row(){
 | 
				
			||||||
    local mesg=$1; shift
 | 
					    local mesg=$1; shift
 | 
				
			||||||
#     printf "${BOLD} ${mesg}${ALL_OFF}\n" "$@" >&2
 | 
					 | 
				
			||||||
    # shellcheck disable=2059
 | 
					    # shellcheck disable=2059
 | 
				
			||||||
    printf "${WHITE} ${mesg}${ALL_OFF}\n" "$@" >&2
 | 
					    printf "${WHITE} ${mesg}${ALL_OFF}\n" "$@"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_row_red(){
 | 
					msg_row_red(){
 | 
				
			||||||
    local mesg=$1; shift
 | 
					    local mesg=$1; shift
 | 
				
			||||||
    # shellcheck disable=2059
 | 
					    # shellcheck disable=2059
 | 
				
			||||||
    printf "${RED} ${mesg} ${ALL_OFF}\n" "$@" >&2
 | 
					    printf "${RED} ${mesg} ${ALL_OFF}\n" "$@"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#}}}
 | 
					#}}}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,18 @@ load_iso_config(){
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    GPG_KEY=${GPG_KEY:-''}
 | 
					    GPG_KEY=${GPG_KEY:-''}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    COMPRESSION="${COMPRESSION:-zstd}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    COMPRESSION_LEVEL="${COMPRESSION_LEVEL:-15}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if [[ -z "${COMPRESSION_ARGS[*]}" ]]; then
 | 
				
			||||||
 | 
					        COMPRESSION_ARGS=(-Xcompression-level "${COMPRESSION_LEVEL}")
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if [[ "${COMPRESSION}" == 'xz' ]]; then
 | 
				
			||||||
 | 
					        COMPRESSION_ARGS=(-Xbcj x86)
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return 0
 | 
					    return 0
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -23,19 +23,19 @@ load_pkg_config(){
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    ARTIX_TREE=(
 | 
					    ARTIX_TREE=(
 | 
				
			||||||
        packages community
 | 
					        packages community
 | 
				
			||||||
        packages-{gfx,gtk,media,net,qt5,xorg}
 | 
					        packages-{gfx,media,net}
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    local dev_tree=(
 | 
					    local dev_tree=(
 | 
				
			||||||
        packages-{python,perl,java,ruby}
 | 
					        packages-{llvm,python,perl,java,ruby,misc}
 | 
				
			||||||
        python-{world,galaxy}
 | 
					        python-{world,galaxy,galaxy-groups,misc}
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    local init_tree=(packages-{openrc,runit,s6,66})
 | 
					    local init_tree=(packages-{openrc,runit,s6,suite66,dinit})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    local desktop_tree=(
 | 
					    local desktop_tree=(
 | 
				
			||||||
        packages-{kf5,plasma,kde,qt6}
 | 
					        packages-{kf5,plasma,kde,qt5,qt6,xorg,gtk}
 | 
				
			||||||
        packages-{lxqt,gnome,cinnamon,mate,xfce,wm}
 | 
					        packages-{lxqt,gnome,cinnamon,mate,xfce,wm,lxde}
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    [[ -z ${TREE_NAMES_ARTIX[*]} ]] && \
 | 
					    [[ -z ${TREE_NAMES_ARTIX[*]} ]] && \
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user