diff options
author | Ronny Chevalier <chevalier.ronny@gmail.com> | 2013-10-30 21:57:44 +0100 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2013-10-30 22:45:18 -0400 |
commit | d74ab852161d2dc4093d369495ddfa18460cfd76 (patch) | |
tree | 568870dcbcd2933d12727bfd0db46f1b74fad9a5 | |
parent | e1636421f46db6d06fbd028ef20a3113fa3e11f8 (diff) |
zsh-completion: add systemd-run
-rw-r--r-- | Makefile.am | 1 | ||||
-rw-r--r-- | TODO | 2 | ||||
-rw-r--r-- | shell-completion/zsh/_systemd-run | 31 |
3 files changed, 32 insertions, 2 deletions
diff --git a/Makefile.am b/Makefile.am index 630fb19c35..8e996735ff 100644 --- a/Makefile.am +++ b/Makefile.am @@ -344,6 +344,7 @@ dist_zshcompletion_DATA = \ shell-completion/zsh/_kernel-install \ shell-completion/zsh/_systemd-nspawn \ shell-completion/zsh/_systemd-analyze \ + shell-completion/zsh/_systemd-run \ shell-completion/zsh/_sd_hosts_or_user_at_host \ shell-completion/zsh/_systemd-delta \ shell-completion/zsh/_systemd @@ -717,8 +717,6 @@ Features: - document initcall_debug - kernel cmdline "bootchart" option for simplicity? -* systemd-run is missing zsh completion scripts - * udev-link-config: - Make sure ID_PATH is always exported and complete for network devices where possible, so we can safely rely diff --git a/shell-completion/zsh/_systemd-run b/shell-completion/zsh/_systemd-run new file mode 100644 index 0000000000..0c81c543c5 --- /dev/null +++ b/shell-completion/zsh/_systemd-run @@ -0,0 +1,31 @@ +#compdef systemd-run + +__systemctl() { + local -a _modes + _modes=("--user" "--system") + systemctl ${words:*_modes} --full --no-legend --no-pager "$@" 2>/dev/null +} + +__get_slices () { + __systemctl list-units --all -t slice \ + | { while read -r a b; do echo $a; done; }; +} + +__slices () { + local -a _slices + _slices=(${(fo)"$(__get_slices)"}) + typeset -U _slices + _describe 'slices' _slices +} + +_arguments \ + {-h,--help}'[Show help message]' \ + '--version[Show package version]' \ + '--user[Run as user unit]' \ + '--scope[Run this as scope rather than service]' \ + '--unit=[Run under the specified unit name]:unit name' \ + '--description=[Description for unit]:description' \ + '--slice=[Run in the specified slice]:slices:__slices' \ + {-r,--remain-after-exit}'[Leave service around until explicitly stopped]' \ + '--send-sighup[Send SIGHUP when terminating]' \ + '*::command:_command' |