mirror of
https://gitlab.archlinux.org/archlinux/devtools.git
synced 2025-09-13 09:56:18 +02:00
Compare commits
2 Commits
feat/ports
...
fe42a31a70
Author | SHA1 | Date | |
---|---|---|---|
![]() |
fe42a31a70 | ||
![]() |
6a1a0f6b50 |
@@ -150,7 +150,6 @@ _pkgctl_cmds=(
|
||||
db
|
||||
diff
|
||||
issue
|
||||
license
|
||||
release
|
||||
repo
|
||||
search
|
||||
@@ -197,6 +196,7 @@ _pkgctl_build_args=(
|
||||
--pkgrel
|
||||
--rebuild
|
||||
--update-checksums
|
||||
--version-upgrade
|
||||
-e --edit
|
||||
|
||||
-r --release
|
||||
|
@@ -59,6 +59,7 @@ _pkgctl_build_args=(
|
||||
'--pkgrel=[Set pkgrel to a given value]:pkgrel:'
|
||||
'--rebuild[Increment the pkgrel variable]'
|
||||
'--update-checksums[Force computation and update of the checksums (disables auto-detection)]'
|
||||
'--version-upgrade[Adjust the PKGBUILD to match the latest upstream version (via pkgctl version upgrade)]'
|
||||
'(-e --edit)'{-e,--edit}'[Edit the PKGBUILD before building]'
|
||||
'(-r --release)'{-r,--release}'[Automatically commit, tag and release after building]'
|
||||
'(-m --message)'{-m,--message}"[Use the given <msg> as the commit message]:message:"
|
||||
|
@@ -84,6 +84,9 @@ PKGBUILD Options
|
||||
are either automatically updated when upgrading a package using `--pkgver`
|
||||
or should remain immutable during rebuilds.
|
||||
|
||||
*--version-upgrade*::
|
||||
Adjust the PKGBUILD to match the latest upstream version (via `pkgctl version upgrade`).
|
||||
|
||||
*-e, --edit*::
|
||||
Edit the PKGBUILD before building
|
||||
|
||||
|
@@ -67,6 +67,7 @@ pkgctl_build_usage() {
|
||||
--pkgrel=PKGREL Set pkgrel to a given value
|
||||
--rebuild Increment the current pkgrel variable
|
||||
--update-checksums Force computation and update of the checksums (disables auto-detection)
|
||||
--version-upgrade Adjust the PKGBUILD to match the latest upstream version (via pkgctl version upgrade)
|
||||
-e, --edit Edit the PKGBUILD before building
|
||||
|
||||
RELEASE OPTIONS
|
||||
@@ -116,6 +117,7 @@ pkgctl_build() {
|
||||
fi
|
||||
|
||||
local UPDATE_CHECKSUMS=0
|
||||
local VERSION_UPGRADE=0
|
||||
local EDIT=0
|
||||
local REBUILD=0
|
||||
local OFFLOAD=0
|
||||
@@ -187,6 +189,10 @@ pkgctl_build() {
|
||||
UPDATE_CHECKSUMS=1
|
||||
shift
|
||||
;;
|
||||
--version-upgrade)
|
||||
VERSION_UPGRADE=1
|
||||
shift
|
||||
;;
|
||||
--rebuild)
|
||||
# shellcheck source=src/lib/util/git.sh
|
||||
source "${_DEVTOOLS_LIBRARY_DIR}"/lib/util/git.sh
|
||||
@@ -312,7 +318,7 @@ pkgctl_build() {
|
||||
|
||||
# Update pacman cache for auto-detection
|
||||
if [[ -z ${REPO} ]]; then
|
||||
update_pacman_repo_cache stable
|
||||
update_pacman_repo_cache multilib
|
||||
# Check valid repos if not resolved dynamically
|
||||
elif ! in_array "${REPO}" "${DEVTOOLS_VALID_REPOS[@]}"; then
|
||||
die "Invalid repository target: %s" "${REPO}"
|
||||
@@ -452,6 +458,13 @@ pkgctl_build() {
|
||||
. ./PKGBUILD
|
||||
fi
|
||||
|
||||
# update PKGBUILD to the latest upstream version
|
||||
if (( VERSION_UPGRADE )); then
|
||||
if ! $(pkgctl_version_upgrade); then
|
||||
die
|
||||
fi
|
||||
fi
|
||||
|
||||
# execute build
|
||||
for arch in "${BUILD_ARCH[@]}"; do
|
||||
if [[ -n $arch ]]; then
|
||||
|
@@ -51,6 +51,7 @@ pkgctl_db_remove() {
|
||||
local partial=0
|
||||
local confirm=1
|
||||
local dbscripts_options=()
|
||||
local lookup_repo=multilib
|
||||
local pkgname
|
||||
|
||||
# option checking
|
||||
@@ -105,13 +106,13 @@ pkgctl_db_remove() {
|
||||
update_pacman_repo_cache unstable
|
||||
;;
|
||||
*-staging)
|
||||
update_pacman_repo_cache staging
|
||||
update_pacman_repo_cache multilib-staging
|
||||
;;
|
||||
*-testing)
|
||||
update_pacman_repo_cache testing
|
||||
update_pacman_repo_cache multilib-testing
|
||||
;;
|
||||
*)
|
||||
update_pacman_repo_cache stable
|
||||
update_pacman_repo_cache multilib
|
||||
;;
|
||||
esac
|
||||
|
||||
|
@@ -188,7 +188,6 @@ path = [
|
||||
"README.md",
|
||||
"keys/**",
|
||||
".SRCINFO",
|
||||
".gitignore",
|
||||
".nvchecker.toml",
|
||||
"*.install",
|
||||
"*.sysusers",
|
||||
|
@@ -124,7 +124,7 @@ pkgctl_release() {
|
||||
|
||||
# Update pacman cache for auto-detection
|
||||
if [[ -z ${REPO} ]]; then
|
||||
update_pacman_repo_cache stable
|
||||
update_pacman_repo_cache multilib
|
||||
# Check valid repos if not resolved dynamically
|
||||
elif ! in_array "${REPO}" "${DEVTOOLS_VALID_REPOS[@]}"; then
|
||||
die "Invalid repository target: %s" "${REPO}"
|
||||
|
@@ -1,26 +0,0 @@
|
||||
#!/hint/bash
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
[[ -z ${DEVTOOLS_INCLUDE_UTIL_MACHINE_SH:-} ]] || return 0
|
||||
DEVTOOLS_INCLUDE_UTIL_MACHINE_SH=1
|
||||
|
||||
_DEVTOOLS_LIBRARY_DIR=${_DEVTOOLS_LIBRARY_DIR:-@pkgdatadir@}
|
||||
# shellcheck source=src/lib/common.sh
|
||||
source "${_DEVTOOLS_LIBRARY_DIR}"/lib/common.sh
|
||||
|
||||
|
||||
set -eo pipefail
|
||||
|
||||
machine_get_hardware_name() {
|
||||
uname --machine
|
||||
}
|
||||
|
||||
machine_has_multilib() {
|
||||
case "$(machine_get_hardware_name)" in
|
||||
x86_64*)
|
||||
return 0
|
||||
;;
|
||||
esac
|
||||
return 1
|
||||
}
|
@@ -8,8 +8,6 @@ DEVTOOLS_INCLUDE_UTIL_PACMAN_SH=1
|
||||
_DEVTOOLS_LIBRARY_DIR=${_DEVTOOLS_LIBRARY_DIR:-@pkgdatadir@}
|
||||
# shellcheck source=src/lib/common.sh
|
||||
source "${_DEVTOOLS_LIBRARY_DIR}"/lib/common.sh
|
||||
# shellcheck source=src/lib/util/machine.sh
|
||||
source "${_DEVTOOLS_LIBRARY_DIR}"/lib/util/machine.sh
|
||||
|
||||
set -e
|
||||
|
||||
@@ -20,8 +18,7 @@ readonly _DEVTOOLS_MAKEPKG_CONF_DIR=${_DEVTOOLS_LIBRARY_DIR}/makepkg.conf.d
|
||||
|
||||
|
||||
update_pacman_repo_cache() {
|
||||
local repo=${1:-stable}
|
||||
repo=$(pacman_resolve_virtual_repo_name "${repo}")
|
||||
local repo=${1:-multilib}
|
||||
|
||||
mkdir -p "${_DEVTOOLS_PACMAN_CACHE_DIR}"
|
||||
msg "Updating pacman database cache"
|
||||
@@ -35,8 +32,7 @@ update_pacman_repo_cache() {
|
||||
|
||||
get_pacman_repo_from_pkgbuild() {
|
||||
local path=${1:-PKGBUILD}
|
||||
local repo=${2:-stable}
|
||||
repo=$(pacman_resolve_virtual_repo_name "${repo}")
|
||||
local repo=${2:-multilib}
|
||||
local -a pkgnames
|
||||
|
||||
# shellcheck source=contrib/makepkg/PKGBUILD.proto
|
||||
@@ -76,7 +72,6 @@ get_pkgnames_from_repo_pkgbase() {
|
||||
|
||||
# update the pacman repo cache if it doesn't exist yet
|
||||
if [[ ! -d "${_DEVTOOLS_PACMAN_CACHE_DIR}" ]]; then
|
||||
# TODO: universe includes multilib, switch for architecture
|
||||
update_pacman_repo_cache universe
|
||||
fi
|
||||
|
||||
@@ -96,23 +91,3 @@ get_pkgnames_from_repo_pkgbase() {
|
||||
printf "%s\n" "${pkgnames[@]}"
|
||||
return 0
|
||||
}
|
||||
|
||||
pacman_resolve_virtual_repo_name() {
|
||||
local repo=$1
|
||||
|
||||
local repo_class=extra
|
||||
if machine_has_multilib; then
|
||||
repo_class=multilib
|
||||
fi
|
||||
|
||||
case "${repo}" in
|
||||
stable)
|
||||
repo=${repo_class}
|
||||
;;
|
||||
testing|staging)
|
||||
repo="${repo_class}-${repo}"
|
||||
;;
|
||||
esac
|
||||
|
||||
printf "%s" "${repo}"
|
||||
}
|
||||
|
@@ -6,7 +6,6 @@
|
||||
# shellcheck disable=2034
|
||||
DEVTOOLS_VALID_BINARY_ARCHES=(
|
||||
x86_64
|
||||
aarch64
|
||||
)
|
||||
|
||||
# shellcheck disable=2034
|
||||
|
Reference in New Issue
Block a user