]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
zsh: _journalctl: also handle --root arg and --key=value style (#3956)
authorDaniel Hahler <github@thequod.de>
Tue, 16 Aug 2016 16:47:39 +0000 (18:47 +0200)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Tue, 16 Aug 2016 16:47:39 +0000 (12:47 -0400)
This will now also handle `journalctl --directory=/var/log/journal`
properly.

shell-completion/zsh/_journalctl

index 610788dcce9192b5f8597c24403aa7a4f52693c8..ef67fcf2a0dddb064b0406b5f8af52a615abc765 100644 (file)
@@ -54,16 +54,25 @@ _journal_boots() {
 # Build arguments for "journalctl" to be used in completion.
 # Use both --user and --system modes, they are not exclusive.
 local -a _modes; _modes=(--user --system)
-local -a _modes_with_arg; _modes_with_arg=(--directory -D --file -M --machine)
+local -a _modes_with_arg; _modes_with_arg=(--directory -D --file -M --machine --root)
 typeset -a _sys_service_mgr
-local w i=0 n=$#words
+local w k v i=0 n=$#words
 while (( i++ < n )); do
     w=$words[$i]
     if (( $_modes[(I)$w] )); then
         _sys_service_mgr+=($w)
     else
-        if (( ${_modes_with_arg[(I)$w]} )); then
-            _sys_service_mgr+=($w ${words[((++i))]})
+        # Handle options with arguments. "--key=value" and "--key value".
+        k=${w%%=*}
+        if (( ${_modes_with_arg[(I)$k]} )); then
+            v=${w#*=}
+            if [[ "$k" != "$w" ]]; then
+                # "--key=value" style.
+                _sys_service_mgr+=($w)
+            else
+                # "--key value" style.
+                _sys_service_mgr+=($w ${words[((++i))]})
+            fi
         fi
     fi
 done