diff options
author | Daniel Shahaf <d.s@daniel.shahaf.name> | 2020-01-07 21:17:26 +0100 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2020-01-08 09:43:01 +0100 |
commit | 356873ddec61ed814aec3cf984cb9a0533984f9c (patch) | |
tree | 849cbc140cea39cdc2f4e846a6cc2c32309f0435 /shell-completion/zsh/_systemctl.in | |
parent | Merge pull request #14423 from danielshahaf/zsh-add-missing-completions (diff) | |
download | systemd-356873ddec61ed814aec3cf984cb9a0533984f9c.tar.xz systemd-356873ddec61ed814aec3cf984cb9a0533984f9c.zip |
zsh: Complete systemctl subcommands in separate tags
Fixes #14422
Diffstat (limited to 'shell-completion/zsh/_systemctl.in')
-rw-r--r-- | shell-completion/zsh/_systemctl.in | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/shell-completion/zsh/_systemctl.in b/shell-completion/zsh/_systemctl.in index 18663fca2e..66bf03d058 100644 --- a/shell-completion/zsh/_systemctl.in +++ b/shell-completion/zsh/_systemctl.in @@ -3,6 +3,8 @@ (( $+functions[_systemctl_commands] )) || _systemctl_commands() { + local expl i + local -a unit_commands=( # Unit Commands "list-sockets:List sockets" @@ -97,20 +99,24 @@ "suspend-then-hibernate:Suspend the system for a period of time, and then hibernate it" ) - local -a _systemctl_cmds=( - "${unit_commands[@]}" - "${machine_commands[@]}" - "${unit_file_commands[@]}" - "${job_commands[@]}" - "${environment_commands[@]}" - "${manager_state_commands[@]}" - "${system_commands[@]}" - ) + local -a groups=( unit machine unit_file job environment manager_state system ) + local -a _systemctl_cmds + for i in $groups; do + _systemctl_cmds+=( "${(@P)${:-"${i}_commands"}}" ) + done if (( CURRENT == 1 )); then - _describe -t commands 'systemctl command' _systemctl_cmds || compadd "$@" + _tags ${^groups//_/-}-commands + while _tags; do + for i in $groups; do + if _requested ${i//_/-}-commands; then + _describe -t ${i//_/-}-commands "${i//_/ } command" ${i}_commands \ + && ret=0 + fi + done + done else - local curcontext="$curcontext" expl + local curcontext="$curcontext" cmd="${${_systemctl_cmds[(r)$words[1]:*]%%:*}}" # Deal with any aliases |