mirror of
https://gitlab.archlinux.org/archlinux/devtools.git
synced 2025-09-13 18:06:19 +02:00
Compare commits
2 Commits
20210202
...
github/for
Author | SHA1 | Date | |
---|---|---|---|
![]() |
669c88da7d | ||
![]() |
4b500415c2 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -19,4 +19,3 @@ crossrepomove
|
|||||||
arch-nspawn
|
arch-nspawn
|
||||||
sogrep
|
sogrep
|
||||||
doc/*.1
|
doc/*.1
|
||||||
doc/*.7
|
|
||||||
|
5
Makefile
5
Makefile
@@ -1,4 +1,4 @@
|
|||||||
V=20210202
|
V=20200213
|
||||||
|
|
||||||
PREFIX = /usr/local
|
PREFIX = /usr/local
|
||||||
MANDIR = $(PREFIX)/share/man
|
MANDIR = $(PREFIX)/share/man
|
||||||
@@ -75,8 +75,7 @@ MANS = \
|
|||||||
doc/makerepropkg.1 \
|
doc/makerepropkg.1 \
|
||||||
doc/mkarchroot.1 \
|
doc/mkarchroot.1 \
|
||||||
doc/find-libdeps.1 \
|
doc/find-libdeps.1 \
|
||||||
doc/find-libprovides.1 \
|
doc/find-libprovides.1
|
||||||
doc/devtools.7
|
|
||||||
|
|
||||||
|
|
||||||
all: $(BINPROGS) bash_completion zsh_completion man
|
all: $(BINPROGS) bash_completion zsh_completion man
|
||||||
|
10
archbuild.in
10
archbuild.in
@@ -34,16 +34,18 @@ usage() {
|
|||||||
echo ' -h This help'
|
echo ' -h This help'
|
||||||
echo ' -c Recreate the chroot before building'
|
echo ' -c Recreate the chroot before building'
|
||||||
echo ' -r <dir> Create chroots in this directory'
|
echo ' -r <dir> Create chroots in this directory'
|
||||||
|
echo ' -s Do not run setarch'
|
||||||
echo ''
|
echo ''
|
||||||
echo "Default makechrootpkg args: ${makechrootpkg_args[*]}"
|
echo "Default makechrootpkg args: ${makechrootpkg_args[*]}"
|
||||||
echo ''
|
echo ''
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
while getopts 'hcr:' arg; do
|
while getopts 'hcr:s' arg; do
|
||||||
case "${arg}" in
|
case "${arg}" in
|
||||||
c) clean_first=true ;;
|
c) clean_first=true ;;
|
||||||
r) chroots="$OPTARG" ;;
|
r) chroots="$OPTARG" ;;
|
||||||
|
s) nosetarch_opt="-s" ;;
|
||||||
*) usage ;;
|
*) usage ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@@ -51,7 +53,7 @@ done
|
|||||||
check_root SOURCE_DATE_EPOCH,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER,GNUPGHOME
|
check_root SOURCE_DATE_EPOCH,SRCDEST,SRCPKGDEST,PKGDEST,LOGDEST,MAKEFLAGS,PACKAGER,GNUPGHOME
|
||||||
|
|
||||||
# Pass all arguments after -- right to makepkg
|
# Pass all arguments after -- right to makepkg
|
||||||
makechrootpkg_args+=("${@:$OPTIND}")
|
makechrootpkg_args+=("${nosetarch_opt}" "${@:$OPTIND}")
|
||||||
|
|
||||||
if ${clean_first} || [[ ! -d "${chroots}/${repo}-${arch}" ]]; then
|
if ${clean_first} || [[ ! -d "${chroots}/${repo}-${arch}" ]]; then
|
||||||
msg "Creating chroot for [%s] (%s)..." "${repo}" "${arch}"
|
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}"
|
rm -rf --one-file-system "${chroots}/${repo}-${arch}"
|
||||||
(umask 0022; mkdir -p "${chroots}/${repo}-${arch}")
|
(umask 0022; mkdir -p "${chroots}/${repo}-${arch}")
|
||||||
setarch "${arch}" mkarchroot \
|
mkarchroot ${nosetarch_opt} \
|
||||||
-C "${pacman_config}" \
|
-C "${pacman_config}" \
|
||||||
-M "${makepkg_config}" \
|
-M "${makepkg_config}" \
|
||||||
"${chroots}/${repo}-${arch}/root" \
|
"${chroots}/${repo}-${arch}/root" \
|
||||||
"${base_packages[@]}" || abort
|
"${base_packages[@]}" || abort
|
||||||
else
|
else
|
||||||
lock 9 "${chroots}/${repo}-${arch}/root.lock" "Locking clean chroot"
|
lock 9 "${chroots}/${repo}-${arch}/root.lock" "Locking clean chroot"
|
||||||
arch-nspawn \
|
arch-nspawn ${nosetarch_opt} \
|
||||||
-C "${pacman_config}" \
|
-C "${pacman_config}" \
|
||||||
-M "${makepkg_config}" \
|
-M "${makepkg_config}" \
|
||||||
"${chroots}/${repo}-${arch}/root" \
|
"${chroots}/${repo}-${arch}/root" \
|
||||||
|
@@ -1,46 +0,0 @@
|
|||||||
devtools(7)
|
|
||||||
===========
|
|
||||||
|
|
||||||
Name
|
|
||||||
----
|
|
||||||
devtools - Developer tools for the Arch Linux distribution
|
|
||||||
|
|
||||||
Description
|
|
||||||
-----------
|
|
||||||
|
|
||||||
Devtools contains tools for package maintenance in Arch Linux. The toolset
|
|
||||||
varies from tools for building packages in a clean chroot ('mkarchroot',...),
|
|
||||||
packaging related tools for sonames ('sogrep', 'lddd') and tools for
|
|
||||||
repository management such as ('archco', 'extra2community')
|
|
||||||
|
|
||||||
Programs
|
|
||||||
--------
|
|
||||||
The list below gives a short overview; see the respective documentation
|
|
||||||
for details.
|
|
||||||
|
|
||||||
linkman:checkpkg[1]
|
|
||||||
Compare the current build pakcage with the repository version
|
|
||||||
|
|
||||||
linkman:find-libdeps[1]
|
|
||||||
Find soname dependencies for a package
|
|
||||||
|
|
||||||
linkman:find-libprovides[1]
|
|
||||||
Find soname's which are provided by a package
|
|
||||||
|
|
||||||
linkman:lddd[1]
|
|
||||||
Find broken library links on your system
|
|
||||||
|
|
||||||
linkman:makerepropkg[1]
|
|
||||||
Rebuild a package to see if it is reproducible
|
|
||||||
|
|
||||||
linkman:mkarchroot[1]
|
|
||||||
Creates an arch chroot in a specified location with a specified set of
|
|
||||||
packages
|
|
||||||
|
|
||||||
linkman:offload-build[1]
|
|
||||||
Build a PKGBUILD on a remote server using makechrootpkg
|
|
||||||
|
|
||||||
linkman:sogrep[1]
|
|
||||||
Find packages using a linked to a given shared library
|
|
||||||
|
|
||||||
include::footer.asciidoc[]
|
|
@@ -7,7 +7,7 @@ makerepropkg - Rebuild a package to see if it is reproducible
|
|||||||
|
|
||||||
Synopsis
|
Synopsis
|
||||||
--------
|
--------
|
||||||
makerepropkg [OPTIONS] [<package_file|pkgname>...]
|
makerepropkg [OPTIONS] <package_file>...
|
||||||
|
|
||||||
Description
|
Description
|
||||||
-----------
|
-----------
|
||||||
@@ -24,15 +24,6 @@ When given multiple packages, additional package files are assumed to be split
|
|||||||
packages and will be treated as additional artifacts to compare during the
|
packages and will be treated as additional artifacts to compare during the
|
||||||
verification step.
|
verification step.
|
||||||
|
|
||||||
A valid target(s) for pacman -S can be specified instead, and makerepropkg will
|
|
||||||
download it to the cache if needed. This is mostly useful to specify which
|
|
||||||
repository to retrieve from. If no positional arguments are specified, the
|
|
||||||
targets will be sourced from the PKGBUILD.
|
|
||||||
|
|
||||||
In either case, the package name will be converted to a filename from the
|
|
||||||
cache, and makerepropkg will proceed as though this filename was initially
|
|
||||||
specified.
|
|
||||||
|
|
||||||
This implements a verifier for pacman/libalpm packages in accordance with the
|
This implements a verifier for pacman/libalpm packages in accordance with the
|
||||||
link:https://reproducible-builds.org/[Reproducible Builds] project.
|
link:https://reproducible-builds.org/[Reproducible Builds] project.
|
||||||
|
|
||||||
|
@@ -28,7 +28,7 @@ Options
|
|||||||
architecture officially supported by Arch Linux.
|
architecture officially supported by Arch Linux.
|
||||||
|
|
||||||
*-s, --server* <hostname>::
|
*-s, --server* <hostname>::
|
||||||
Offload to a specific build server. The default is build.archlinux.org
|
Offload to a specific build server. The default is dragon.archlinux.org
|
||||||
which is used as part of the build toolchain for the official Arch Linux
|
which is used as part of the build toolchain for the official Arch Linux
|
||||||
repos.
|
repos.
|
||||||
|
|
||||||
|
@@ -78,6 +78,7 @@ usage() {
|
|||||||
echo '-C Run checkpkg on the package'
|
echo '-C Run checkpkg on the package'
|
||||||
echo '-T Build in a temporary directory'
|
echo '-T Build in a temporary directory'
|
||||||
echo '-U Run makepkg as a specified user'
|
echo '-U Run makepkg as a specified user'
|
||||||
|
echo '-s Do not run setarch'
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -144,7 +145,7 @@ install_packages() {
|
|||||||
pkgnames=("${install_pkgs[@]##*/}")
|
pkgnames=("${install_pkgs[@]##*/}")
|
||||||
|
|
||||||
cp -- "${install_pkgs[@]}" "$copydir/root/"
|
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/}"
|
bash -c 'yes y | pacman -U -- "$@"' -bash "${pkgnames[@]/#//root/}"
|
||||||
ret=$?
|
ret=$?
|
||||||
rm -- "${pkgnames[@]/#/$copydir/root/}"
|
rm -- "${pkgnames[@]/#/$copydir/root/}"
|
||||||
@@ -242,15 +243,6 @@ download_sources() {
|
|||||||
die "Could not download sources."
|
die "Could not download sources."
|
||||||
}
|
}
|
||||||
|
|
||||||
move_logfiles() {
|
|
||||||
local l
|
|
||||||
for l in "$copydir"/logdest/*; do
|
|
||||||
[[ $l == */logpipe.* ]] && continue
|
|
||||||
chown "$src_owner" "$l"
|
|
||||||
mv "$l" "$LOGDEST"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
move_products() {
|
move_products() {
|
||||||
local pkgfile
|
local pkgfile
|
||||||
for pkgfile in "$copydir"/pkgdest/*; do
|
for pkgfile in "$copydir"/pkgdest/*; do
|
||||||
@@ -263,7 +255,12 @@ move_products() {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
move_logfiles
|
local l
|
||||||
|
for l in "$copydir"/logdest/*; do
|
||||||
|
[[ $l == */logpipe.* ]] && continue
|
||||||
|
chown "$src_owner" "$l"
|
||||||
|
mv "$l" "$LOGDEST"
|
||||||
|
done
|
||||||
|
|
||||||
for s in "$copydir"/srcpkgdest/*; do
|
for s in "$copydir"/srcpkgdest/*; do
|
||||||
chown "$src_owner" "$s"
|
chown "$src_owner" "$s"
|
||||||
@@ -277,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
|
case "$arg" in
|
||||||
c) clean_first=1 ;;
|
c) clean_first=1 ;;
|
||||||
D) bindmounts_ro+=("--bind-ro=$OPTARG") ;;
|
D) bindmounts_ro+=("--bind-ro=$OPTARG") ;;
|
||||||
@@ -290,6 +287,7 @@ while getopts 'hcur:I:l:nCTD:d:U:' arg; do
|
|||||||
C) run_checkpkg=1 ;;
|
C) run_checkpkg=1 ;;
|
||||||
T) temp_chroot=1; copy+="-$$" ;;
|
T) temp_chroot=1; copy+="-$$" ;;
|
||||||
U) makepkg_user="$OPTARG" ;;
|
U) makepkg_user="$OPTARG" ;;
|
||||||
|
s) nosetarch_opt="-s" ;;
|
||||||
h|*) usage ;;
|
h|*) usage ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@@ -344,7 +342,7 @@ if [[ ! -d $copydir ]] || (( clean_first )); then
|
|||||||
sync_chroot "$chrootdir" "$copydir" "$copy"
|
sync_chroot "$chrootdir" "$copydir" "$copy"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
(( update_first )) && arch-nspawn "$copydir" \
|
(( update_first )) && arch-nspawn ${nosetarch_opt} "$copydir" \
|
||||||
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||||
pacman -Syuu --noconfirm
|
pacman -Syuu --noconfirm
|
||||||
|
|
||||||
@@ -364,7 +362,7 @@ download_sources
|
|||||||
|
|
||||||
prepare_chroot
|
prepare_chroot
|
||||||
|
|
||||||
if arch-nspawn "$copydir" \
|
if arch-nspawn ${nosetarch_opt} "$copydir" \
|
||||||
--bind="${PWD//:/\\:}:/startdir" \
|
--bind="${PWD//:/\\:}:/startdir" \
|
||||||
--bind="${SRCDEST//:/\\:}:/srcdest" \
|
--bind="${SRCDEST//:/\\:}:/srcdest" \
|
||||||
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
|
||||||
@@ -374,7 +372,6 @@ then
|
|||||||
move_products
|
move_products
|
||||||
else
|
else
|
||||||
(( ret += 1 ))
|
(( ret += 1 ))
|
||||||
move_logfiles
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
(( temp_chroot )) && delete_chroot "$copydir" "$copy"
|
(( temp_chroot )) && delete_chroot "$copydir" "$copy"
|
||||||
@@ -402,7 +399,7 @@ else
|
|||||||
for remotepkg in "${remotepkgs[@]}"; do
|
for remotepkg in "${remotepkgs[@]}"; do
|
||||||
if [[ $remotepkg != file://* ]]; then
|
if [[ $remotepkg != file://* ]]; then
|
||||||
msg2 "Downloading current versions"
|
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 \
|
mapfile -t remotepkgs < <(pacman --config "$copydir"/etc/pacman.conf \
|
||||||
--dbpath "$copydir"/var/lib/pacman \
|
--dbpath "$copydir"/var/lib/pacman \
|
||||||
-Sddp "${pkgnames[@]}")
|
-Sddp "${pkgnames[@]}")
|
||||||
|
@@ -15,7 +15,7 @@ DLAGENTS=('file::/usr/bin/curl -gqC - -o %o %u'
|
|||||||
'ftp::/usr/bin/curl -gqfC - --ftp-pasv --retry 3 --retry-delay 3 -o %o %u'
|
'ftp::/usr/bin/curl -gqfC - --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 -gqb "" -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 -gqb "" -fLC - --retry 3 --retry-delay 3 -o %o %u'
|
||||||
'rsync::/usr/bin/rsync --no-motd -zz %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')
|
||||||
|
|
||||||
# Other common tools:
|
# Other common tools:
|
||||||
|
@@ -57,15 +57,9 @@ parse_buildinfo() {
|
|||||||
get_pkgfile() {
|
get_pkgfile() {
|
||||||
local cdir=${cache_dirs[0]}
|
local cdir=${cache_dirs[0]}
|
||||||
local pkgfilebase=${1}
|
local pkgfilebase=${1}
|
||||||
local mode=${2}
|
|
||||||
local pkgname=${pkgfilebase%-*-*-*}
|
local pkgname=${pkgfilebase%-*-*-*}
|
||||||
local pkgfile ext
|
local pkgfile ext
|
||||||
|
|
||||||
# try without downloading
|
|
||||||
if [[ ${mode} != localonly ]] && get_pkgfile "${pkgfilebase}" localonly; then
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
for ext in .zst .xz ''; do
|
for ext in .zst .xz ''; do
|
||||||
pkgfile=${pkgfilebase}.pkg.tar${ext}
|
pkgfile=${pkgfilebase}.pkg.tar${ext}
|
||||||
|
|
||||||
@@ -78,9 +72,6 @@ get_pkgfile() {
|
|||||||
|
|
||||||
for f in "${pkgfile}" "${pkgfile}.sig"; do
|
for f in "${pkgfile}" "${pkgfile}.sig"; do
|
||||||
if [[ ! -f "${cdir}/${f}" ]]; then
|
if [[ ! -f "${cdir}/${f}" ]]; then
|
||||||
if [[ ${mode} = localonly ]]; then
|
|
||||||
continue 2
|
|
||||||
fi
|
|
||||||
msg2 "retrieving '%s'..." "${f}" >&2
|
msg2 "retrieving '%s'..." "${f}" >&2
|
||||||
curl -Llf -# -o "${cdir}/${f}" "${archiveurl}/${pkgname:0:1}/${pkgname}/${f}" || continue 2
|
curl -Llf -# -o "${cdir}/${f}" "${archiveurl}/${pkgname:0:1}/${pkgname}/${f}" || continue 2
|
||||||
fi
|
fi
|
||||||
@@ -124,45 +115,19 @@ shift $((OPTIND - 1))
|
|||||||
|
|
||||||
check_root
|
check_root
|
||||||
|
|
||||||
[[ -f PKGBUILD ]] || { error "No PKGBUILD in current directory."; exit 1; }
|
if [[ -n $1 ]]; then
|
||||||
|
pkgfile="$1"
|
||||||
# without arguments, get list of packages from PKGBUILD
|
splitpkgs=("$@")
|
||||||
if [[ -z $1 ]]; then
|
for f in "${splitpkgs[@]}"; do
|
||||||
mapfile -t pkgnames < <(source PKGBUILD; pacman -Sddp --print-format '%r/%n' "${pkgname[@]}")
|
if ! bsdtar -tqf "${f}" .BUILDINFO >/dev/null 2>&1; then
|
||||||
wait $! || {
|
error "file is not a valid pacman package: '%s'" "${f}"
|
||||||
error "No package file specified and failed to retrieve package names from './PKGBUILD'."
|
exit 1
|
||||||
plain "Try '${BASH_SOURCE[0]##*/} -h' for more information." >&2
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
msg "Reproducing all pkgnames listed in ./PKGBUILD"
|
|
||||||
set -- "${pkgnames[@]}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check each package to see if it's a file, and if not, try to download it
|
|
||||||
# using pacman -Sw, and get the filename from there
|
|
||||||
splitpkgs=()
|
|
||||||
for p in "$@"; do
|
|
||||||
if [[ -f ${p} ]]; then
|
|
||||||
splitpkgs+=("${p}")
|
|
||||||
else
|
|
||||||
pkgfile_remote=$(pacman -Sddp "${p}" 2>/dev/null) || { error "package name '%s' not in repos" "${p}"; exit 1; }
|
|
||||||
pkgfile=${pkgfile_remote#file://}
|
|
||||||
if [[ ! -f ${pkgfile} ]]; then
|
|
||||||
msg "Downloading package '%s' into pacman's cache" "${pkgfile}"
|
|
||||||
sudo pacman -Swdd --noconfirm --logfile /dev/null "${p}" || exit 1
|
|
||||||
pkgfile_remote=$(pacman -Sddp "${p}" 2>/dev/null)
|
|
||||||
pkgfile="${pkgfile_remote#file://}"
|
|
||||||
fi
|
fi
|
||||||
splitpkgs+=("${pkgfile}")
|
done
|
||||||
fi
|
else
|
||||||
done
|
error "no package file specified. Try '${BASH_SOURCE[0]##*/} -h' for more information. "
|
||||||
|
exit 1
|
||||||
for f in "${splitpkgs[@]}"; do
|
fi
|
||||||
if ! bsdtar -tqf "${f}" .BUILDINFO >/dev/null 2>&1; then
|
|
||||||
error "file is not a valid pacman package: '%s'" "${f}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
if (( ${#cache_dirs[@]} == 0 )); then
|
if (( ${#cache_dirs[@]} == 0 )); then
|
||||||
mapfile -t cache_dirs < <(pacman-conf CacheDir)
|
mapfile -t cache_dirs < <(pacman-conf CacheDir)
|
||||||
@@ -174,11 +139,11 @@ load_makepkg_config
|
|||||||
HOME=${ORIG_HOME}
|
HOME=${ORIG_HOME}
|
||||||
[[ -d ${SRCDEST} ]] || SRCDEST=${PWD}
|
[[ -d ${SRCDEST} ]] || SRCDEST=${PWD}
|
||||||
|
|
||||||
parse_buildinfo < <(bsdtar -xOqf "${splitpkgs[0]}" .BUILDINFO)
|
parse_buildinfo < <(bsdtar -xOqf "${pkgfile}" .BUILDINFO)
|
||||||
export SOURCE_DATE_EPOCH="${buildinfo[builddate]}"
|
export SOURCE_DATE_EPOCH="${buildinfo[builddate]}"
|
||||||
PACKAGER="${buildinfo[packager]}"
|
PACKAGER="${buildinfo[packager]}"
|
||||||
BUILDDIR="${buildinfo[builddir]}"
|
BUILDDIR="${buildinfo[builddir]}"
|
||||||
PKGEXT=${splitpkgs[0]#${splitpkgs[0]%.pkg.tar*}}
|
PKGEXT=${pkgfile#${pkgfile%.pkg.tar*}}
|
||||||
|
|
||||||
# nuke and restore reproducible testenv
|
# nuke and restore reproducible testenv
|
||||||
for copy in "${buildroot}"/*/; do
|
for copy in "${buildroot}"/*/; do
|
||||||
|
@@ -24,7 +24,7 @@ source /usr/share/makepkg/util/config.sh
|
|||||||
# global defaults suitable for use by Arch staff
|
# global defaults suitable for use by Arch staff
|
||||||
repo=extra
|
repo=extra
|
||||||
arch=x86_64
|
arch=x86_64
|
||||||
server=build.archlinux.org
|
server=dragon.archlinux.org
|
||||||
|
|
||||||
die() { printf "error: $1\n" "${@:2}"; exit 1; }
|
die() { printf "error: $1\n" "${@:2}"; exit 1; }
|
||||||
|
|
||||||
@@ -83,9 +83,6 @@ archbuild_cmd=("${repo}${archbuild_arch:+-$archbuild_arch}-build" "$@")
|
|||||||
|
|
||||||
trap 'rm -rf $TEMPDIR' EXIT INT TERM QUIT
|
trap 'rm -rf $TEMPDIR' EXIT INT TERM QUIT
|
||||||
|
|
||||||
# Load makepkg.conf variables to be available
|
|
||||||
load_makepkg_config
|
|
||||||
|
|
||||||
# Use a source-only tarball as an intermediate to transfer files. This
|
# Use a source-only tarball as an intermediate to transfer files. This
|
||||||
# guarantees the checksums are okay, and guarantees that all needed files are
|
# guarantees the checksums are okay, and guarantees that all needed files are
|
||||||
# transferred, including local sources, install scripts, and changelogs.
|
# transferred, including local sources, install scripts, and changelogs.
|
||||||
@@ -101,7 +98,7 @@ mapfile -t files < <(
|
|||||||
# This is sort of bash golfing but it allows running a mildly complex
|
# This is sort of bash golfing but it allows running a mildly complex
|
||||||
# command over ssh with a single connection.
|
# command over ssh with a single connection.
|
||||||
# shellcheck disable=SC2145
|
# shellcheck disable=SC2145
|
||||||
cat "$SRCPKGDEST"/*"$SRCEXT" |
|
cat "$SRCPKGDEST"/*.src.tar.gz |
|
||||||
ssh $server '
|
ssh $server '
|
||||||
temp="${XDG_CACHE_HOME:-$HOME/.cache}/offload-build" &&
|
temp="${XDG_CACHE_HOME:-$HOME/.cache}/offload-build" &&
|
||||||
mkdir -p "$temp" &&
|
mkdir -p "$temp" &&
|
||||||
@@ -125,6 +122,7 @@ mapfile -t files < <(
|
|||||||
|
|
||||||
if (( ${#files[@]} )); then
|
if (( ${#files[@]} )); then
|
||||||
printf '%s\n' '' '-> copying files...'
|
printf '%s\n' '' '-> copying files...'
|
||||||
|
load_makepkg_config
|
||||||
scp "${files[@]/#/$server:}" "${TEMPDIR}/"
|
scp "${files[@]/#/$server:}" "${TEMPDIR}/"
|
||||||
mv "${TEMPDIR}"/*.pkg.tar* "${PKGDEST:-${PWD}}/"
|
mv "${TEMPDIR}"/*.pkg.tar* "${PKGDEST:-${PWD}}/"
|
||||||
mv "${TEMPDIR}/PKGBUILD" "${PWD}/"
|
mv "${TEMPDIR}/PKGBUILD" "${PWD}/"
|
||||||
|
Reference in New Issue
Block a user