diff options
-rw-r--r-- | bash_completion | 12 | ||||
-rw-r--r-- | completions/service | 20 |
2 files changed, 22 insertions, 10 deletions
diff --git a/bash_completion b/bash_completion index 1ef70305..9c96db78 100644 --- a/bash_completion +++ b/bash_completion @@ -1043,9 +1043,12 @@ _backup_glob='@(#*#|*@(~|.@(bak|orig|rej|swp|dpkg*|rpm@(orig|new|save))))' # _services() { - local sysvdir famdir - [ -d /etc/rc.d/init.d ] && sysvdir=/etc/rc.d/init.d || sysvdir=/etc/init.d - famdir=/etc/xinetd.d + local sysvdir=/etc/init.d famdir=/etc/xinetd.d + if [[ -d /etc/rc.d/init.d ]]; then + sysvdir=/etc/rc.d/init.d + elif [[ -f /etc/slackware-version ]]; then + sysvdir=/etc/rc.d + fi local restore_nullglob=$(shopt -p nullglob); shopt -s nullglob @@ -1843,7 +1846,8 @@ _completion_loader() [[ $BASH_SOURCE == */* ]] && compdir="${BASH_SOURCE%/*}/completions" # Special case for init.d scripts. - if [[ $1 == /etc?(/rc.d)/init.d/* ]]; then + if [[ $1 == /etc?(/rc.d)/init.d/* || \ + ( $1 == /etc/rc.d/* && -f /etc/slackware-version ) ]]; then . "$compdir/service" &>/dev/null && return 124 || return 1 fi diff --git a/completions/service b/completions/service index f008770e..e359ef48 100644 --- a/completions/service +++ b/completions/service @@ -15,9 +15,12 @@ _service() if [[ $cword -eq 1 && $prev == ?(*/)service ]]; then _services else - local sysvdir - [ -d /etc/rc.d/init.d ] && \ - sysvdir=/etc/rc.d/init.d || sysvdir=/etc/init.d + local sysvdir=/etc/init.d + if [[ -d /etc/rc.d/init.d ]]; then + sysvdir=/etc/rc.d/init.d + elif [[ -f /etc/slackware-version ]]; then + sysvdir=/etc/rc.d + fi COMPREPLY=( $( compgen -W '`sed -e "y/|/ /" \ -ne "s/^.*\(U\|msg_u\)sage.*{\(.*\)}.*$/\2/p" \ $sysvdir/${prev##*/} 2>/dev/null` start stop' -- "$cur" ) ) @@ -26,9 +29,14 @@ _service() return 0 } && complete -F _service service -for svc in /etc/init.d/!($_backup_glob) /etc/rc.d/init.d/!($_backup_glob); do - [ -x "$svc" ] && complete -F _service $svc + +svcdirs=( /etc/init.d /etc/rc.d/init.d ) +[[ -f /etc/slackware-version ]] && svcdirs=( /etc/rc.d ) +for svcdir in ${svcdirs[@]}; do + for svc in $svcdir/!($_backup_glob); do + [ -x "$svc" ] && complete -F _service $svc + done done -unset svc +unset svc svcdir svcdirs # ex: ts=4 sw=4 et filetype=sh |