diff options
author | Felipe F. Tonello <eu@felipetonello.com> | 2013-10-03 14:42:00 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-10-14 16:54:28 +0100 |
commit | d91b08f3a27baa49ae35dc20dba1b2d76e6abd64 (patch) | |
tree | af0e17b028c2a28c542d4b11213a510c3cff20cf /meta/classes/update-rc.d.bbclass | |
parent | a5afc67cbfc32beb3be10392bf9788cfc3610ab1 (diff) | |
download | openembedded-core-d91b08f3a27baa49ae35dc20dba1b2d76e6abd64.tar.gz openembedded-core-d91b08f3a27baa49ae35dc20dba1b2d76e6abd64.tar.bz2 openembedded-core-d91b08f3a27baa49ae35dc20dba1b2d76e6abd64.zip |
update-rc: Stop and remove service if updating package
Since when updating packages packages managers do not remove the previous package,
it just replaces new files and run pre/post install scripts. This causes not
to update update-rc scripts if they were changed.
This patch is useful in case the newer package version updated the update-rc
script.
Signed-off-by: Felipe F. Tonello <eu@felipetonello.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/update-rc.d.bbclass')
-rw-r--r-- | meta/classes/update-rc.d.bbclass | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/meta/classes/update-rc.d.bbclass b/meta/classes/update-rc.d.bbclass index f726f2f4b1..d44d36cb5b 100644 --- a/meta/classes/update-rc.d.bbclass +++ b/meta/classes/update-rc.d.bbclass @@ -13,7 +13,23 @@ INITSCRIPT_PARAMS ?= "defaults" INIT_D_DIR = "${sysconfdir}/init.d" updatercd_postinst() { -if test "x$D" != "x"; then +IN_TARGET=`test "x$D" = "x"` + +# test if there is a previous init script there, ie, we are updating the package +# if so, we stop the service and remove it before we install from the new package +if type update-rc.d >/dev/null 2>/dev/null; then + if [ $IN_TARGET -a `test -f "${INIT_D_DIR}/${INITSCRIPT_NAME}"` ]; then + ${INIT_D_DIR}/${INITSCRIPT_NAME} stop + fi + if [ ! $IN_TARGET ]; then + OPT="-f -r $D" + else + OPT="-f" + fi + update-rc.d $OPT ${INITSCRIPT_NAME} remove +fi + +if [ ! $IN_TARGET ]; then OPT="-r $D" else OPT="-s" |