2020-12-17 13:59:00 +01:00
|
|
|
#!/usr/bin/env bash
|
2022-03-17 05:23:28 +01:00
|
|
|
# shellcheck source-path=/data/data/com.termux/files/home/termux-packages
|
|
|
|
set -u
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
# Following variables should be set in environment outside of this script.
|
2020-12-17 21:22:16 +01:00
|
|
|
# Build updated packages.
|
2020-12-17 21:03:35 +01:00
|
|
|
: "${BUILD_PACKAGES:=false}"
|
2020-12-17 21:22:16 +01:00
|
|
|
# Commit changes to Git.
|
|
|
|
: "${GIT_COMMIT_PACKAGES:=false}"
|
|
|
|
# Push changes to remote.
|
|
|
|
: "${GIT_PUSH_PACKAGES:=false}"
|
2020-12-17 21:03:35 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
export TERMUX_PKG_UPDATE_METHOD="" # Which method to use for updating? (repology, github or gitlab)
|
|
|
|
export TERMUX_PKG_UPDATE_TAG_TYPE="" # Whether to use latest-release-tag or newest-tag.
|
|
|
|
export TERMUX_GITLAB_API_HOST="gitlab.com" # Default host for gitlab-ci.
|
2022-03-27 20:08:57 +02:00
|
|
|
export TERMUX_PKG_AUTO_UPDATE=false # Whether to auto-update or not. Disabled by default.
|
2022-03-17 05:23:28 +01:00
|
|
|
export TERMUX_PKG_UPDATE_VERSION_REGEXP="" # Regexp to extract version.
|
|
|
|
export TERMUX_REPOLOGY_DATA_FILE
|
|
|
|
TERMUX_REPOLOGY_DATA_FILE="$(mktemp -t termux-repology.XXXXXX)" # File to store repology data.
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
export TERMUX_SCRIPTDIR
|
|
|
|
TERMUX_SCRIPTDIR="$(realpath "$(dirname "$0")/../..")" # Script directory.
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
# Define few more variables used by scripts.
|
|
|
|
# shellcheck source=scripts/properties.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}/scripts/properties.sh"
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
# Utility function to write error message to stderr.
|
|
|
|
# shellcheck source=scripts/updates/utils/termux_error_exit.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/utils/termux_error_exit.sh
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
# Utility function to write updated version to build.sh.
|
|
|
|
# shellcheck source=scripts/updates/utils/termux_pkg_upgrade_version.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/utils/termux_pkg_upgrade_version.sh
|
|
|
|
|
|
|
|
# Utility function to check if package needs to be updated, based on version comparison.
|
|
|
|
# shellcheck source=scripts/updates/utils/termux_pkg_is_update_needed.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/utils/termux_pkg_is_update_needed.sh
|
|
|
|
|
|
|
|
# Wrapper around github api to get latest release or newest tag.
|
|
|
|
# shellcheck source=scripts/updates/api/termux_github_api_get_tag.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/api/termux_github_api_get_tag.sh
|
|
|
|
|
|
|
|
# Wrapper around gitlab api to get latest release or newest tag.
|
|
|
|
# shellcheck source=scripts/updates/api/termux_gitlab_api_get_tag.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/api/termux_gitlab_api_get_tag.sh
|
|
|
|
|
|
|
|
# Function to get latest version of a package as per repology.
|
|
|
|
# shellcheck source=scripts/updates/api/termux_repology_api_get_latest_version.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/api/termux_repology_api_get_latest_version.sh
|
|
|
|
|
|
|
|
# Default auto update script for packages hosted on github.com. Should not be overrided by build.sh.
|
|
|
|
# To use custom algorithm, one should override termux_pkg_auto_update().
|
|
|
|
# shellcheck source=scripts/updates/internal/termux_github_auto_update.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/internal/termux_github_auto_update.sh
|
|
|
|
|
|
|
|
# Default auto update script for packages hosted on hosts using gitlab-ci. Should not be overrided by build.sh.
|
|
|
|
# To use custom algorithm, one should override termux_pkg_auto_update().
|
|
|
|
# shellcheck source=scripts/updates/internal/termux_gitlab_auto_update.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/internal/termux_gitlab_auto_update.sh
|
|
|
|
|
2022-03-27 20:08:57 +02:00
|
|
|
# Default auto update script for rest packages. Should not be overrided by build.sh.
|
2022-03-17 05:23:28 +01:00
|
|
|
# To use custom algorithm, one should override termux_pkg_auto_update().
|
|
|
|
# shellcheck source=scripts/updates/internal/termux_repology_auto_update.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/internal/termux_repology_auto_update.sh
|
|
|
|
|
|
|
|
# Main script to:
|
|
|
|
# - by default, decide which update method to use,
|
|
|
|
# - but can be overrided by build.sh to use custom update method.
|
|
|
|
# - For example: see neovim-nightly's build.sh.
|
|
|
|
# shellcheck source=scripts/updates/termux_pkg_auto_update.sh
|
|
|
|
. "${TERMUX_SCRIPTDIR}"/scripts/updates/termux_pkg_auto_update.sh
|
|
|
|
|
|
|
|
_update() {
|
|
|
|
export TERMUX_PKG_NAME
|
|
|
|
TERMUX_PKG_NAME="$(basename "$1")"
|
2022-04-20 20:01:54 +02:00
|
|
|
export TERMUX_PKG_BUILDER_DIR
|
|
|
|
TERMUX_PKG_BUILDER_DIR="$(realpath "$1")" # Directory containing build.sh.
|
2022-03-17 05:23:28 +01:00
|
|
|
# Avoid:
|
|
|
|
# - ending on errors such as $(which prog), where prog is not installed.
|
|
|
|
# - error on unbound variable.
|
|
|
|
#
|
|
|
|
# Variables used by auto update script should be covered by above variables and properties.sh.
|
|
|
|
set +e +u
|
|
|
|
# shellcheck source=/dev/null
|
|
|
|
. "${pkg_dir}"/build.sh 2>/dev/null
|
|
|
|
set -e -u
|
|
|
|
|
|
|
|
IFS="," read -r -a BLACKLISTED_ARCH <<<"${TERMUX_PKG_BLACKLISTED_ARCHES:-}"
|
|
|
|
export TERMUX_ARCH="" # Arch to test updates.
|
|
|
|
for arch in aarch64 arm i686 x86_64; do
|
|
|
|
# shellcheck disable=SC2076
|
|
|
|
if [[ ! " ${BLACKLISTED_ARCH[*]} " =~ " ${arch} " ]]; then
|
|
|
|
TERMUX_ARCH="${arch}"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-03-17 05:23:28 +01:00
|
|
|
# Only update if auto update is enabled.
|
|
|
|
if [[ "${TERMUX_PKG_AUTO_UPDATE}" == "true" ]]; then
|
|
|
|
echo # Newline.
|
2022-04-20 20:08:21 +02:00
|
|
|
echo "INFO: Updating ${TERMUX_PKG_NAME} [Current version: ${TERMUX_PKG_VERSION}]..."
|
|
|
|
termux_pkg_auto_update
|
2021-10-04 12:17:04 +02:00
|
|
|
fi
|
2022-03-17 05:23:28 +01:00
|
|
|
}
|
2020-12-17 13:59:00 +01:00
|
|
|
|
2022-04-20 20:08:21 +02:00
|
|
|
declare -a _FAILED_UPDATES=()
|
|
|
|
|
|
|
|
_run_update() {
|
2022-03-27 20:08:57 +02:00
|
|
|
local pkg_dir="$1"
|
2022-04-20 20:08:21 +02:00
|
|
|
# Check if this `pkg_dir` has a `build.sh` file.
|
2022-03-17 05:23:28 +01:00
|
|
|
if [[ ! -f "${pkg_dir}/build.sh" ]]; then
|
|
|
|
# Fail if detected a non-package directory.
|
|
|
|
termux_error_exit "ERROR: directory '${pkg_dir}' is not a package."
|
2021-10-04 12:17:04 +02:00
|
|
|
fi
|
2022-03-17 05:23:28 +01:00
|
|
|
# Run each package update in separate process since we include their environment variables.
|
|
|
|
(
|
|
|
|
set -euo pipefail
|
|
|
|
_update "${pkg_dir}"
|
|
|
|
)
|
|
|
|
# shellcheck disable=SC2181
|
|
|
|
if [[ $? -ne 0 ]]; then
|
2022-03-27 20:08:57 +02:00
|
|
|
_FAILED_UPDATES+=("$(basename "${pkg_dir}")")
|
2021-10-04 12:17:04 +02:00
|
|
|
fi
|
2022-03-17 05:23:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
main() {
|
|
|
|
echo "INFO: Running update for: $*"
|
|
|
|
|
|
|
|
if [[ "$1" == "@all" ]]; then
|
2022-04-20 20:08:21 +02:00
|
|
|
for repo_dir in $(jq --raw-output 'keys | .[]' "${TERMUX_SCRIPTDIR}/repo.json"); do
|
|
|
|
for pkg_dir in "${repo_dir}"/*; do
|
2022-04-18 06:48:47 +02:00
|
|
|
_run_update "${pkg_dir}"
|
|
|
|
done
|
2022-03-17 05:23:28 +01:00
|
|
|
done
|
|
|
|
else
|
|
|
|
for pkg in "$@"; do
|
2022-04-20 20:08:21 +02:00
|
|
|
if [ ! -d "${pkg}" ]; then # If only package name is given, try to find it's directory.
|
|
|
|
for repo_dir in $(jq --raw-output 'keys | .[]' "${TERMUX_SCRIPTDIR}/repo.json"); do
|
2022-04-18 06:48:47 +02:00
|
|
|
if [ -d "${repo_dir}/${pkg}" ]; then
|
|
|
|
pkg="${repo_dir}/${pkg}"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2022-04-20 20:08:21 +02:00
|
|
|
_run_update "${pkg}" # Here, `pkg` is a directory.
|
2022-03-17 05:23:28 +01:00
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2022-03-27 20:08:57 +02:00
|
|
|
if ((${#_FAILED_UPDATES[@]} > 0)); then
|
2022-03-17 05:23:28 +01:00
|
|
|
echo # Newline.
|
|
|
|
echo "===========================Failed updates==========================="
|
2022-03-27 20:08:57 +02:00
|
|
|
for failed_update in "${_FAILED_UPDATES[@]}"; do
|
2022-03-17 05:23:28 +01:00
|
|
|
echo "==> ${failed_update}"
|
|
|
|
done
|
|
|
|
exit 1 # Exit with error code, so that we know that some/all updates failed.
|
2021-10-04 12:17:04 +02:00
|
|
|
fi
|
2022-03-17 05:23:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
main "$@"
|