From 51b70a5b7f48c000d4adf6b9a5146d66a5323346 Mon Sep 17 00:00:00 2001 From: Antoine Jacoutot Date: Tue, 19 Aug 2014 16:47:19 +0000 Subject: Simplify some checks Return immediatly from add_flags() if we are already enabled and no flags are (re)set; unbreak "enable" under some circumstances. --- usr.sbin/rcctl/rcctl.sh | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) (limited to 'usr.sbin/rcctl') diff --git a/usr.sbin/rcctl/rcctl.sh b/usr.sbin/rcctl/rcctl.sh index eb17004e7f3..4b43bdc8831 100755 --- a/usr.sbin/rcctl/rcctl.sh +++ b/usr.sbin/rcctl/rcctl.sh @@ -206,7 +206,9 @@ add_flags() local _svc=$2 [ -n "${_svc}" ] || return - if [ -n "$3" -a "$3" = "flags" ]; then + if [ -n "$3" ]; then + # there is an early check for this; but this function is fed with $* + [ "$3" = "flags" ] || return if [ -n "$4" ]; then while [ "${_numargs}" -ge 4 ] do @@ -215,9 +217,9 @@ add_flags() done set -A _flags -- ${_flags} fi - elif svc_is_base ${_svc}; then - # base svc: save current flags because they are reset below - set -A _flags -- $(eval echo \${${_svc}_flags}) + elif svc_is_enabled ${_svc}; then + # svc is already enabled and we did not (re)set the flags + return fi # special var @@ -243,14 +245,12 @@ add_flags() fi # pkg script - if [ -n "$3" -a "$3" = "flags" ]; then - rcconf_edit_begin - grep -v "^${_svc}_flags.*=" /etc/rc.conf.local >${_TMP_RCCONF} - if [ "${#_flags[*]}" -gt 0 ]; then - echo ${_svc}_flags=${_flags[@]} >>${_TMP_RCCONF} - fi - rcconf_edit_end + rcconf_edit_begin + grep -v "^${_svc}_flags.*=" /etc/rc.conf.local >${_TMP_RCCONF} + if [ "${#_flags[*]}" -gt 0 ]; then + echo ${_svc}_flags=${_flags[@]} >>${_TMP_RCCONF} fi + rcconf_edit_end } rm_flags() -- cgit v1.2.3