Compare commits

..

4 Commits

Author SHA1 Message Date
Robin Candau
fe42a31a70 Merge branch 'build_version_upgrade' into 'master'
feat: introduce the `--version-upgrade` argument to `pkgctl build`

See merge request archlinux/devtools!261
2025-08-02 04:52:34 +02:00
Christian Heusel
01757e6904 fix(commitpkg): Quiet git ls-files output
So far all files in `needsversioning=(...)` have been printed to the
command line if they were found, which is not useful, especially now
that we have more files present there.

It makes sense however to keep the standard error output, as this gives
a actionable suggestion what one should to to fix the issue:

    > error: pathspec 'PKGBUILD' did not match any file(s) known to git
    > Did you forget to 'git add'?

Fixes #281

Signed-off-by: Christian Heusel <christian@heusel.eu>
2025-08-01 11:26:57 +02:00
Daniel M. Capella
c5fe8ff3e6 feat(license): Extend matches for sysusers/tmpfiles configs
Eg. to match:
- sysusers.conf
- $pkgname.sysusers
- $pkgname.sysusers.conf
2025-07-28 23:38:32 -04:00
Robin Candau
6a1a0f6b50 feat: introduce the --version-upgrade argument to pkgctl build
This commit introduces the `--version-upgrade` argument to `pkgctl build` which updates the PKGBUILD to the latest upstream version via `pkgctl version upgrade` before starting the build (similarly to the `--pkgver` argument but automated via the `nvchecker` integration of `pkgctl version`).
2024-06-01 12:58:45 +02:00
6 changed files with 21 additions and 1 deletions

View File

@@ -196,6 +196,7 @@ _pkgctl_build_args=(
--pkgrel --pkgrel
--rebuild --rebuild
--update-checksums --update-checksums
--version-upgrade
-e --edit -e --edit
-r --release -r --release

View File

@@ -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:"

View File

@@ -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

View File

@@ -155,7 +155,7 @@ if (( ${#needsversioning[*]} )); then
if [[ ! -f "${file}" ]]; then if [[ ! -f "${file}" ]]; then
continue continue
fi fi
if ! git ls-files --error-unmatch "$file"; then if ! git ls-files --error-unmatch "$file" >/dev/null; then
die "%s is not under version control" "$file" die "%s is not under version control" "$file"
fi fi
done done

View File

@@ -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
@@ -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

View File

@@ -191,7 +191,9 @@ path = [
".nvchecker.toml", ".nvchecker.toml",
"*.install", "*.install",
"*.sysusers", "*.sysusers",
"*sysusers.conf",
"*.tmpfiles", "*.tmpfiles",
"*tmpfiles.conf",
"*.logrotate", "*.logrotate",
"*.pam", "*.pam",
"*.service", "*.service",