From 55eb3794fb4ad563102d5ab30c1d5337a599b2e5 Mon Sep 17 00:00:00 2001 From: Roy Marples Date: Tue, 25 Mar 2008 14:06:05 +0000 Subject: Rework our folder structure so that we don't have OS specific dirs, making it easier to share init and conf files per OS. --- init.d/rc-enabled.in | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 init.d/rc-enabled.in (limited to 'init.d/rc-enabled.in') diff --git a/init.d/rc-enabled.in b/init.d/rc-enabled.in new file mode 100644 index 0000000..9801203 --- /dev/null +++ b/init.d/rc-enabled.in @@ -0,0 +1,54 @@ +#!@PREFIX@/sbin/runscript +# Copyright 2007-2008 Roy Marples +# All rights reserved. Released under the 2-clause BSD license. + +depend() +{ + need localmount net + after * + before local + keyword noprefix +} + +start() +{ + ebegin "Starting local rc services" + local svc= enabled= retval=0 service= + for svc in $(rcorder /etc/rc.d/* @PKG_PREFIX@/etc/rc.d/* 2>/dev/null); do + [ -x "$svc" ] || continue + service=${svc##*/} + + # Skip these services + for s in cleartmp moused; do + [ "${s}" = "${service}" ] && continue 2 + done + + # If we have an init script for this service, continue + [ -x @SYSCONFDIR@/init.d/"${service}" ] && continue + [ -x @PKG_PREFIX@/@SYSCONFDIR@/init.d/"${service}" ] && continue + [ -x @LOCAL_PREFIX@/@SYSCONFDIR@/init.d/"${service}" ] && continue + + # Ensure that the users rc.conf will start us - ignore the defaults + eval enabled=\$${svc##*/}_enable + yesno ${enabled} || yesno ${svc##*/} || continue + + # Good to go! + "$svc" start && started="${started} ${svc}" + : $((retval += $?)) + done + service_set_value started "${started}" + eend $retval "Some local rc services failed to start" + return 0 +} + +stop() +{ + ebegin "Stopping local rc services" + local svc= retval=0 + for svc in $(rcorder $(service_get_value started) 2>/dev/null | sort -r); do + "${svc}" stop + : $((retval += $?)) + done + eend $retval "Some local rc services failed to stop" + return 0 +} -- cgit v1.2.3