chiark / gitweb /
zsh-completion: add systemd-run
authorRonny Chevalier <chevalier.ronny@gmail.com>
Wed, 30 Oct 2013 20:57:44 +0000 (21:57 +0100)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Thu, 31 Oct 2013 02:45:18 +0000 (22:45 -0400)
Makefile.am
TODO
shell-completion/zsh/_systemd-run [new file with mode: 0644]

index 630fb19c3545289ea8b2065ce2cc91560a610085..8e996735ffc7fa423a0fa747bc748ab099a6d45c 100644 (file)
@@ -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
diff --git a/TODO b/TODO
index c537ff0782cfe5df6eb5c20e23c2a0c369ed944c..7ad00f7da5569ba7e7cb5804f134f5366b2082ca 100644 (file)
--- a/TODO
+++ b/TODO
@@ -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 (file)
index 0000000..0c81c54
--- /dev/null
@@ -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'