|
|
@@ -94,12 +94,12 @@ makepkg_source_package || die "unable to make source package"
|
|
|
|
rmdir --ignore-fail-on-non-empty src 2>/dev/null || true
|
|
|
|
rmdir --ignore-fail-on-non-empty src 2>/dev/null || true
|
|
|
|
|
|
|
|
|
|
|
|
# Create a temporary directory on the server
|
|
|
|
# Create a temporary directory on the server
|
|
|
|
remote_temp=$(
|
|
|
|
cmd='
|
|
|
|
ssh "${SSH_OPTS[@]}" -- "$server" '
|
|
|
|
|
|
|
|
temp="${XDG_CACHE_HOME:-$HOME/.cache}/offload-build" &&
|
|
|
|
temp="${XDG_CACHE_HOME:-$HOME/.cache}/offload-build" &&
|
|
|
|
mkdir -p "$temp" &&
|
|
|
|
mkdir -p "$temp" &&
|
|
|
|
mktemp --directory --tmpdir="$temp"
|
|
|
|
mktemp --directory --tmpdir="$temp"
|
|
|
|
')
|
|
|
|
'
|
|
|
|
|
|
|
|
remote_temp=$(ssh "${SSH_OPTS[@]}" -- "$server" "bash -l -c '$cmd'")
|
|
|
|
|
|
|
|
|
|
|
|
# Transfer the srcpkg to the server
|
|
|
|
# Transfer the srcpkg to the server
|
|
|
|
msg "Transferring source package to the server..."
|
|
|
|
msg "Transferring source package to the server..."
|
|
|
@@ -109,18 +109,17 @@ rsync "${RSYNC_OPTS[@]}" -- "$srcpkg" "$server":"$remote_temp" || die
|
|
|
|
|
|
|
|
|
|
|
|
# Prepare the srcpkg on the server
|
|
|
|
# Prepare the srcpkg on the server
|
|
|
|
msg "Extracting srcpkg"
|
|
|
|
msg "Extracting srcpkg"
|
|
|
|
ssh "${SSH_OPTS[@]}" -- "$server" "cd ${remote_temp@Q} && bsdtar --strip-components 1 -xvf $(basename "$srcpkg")" || die
|
|
|
|
ssh "${SSH_OPTS[@]}" -- "$server" "bash -c -l 'cd ${remote_temp@Q} && bsdtar --strip-components 1 -xvf $(basename "$srcpkg")'" || die
|
|
|
|
|
|
|
|
|
|
|
|
# Run the build command on the server
|
|
|
|
# Run the build command on the server
|
|
|
|
msg "Running archbuild"
|
|
|
|
msg "Running archbuild"
|
|
|
|
# shellcheck disable=SC2145
|
|
|
|
# shellcheck disable=SC2145
|
|
|
|
if ssh "${SSH_OPTS[@]}" -t -- "$server" "cd ${remote_temp@Q} && export LOGDEST="" && ${archbuild_cmd[@]@Q}"; then
|
|
|
|
if ssh "${SSH_OPTS[@]}" -t -- "$server" "bash -c -l 'cd ${remote_temp@Q} && export LOGDEST="" && ${archbuild_cmd[@]@Q}'"; then
|
|
|
|
msg "Build complete"
|
|
|
|
msg "Build complete"
|
|
|
|
|
|
|
|
|
|
|
|
# Get an array of files that should be downloaded from the server
|
|
|
|
# Get an array of files that should be downloaded from the server
|
|
|
|
mapfile -t files < <(
|
|
|
|
cmd='
|
|
|
|
ssh "${SSH_OPTS[@]}" -- "$server" "
|
|
|
|
cd '"${remote_temp@Q}"' &&
|
|
|
|
cd ${remote_temp@Q}"' &&
|
|
|
|
|
|
|
|
makepkg_user_config="${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf" &&
|
|
|
|
makepkg_user_config="${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf" &&
|
|
|
|
makepkg_config="/usr/share/devtools/makepkg.conf.d/'"${arch}"'.conf" &&
|
|
|
|
makepkg_config="/usr/share/devtools/makepkg.conf.d/'"${arch}"'.conf" &&
|
|
|
|
if [[ -f /usr/share/devtools/makepkg.conf.d/'"${repo}"'-'"${arch}"'.conf ]]; then
|
|
|
|
if [[ -f /usr/share/devtools/makepkg.conf.d/'"${repo}"'-'"${arch}"'.conf ]]; then
|
|
|
@@ -132,13 +131,12 @@ if ssh "${SSH_OPTS[@]}" -t -- "$server" "cd ${remote_temp@Q} && export LOGDEST="
|
|
|
|
printf "%s\n" '"${remote_temp@Q}/PKGBUILD"'
|
|
|
|
printf "%s\n" '"${remote_temp@Q}/PKGBUILD"'
|
|
|
|
|
|
|
|
|
|
|
|
find '"${remote_temp@Q}"' -name "*.log"
|
|
|
|
find '"${remote_temp@Q}"' -name "*.log"
|
|
|
|
')
|
|
|
|
'
|
|
|
|
|
|
|
|
mapfile -t files < <(ssh "${SSH_OPTS[@]}" -- "$server" "bash -c -l '$cmd'")
|
|
|
|
else
|
|
|
|
else
|
|
|
|
# Build failed, only the logs should be downloaded from the server
|
|
|
|
# Build failed, only the logs should be downloaded from the server
|
|
|
|
mapfile -t files < <(
|
|
|
|
cmd='find '"${remote_temp@Q}"' -name "*.log"'
|
|
|
|
ssh "${SSH_OPTS[@]}" -- "$server" '
|
|
|
|
mapfile -t files < <(ssh "${SSH_OPTS[@]}" -- "$server" "bash -c -l '$cmd'")
|
|
|
|
find '"${remote_temp@Q}"' -name "*.log"
|
|
|
|
|
|
|
|
')
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|