summaryrefslogtreecommitdiff
path: root/sbin/rc
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/rc')
-rwxr-xr-xsbin/rc47
1 files changed, 22 insertions, 25 deletions
diff --git a/sbin/rc b/sbin/rc
index 000fabe..6527d16 100755
--- a/sbin/rc
+++ b/sbin/rc
@@ -14,7 +14,7 @@ get_critical_services() {
local x=
CRITICAL_SERVICES=
- if [[ -f /etc/runlevels/${BOOTLEVEL}/.critical ]] ; then
+ if [[ -f "/etc/runlevels/${BOOTLEVEL}/.critical" ]] ; then
for x in $(< "/etc/runlevels/${BOOTLEVEL}/.critical") ; do
CRITICAL_SERVICES="${CRITICAL_SERVICES} ${x##*/}"
done
@@ -53,34 +53,34 @@ then
# We reset argv1 to the bootlevel given on the kernel command line
# if there is one
- argv1=${BOOTLEVEL}
+ argv1="${BOOTLEVEL}"
fi
source "${svclib}/sh/rc-services.sh"
-if [[ -f ${svcdir}/softlevel ]] ; then
+if [[ -f "${svcdir}/softlevel" ]] ; then
# Set OLDSOFTLEVEL if we had a valid SOFTLEVEL
- export OLDSOFTLEVEL=$(< ${svcdir}/softlevel)
+ export OLDSOFTLEVEL="$(< "${svcdir}/softlevel")"
else
export OLDSOFTLEVEL=
fi
if [[ -z ${argv1} ]] ; then
- if [[ -f ${svcdir}/softlevel ]] ; then
- export SOFTLEVEL=$(< ${svcdir}/softlevel)
+ if [[ -f "${svcdir}/softlevel" ]] ; then
+ export SOFTLEVEL="$(< "${svcdir}/softlevel")"
else
- export SOFTLEVEL=${BOOTLEVEL}
+ export SOFTLEVEL="${BOOTLEVEL}"
fi
else
- export SOFTLEVEL=${argv1}
+ export SOFTLEVEL="${argv1}"
fi
-if [[ ! -f ${svcdir}/softlevel ]] ; then
+if [[ ! -f "${svcdir}/softlevel" ]] ; then
echo "${SOFTLEVEL}" > "${svcdir}/softlevel"
fi
# For keeping a list of services that fails during boot/halt
-if [[ ! -d ${svcdir}/failed ]] ; then
+if [[ ! -d "${svcdir}/failed" ]] ; then
mkdir -p -m 0755 "${svcdir}/failed"
else
rm -rf "${svcdir}"/failed/*
@@ -89,18 +89,18 @@ fi
if [[ ${SOFTLEVEL} == "reboot" || ${SOFTLEVEL} == "shutdown" ]] ; then
myscripts=
-elif [[ ! -d /etc/runlevels/${SOFTLEVEL} ]] ; then
+elif [[ ! -d "/etc/runlevels/${SOFTLEVEL}" ]] ; then
eerror "ERROR: runlevel ${SOFTLEVEL} does not exist; exiting ..."
exit 1
else
myscripts=
if [[ ${SOFTLEVEL} != "${BOOTLEVEL}" ]] ; then
# Normal runlevels *include* boot scripts
- mylevels=$(dolisting "/etc/runlevels/${SOFTLEVEL}/")
- mylevels="${mylevels} $(dolisting /etc/runlevels/${BOOTLEVEL}/)"
+ mylevels="$(dolisting "/etc/runlevels/${SOFTLEVEL}/")"
+ mylevels="${mylevels} $(dolisting "/etc/runlevels/${BOOTLEVEL}/")"
else
# Non-normal runlevels don't include boot scripts as default
- mylevels=$(dolisting "/etc/runlevels/${SOFTLEVEL}/")
+ mylevels="$(dolisting "/etc/runlevels/${SOFTLEVEL}/")"
fi
for x in ${mylevels} ; do
@@ -116,7 +116,7 @@ fi
mkdir -p -m 0755 "${svcdir}/softscripts.new"
for x in ${myscripts} ; do
- if [[ ! -e /etc/init.d/${x} ]] ; then
+ if [[ ! -e "/etc/init.d/${x}" ]] ; then
ewarn "WARNING: /etc/init.d/${x} missing; skipping ..."
continue
fi
@@ -139,12 +139,12 @@ get_stop_services() {
dep_stop() {
local x dep needsme depservice
- local myservice=${1##*/}
+ local myservice="${1##*/}"
service_stopped "${myservice}" && return 0
# Candidate for zapping ?
- [[ ! -L ${svcdir}/softscripts.new/${myservice} ]] || \
+ [[ ! -L "${svcdir}/softscripts.new/${myservice}" ]] || \
return 0
# If this is a 'net' service, we do not want to stop it if it was
@@ -171,11 +171,8 @@ dep_stop() {
needsme=0
for dep in $(needsme "${myservice}") ; do
- #if service_started "${dep}" && \
- if [[ -L ${svcdir}/softscripts.new/${dep} ]] ; then
- # This dep is valid
+ if [[ -L "${svcdir}/softscripts.new/${dep}" ]] ; then
needsme=1
-
break
fi
done
@@ -192,13 +189,13 @@ if [[ ${SOFTLEVEL} != "reboot" && \
done
# Wait for any services that may still be stopping ...
- [ "${RC_PARALLEL_STARTUP}" = "yes" ] && wait
+ [[ ${RC_PARALLEL_STARTUP} = "yes" ]] && wait
else
get_critical_services
is_critical_service() {
local x
- local myservice=${1##*/}
+ local myservice="${1##*/}"
for x in ${CRITICAL_SERVICES} ${LOGGER_SERVICE} ; do
[[ ${myservice} == "${x}" ]] && return 0
@@ -261,10 +258,10 @@ get_start_services() {
local x list
get_critical_services
- list=${CRITICAL_SERVICES}
+ list="${CRITICAL_SERVICES}"
[[ -n ${LOGGER_SERVICE} && \
- -L ${svcdir}/softscripts/${LOGGER_SERVICE} ]] && \
+ -L "${svcdir}/softscripts/${LOGGER_SERVICE}" ]] && \
list="${list} ${LOGGER_SERVICE}"
for x in $(dolisting "${svcdir}/softscripts/") ; do