base-files: fix prerm return value, align with postinst code

The return value of a package prerm script is discarded and not returned
correctly by default_prerm(). This allows other operations like service
shutdown to "leak" their return value, prompting workarounds like commit
48cfc826 which do not address the root cause.

Preserve a package prerm script return value for use by default_prerm(),
sharing the corresponding code from default_postinst() for consistency.
Also use consistent code for handling of /etc/init.d/ scripts.

Run Tested on: LEDE 17.01.4 running ar71xx.

Signed-off-by: Tony Ambardar <itugrok@yahoo.com>
This commit is contained in:
Tony Ambardar 2018-03-02 20:04:36 -08:00 committed by Jo-Philipp Wich
parent 5c9ad4fa6e
commit 8806da86f5

View File

@ -152,22 +152,27 @@ config_list_foreach() {
default_prerm() { default_prerm() {
local root="${IPKG_INSTROOT}" local root="${IPKG_INSTROOT}"
local name local pkgname="$(basename ${1%.*})"
local ret=0
name=$(basename ${1%.*}) if [ -f "$root/usr/lib/opkg/info/${pkgname}.prerm-pkg" ]; then
[ -f "$root/usr/lib/opkg/info/${name}.prerm-pkg" ] && . "$root/usr/lib/opkg/info/${name}.prerm-pkg" ( . "$root/usr/lib/opkg/info/${pkgname}.prerm-pkg" )
ret=$?
fi
local shell="$(which bash)" local shell="$(which bash)"
for i in `cat "$root/usr/lib/opkg/info/${name}.list" | grep "^/etc/init.d/"`; do for i in $(grep -s "^/etc/init.d/" "$root/usr/lib/opkg/info/${pkgname}.list"); do
if [ -n "$root" ]; then if [ -n "$root" ]; then
${shell:-/bin/sh} "$root/etc/rc.common" "$root$i" disable ${shell:-/bin/sh} "$root/etc/rc.common" "$root$i" disable
else else
if [ "$PKG_UPGRADE" != "1" ]; then if [ "$PKG_UPGRADE" != "1" ]; then
"$i" disable "$i" disable
fi fi
"$i" stop || /bin/true "$i" stop
fi fi
done done
return $ret
} }
add_group_and_user() { add_group_and_user() {