mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-10 13:28:12 -05:00
makepkg: rework libdepends
Rewrite the handling of libdepends. The primary advantage are: - Moves functionality from write_pkginfo() to find_libdepends(). - The order of the depends array in the PKGBUILD is kept in the package. - An unneeded libdepends is only a warning and not an error. This allows putting a libdepend on a library that is dlopened. - It is now modular so can be extended to library types other than ELF *.so. - Finding the list of libraries a package depends only occurs when a libdepend is specified in the depends array. Signed-off-by: Allan McRae <allan@archlinux.org>
This commit is contained in:
parent
81bc390dc1
commit
9a76a458b8
@ -1131,12 +1131,29 @@ tidy_install() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
find_libdepends() {
|
find_libdepends() {
|
||||||
local libdepends
|
local d sodepends;
|
||||||
find "$pkgdir" -type f -perm -u+x | while read filename
|
|
||||||
do
|
sodepends=0;
|
||||||
|
for d in "${depends[@]}"; do
|
||||||
|
if [[ $d = *.so ]]; then
|
||||||
|
sodepends=1;
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if (( sodepends == 0 )); then
|
||||||
|
printf '%s\n' "${depends[@]}"
|
||||||
|
return;
|
||||||
|
fi
|
||||||
|
|
||||||
|
local libdeps filename soarch sofile soname soversion;
|
||||||
|
declare -A libdeps;
|
||||||
|
|
||||||
|
while read filename; do
|
||||||
# get architecture of the file; if soarch is empty it's not an ELF binary
|
# get architecture of the file; if soarch is empty it's not an ELF binary
|
||||||
soarch=$(LC_ALL=C readelf -h "$filename" 2>/dev/null | sed -n 's/.*Class.*ELF\(32\|64\)/\1/p')
|
soarch=$(LC_ALL=C readelf -h "$filename" 2>/dev/null | sed -n 's/.*Class.*ELF\(32\|64\)/\1/p')
|
||||||
[ -n "$soarch" ] || continue
|
[[ -n "$soarch" ]] || continue
|
||||||
|
|
||||||
# process all libraries needed by the binary
|
# process all libraries needed by the binary
|
||||||
for sofile in $(LC_ALL=C readelf -d "$filename" 2>/dev/null | sed -nr 's/.*Shared library: \[(.*)\].*/\1/p')
|
for sofile in $(LC_ALL=C readelf -d "$filename" 2>/dev/null | sed -nr 's/.*Shared library: \[(.*)\].*/\1/p')
|
||||||
do
|
do
|
||||||
@ -1144,19 +1161,42 @@ find_libdepends() {
|
|||||||
soname="${sofile%.so?(+(.+([0-9])))}".so
|
soname="${sofile%.so?(+(.+([0-9])))}".so
|
||||||
# extract the major version: 1
|
# extract the major version: 1
|
||||||
soversion="${sofile##*\.so\.}"
|
soversion="${sofile##*\.so\.}"
|
||||||
if in_array "${soname}" ${depends[@]}; then
|
|
||||||
if ! in_array "${soname}=${soversion}-${soarch}" ${libdepends[@]}; then
|
if [[ ${libdeps[$soname]} ]]; then
|
||||||
# libfoo.so=1-64
|
if [[ ${libdeps[$soname]} != *${soversion}-${soarch}* ]]; then
|
||||||
printf "%s" "${soname}=${soversion}-${soarch}"
|
libdeps[$soname]+=" ${soversion}-${soarch}"
|
||||||
libdepends+=("${soname}=${soversion}-${soarch}")
|
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
libdeps[$soname]="${soversion}-${soarch}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
done < <(find "$pkgdir" -type f -perm -u+x)
|
||||||
|
|
||||||
|
local libdepends v
|
||||||
|
for d in "${depends[@]}"; do
|
||||||
|
case "$d" in
|
||||||
|
*.so)
|
||||||
|
if [[ ${libdeps[$d]} ]]; then
|
||||||
|
for v in ${libdeps[$d]}; do
|
||||||
|
libdepends+=("$d=$v")
|
||||||
done
|
done
|
||||||
|
else
|
||||||
|
warning "$(gettext "Library listed in %s is not required by any files: %s")" "'depends'" "$d"
|
||||||
|
libdepends+=("$d")
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
libdepends+=("$d")
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
printf '%s\n' "${libdepends[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
find_libprovides() {
|
find_libprovides() {
|
||||||
local libprovides missing
|
local p libprovides missing
|
||||||
for p in "${provides[@]}"; do
|
for p in "${provides[@]}"; do
|
||||||
missing=0
|
missing=0
|
||||||
case "$p" in
|
case "$p" in
|
||||||
@ -1246,38 +1286,20 @@ write_pkginfo() {
|
|||||||
printf "size = %s\n" "$size"
|
printf "size = %s\n" "$size"
|
||||||
printf "arch = %s\n" "$pkgarch"
|
printf "arch = %s\n" "$pkgarch"
|
||||||
|
|
||||||
|
mapfile -t provides < <(find_libprovides)
|
||||||
|
mapfile -t depends < <(find_libdepends)
|
||||||
|
|
||||||
[[ $license ]] && printf "license = %s\n" "${license[@]}"
|
[[ $license ]] && printf "license = %s\n" "${license[@]}"
|
||||||
[[ $replaces ]] && printf "replaces = %s\n" "${replaces[@]}"
|
[[ $replaces ]] && printf "replaces = %s\n" "${replaces[@]}"
|
||||||
[[ $groups ]] && printf "group = %s\n" "${groups[@]}"
|
[[ $groups ]] && printf "group = %s\n" "${groups[@]}"
|
||||||
[[ $optdepends ]] && printf "optdepend = %s\n" "${optdepends[@]//+([[:space:]])/ }"
|
|
||||||
[[ $conflicts ]] && printf "conflict = %s\n" "${conflicts[@]}"
|
[[ $conflicts ]] && printf "conflict = %s\n" "${conflicts[@]}"
|
||||||
|
|
||||||
mapfile -t provides < <(find_libprovides)
|
|
||||||
[[ $provides ]] && printf "provides = %s\n" "${provides[@]}"
|
[[ $provides ]] && printf "provides = %s\n" "${provides[@]}"
|
||||||
|
|
||||||
[[ $backup ]] && printf "backup = %s\n" "${backup[@]}"
|
[[ $backup ]] && printf "backup = %s\n" "${backup[@]}"
|
||||||
|
[[ $depends ]] && printf "depend = %s\n" "${depends[@]}"
|
||||||
|
[[ $optdepends ]] && printf "optdepend = %s\n" "${optdepends[@]//+([[:space:]])/ }"
|
||||||
local it
|
|
||||||
mapfile -t libdepends < <(find_libdepends)
|
|
||||||
depends+=("${libdepends[@]}")
|
|
||||||
|
|
||||||
for it in "${depends[@]}"; do
|
|
||||||
if [[ $it = *.so ]]; then
|
|
||||||
# check if the entry has been found by find_libdepends
|
|
||||||
# if not, it's unneeded; tell the user so he can remove it
|
|
||||||
printf -v re '(^|\s)%s=.*' "$it"
|
|
||||||
if [[ ! $libdepends =~ $re ]]; then
|
|
||||||
error "$(gettext "Cannot find library listed in %s: %s")" "'depends'" "$it"
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
printf "depend = %s\n" "$it"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
[[ $makedepends ]] && printf "makedepend = %s\n" "${makedepends[@]}"
|
[[ $makedepends ]] && printf "makedepend = %s\n" "${makedepends[@]}"
|
||||||
|
|
||||||
|
local it
|
||||||
for it in "${packaging_options[@]}"; do
|
for it in "${packaging_options[@]}"; do
|
||||||
check_option "$it" "y"
|
check_option "$it" "y"
|
||||||
case $? in
|
case $? in
|
||||||
|
Loading…
Reference in New Issue
Block a user