mirror of
https://gitlab.archlinux.org/archlinux/devtools.git
synced 2025-10-24 21:42:04 +02:00
Compare commits
2 Commits
bertptrs/z
...
github/for
Author | SHA1 | Date | |
---|---|---|---|
![]() |
669c88da7d | ||
![]() |
4b500415c2 |
10
archbuild.in
10
archbuild.in
@@ -34,16 +34,18 @@ usage() {
|
||||
echo ' -h This help'
|
||||
echo ' -c Recreate the chroot before building'
|
||||
echo ' -r <dir> Create chroots in this directory'
|
||||
echo ' -s Do not run setarch'
|
||||
echo ''
|
||||
echo "Default makechrootpkg args: ${makechrootpkg_args[*]}"
|
||||
echo ''
|
||||
exit 1
|
||||
}
|
||||
|
||||
while getopts 'hcr:' arg; do
|
||||
while getopts 'hcr:s' arg; do
|
||||
case "${arg}" in
|
||||
c) clean_first=true ;;
|
||||
r) chroots="$OPTARG" ;;
|
||||
s) nosetarch_opt="-s" ;;
|
||||
*) usage ;;
|
||||
esac
|
||||
done
|
||||
@@ -51,7 +53,7 @@ done
|
||||
check_root SOURCE_DATE_EPOCH,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER,GNUPGHOME
|
||||
|
||||
# Pass all arguments after -- right to makepkg
|
||||
makechrootpkg_args+=("${@:$OPTIND}")
|
||||
makechrootpkg_args+=("${nosetarch_opt}" "${@:$OPTIND}")
|
||||
|
||||
if ${clean_first} || [[ ! -d "${chroots}/${repo}-${arch}" ]]; then
|
||||
msg "Creating chroot for [%s] (%s)..." "${repo}" "${arch}"
|
||||
@@ -69,14 +71,14 @@ if ${clean_first} || [[ ! -d "${chroots}/${repo}-${arch}" ]]; then
|
||||
|
||||
rm -rf --one-file-system "${chroots}/${repo}-${arch}"
|
||||
(umask 0022; mkdir -p "${chroots}/${repo}-${arch}")
|
||||
setarch "${arch}" mkarchroot \
|
||||
mkarchroot ${nosetarch_opt} \
|
||||
-C "${pacman_config}" \
|
||||
-M "${makepkg_config}" \
|
||||
"${chroots}/${repo}-${arch}/root" \
|
||||
"${base_packages[@]}" || abort
|
||||
else
|
||||
lock 9 "${chroots}/${repo}-${arch}/root.lock" "Locking clean chroot"
|
||||
arch-nspawn \
|
||||
arch-nspawn ${nosetarch_opt} \
|
||||
-C "${pacman_config}" \
|
||||
-M "${makepkg_config}" \
|
||||
"${chroots}/${repo}-${arch}/root" \
|
||||
|
@@ -78,6 +78,7 @@ usage() {
|
||||
echo '-C Run checkpkg on the package'
|
||||
echo '-T Build in a temporary directory'
|
||||
echo '-U Run makepkg as a specified user'
|
||||
echo '-s Do not run setarch'
|
||||
exit 1
|
||||
}
|
||||
|
||||
@@ -144,7 +145,7 @@ install_packages() {
|
||||
pkgnames=("${install_pkgs[@]##*/}")
|
||||
|
||||
cp -- "${install_pkgs[@]}" "$copydir/root/"
|
||||
arch-nspawn "$copydir" "${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||
arch-nspawn ${nosetarch_opt} "$copydir" "${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||
bash -c 'yes y | pacman -U -- "$@"' -bash "${pkgnames[@]/#//root/}"
|
||||
ret=$?
|
||||
rm -- "${pkgnames[@]/#/$copydir/root/}"
|
||||
@@ -273,7 +274,7 @@ move_products() {
|
||||
}
|
||||
# }}}
|
||||
|
||||
while getopts 'hcur:I:l:nCTD:d:U:' arg; do
|
||||
while getopts 'hcur:I:l:nCTD:d:U:s' arg; do
|
||||
case "$arg" in
|
||||
c) clean_first=1 ;;
|
||||
D) bindmounts_ro+=("--bind-ro=$OPTARG") ;;
|
||||
@@ -286,6 +287,7 @@ while getopts 'hcur:I:l:nCTD:d:U:' arg; do
|
||||
C) run_checkpkg=1 ;;
|
||||
T) temp_chroot=1; copy+="-$$" ;;
|
||||
U) makepkg_user="$OPTARG" ;;
|
||||
s) nosetarch_opt="-s" ;;
|
||||
h|*) usage ;;
|
||||
esac
|
||||
done
|
||||
@@ -340,7 +342,7 @@ if [[ ! -d $copydir ]] || (( clean_first )); then
|
||||
sync_chroot "$chrootdir" "$copydir" "$copy"
|
||||
fi
|
||||
|
||||
(( update_first )) && arch-nspawn "$copydir" \
|
||||
(( update_first )) && arch-nspawn ${nosetarch_opt} "$copydir" \
|
||||
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||
pacman -Syuu --noconfirm
|
||||
|
||||
@@ -360,7 +362,7 @@ download_sources
|
||||
|
||||
prepare_chroot
|
||||
|
||||
if arch-nspawn "$copydir" \
|
||||
if arch-nspawn ${nosetarch_opt} "$copydir" \
|
||||
--bind="${PWD//:/\\:}:/startdir" \
|
||||
--bind="${SRCDEST//:/\\:}:/srcdest" \
|
||||
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||
@@ -397,7 +399,7 @@ else
|
||||
for remotepkg in "${remotepkgs[@]}"; do
|
||||
if [[ $remotepkg != file://* ]]; then
|
||||
msg2 "Downloading current versions"
|
||||
arch-nspawn "$copydir" pacman --noconfirm -Swdd "${pkgnames[@]}"
|
||||
arch-nspawn ${nosetarch_opt} "$copydir" pacman --noconfirm -Swdd "${pkgnames[@]}"
|
||||
mapfile -t remotepkgs < <(pacman --config "$copydir"/etc/pacman.conf \
|
||||
--dbpath "$copydir"/var/lib/pacman \
|
||||
-Sddp "${pkgnames[@]}")
|
||||
|
Reference in New Issue
Block a user