about summary refs log tree commit diff
path: root/Completion/Unix/Command/_chkconfig
diff options
context:
space:
mode:
authorOliver Kiddle <opk@users.sourceforge.net>2002-02-01 14:56:20 +0000
committerOliver Kiddle <opk@users.sourceforge.net>2002-02-01 14:56:20 +0000
commit8a2469d72578f05aa2543d27f67d6c034a68aa8f (patch)
tree1347abc76283f16bd4fdfb03daf655912bf1222d /Completion/Unix/Command/_chkconfig
parent6ed6d4e2d6e91a1d5b16a5cf908aa749c680b2f0 (diff)
downloadzsh-8a2469d72578f05aa2543d27f67d6c034a68aa8f.tar.gz
zsh-8a2469d72578f05aa2543d27f67d6c034a68aa8f.tar.xz
zsh-8a2469d72578f05aa2543d27f67d6c034a68aa8f.zip
16449: new chkconfig completion for both the RedHat and IRIX commands
Diffstat (limited to 'Completion/Unix/Command/_chkconfig')
-rw-r--r--Completion/Unix/Command/_chkconfig33
1 files changed, 33 insertions, 0 deletions
diff --git a/Completion/Unix/Command/_chkconfig b/Completion/Unix/Command/_chkconfig
new file mode 100644
index 000000000..92bc60c60
--- /dev/null
+++ b/Completion/Unix/Command/_chkconfig
@@ -0,0 +1,33 @@
+#compdef chkconfig
+
+local curcontext="$curcontext" state line ret=1
+
+case $OSTYPE in
+linux*)
+  _arguments -C \
+    '(- 2)--list[list services]' \
+    '(-)--level[specify runlevels to apply to]:-:_values -s "" "run levels" 1 2 3 4 5 6 7' \
+    '(- 2)--add[add new service]' \
+    '(- 2)--del[remove service from chkconfig management]' \
+    '1:service name:->services' \
+    '2:state:(on off reset)' && ret=0
+
+  if [[ -n "$state" ]]; then
+    _wanted services expl 'system service' \
+	compadd ${${${(f)"$($words[1] --list)"}%%[ :]*}##$'\t'*} && ret=0
+  fi
+;;
+irix*)
+  _arguments -C \
+    '(- 1)-s[print state of configuration flags]' \
+    '(1 -s)-f[set flag state]:configuration flag:->flag:state:(on off)' \
+    '1:configuration flag:->flag' && ret=0
+
+  if [[ -n "$state" ]]; then
+    _wanted conf-flags expl 'configuration flag' \
+	compadd ${${${(f)"$($words[1])"}[4,-1]##$'\t'}%% *} && ret=0
+  fi
+;;
+esac
+
+return ret