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