hooks/pre-pkg: add pkglint-subpkgs hook
This commit is contained in:
parent
b2b7380a91
commit
c5d40ba078
1 changed files with 44 additions and 0 deletions
44
common/hooks/pre-pkg/99-pkglint-subpkgs.sh
Normal file
44
common/hooks/pre-pkg/99-pkglint-subpkgs.sh
Normal file
|
@ -0,0 +1,44 @@
|
|||
# vim: set ts=4 sw=4 et:
|
||||
#
|
||||
# This hook executes the following tasks:
|
||||
# - Warns if the main package is in subpackages=
|
||||
# - Warns if a subpackage is unreachable (never appears in subpackages=)
|
||||
|
||||
hook() {
|
||||
local subpkgs matches
|
||||
|
||||
# Run this only against the main package
|
||||
if [ "$pkgname" != "$sourcepkg" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
if [ -z "$subpackages" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
subpkgs=$(get_subpkgs)
|
||||
|
||||
subpackages="${subpackages// /$'\n'}"
|
||||
|
||||
# Sort the strings so they can be compare for equality
|
||||
subpkgs="$(printf "%s\\n" "$subpkgs" | sort)"
|
||||
subpackages="$(printf "%s\\n" "$subpackages" | sort)"
|
||||
|
||||
if [ "$subpackages" = "$subpkgs" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# XXX: Make the sed call work when subpackages has multiple lines
|
||||
# this can be done with grep with perl regexp (-P) but chroot-grep
|
||||
# is compiled without it
|
||||
matches="$(sed -n 's/subpackages.*"\(.*\)"[^"]*$/\1/p' $XBPS_SRCPKGDIR/$pkgname/template \
|
||||
| tr " " "\n" | sort)"
|
||||
|
||||
for s in $subpkgs; do
|
||||
grep -q "^$s" <<< "$matches" ||
|
||||
msg_warn "${s}_package() defined but will never be built.\n"
|
||||
done
|
||||
|
||||
grep -q "^$pkgname" <<< "$matches" &&
|
||||
msg_warn "$pkgname is sourcepkg but is in subpackages=.\n"
|
||||
}
|
Loading…
Reference in a new issue