Zbigniew Jędrzejewski-Szmek 436654
From 50bb352ccad52c5f56a457305f5422b1359cbf42 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 436654
From: Eric Cook <llua@gmx.com>
Zbigniew Jędrzejewski-Szmek 436654
Date: Fri, 29 May 2015 10:40:11 -0400
Zbigniew Jędrzejewski-Szmek 436654
Subject: [PATCH] zsh-completion: a more style/tag aware _systemctl
Zbigniew Jędrzejewski-Szmek 436654
Zbigniew Jędrzejewski-Szmek 436654
using _wanted instead of calling compadd directly. this allows the user to customize
Zbigniew Jędrzejewski-Szmek 436654
possible matches.
Zbigniew Jędrzejewski-Szmek 436654
Zbigniew Jędrzejewski-Szmek 436654
An example being, grouping units by type:
Zbigniew Jędrzejewski-Szmek 436654
autoload -Uz compinit; compinit
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*' menu select
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*' group-name ''
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*' format 'Completing %d'
Zbigniew Jędrzejewski-Szmek 436654
zstyle -e ':completion:*:*:systemctl-(((re|)en|dis)able|(*re|)start|reload*):*' \
Zbigniew Jędrzejewski-Szmek 436654
tag-order 'local type; for type in service template target socket;
Zbigniew Jędrzejewski-Szmek 436654
    reply+=( systemd-units:-${type}:${type} ); reply=( "$reply systemd-units:-misc:misc" )'
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*:systemd-units-template' ignored-patterns '^*@'
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*:systemd-units-target' ignored-patterns '^*.target'
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*:systemd-units-socket' ignored-patterns '^*.socket'
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*:systemd-units-service' ignored-patterns '^*.service'
Zbigniew Jędrzejewski-Szmek 436654
zstyle ':completion:*:systemd-units-misc' ignored-patterns '*(@|.(service|socket|target))'
Zbigniew Jędrzejewski-Szmek 436654
Zbigniew Jędrzejewski-Szmek 436654
also, <poke> http://lists.freedesktop.org/archives/systemd-devel/2015-May/032012.html
Zbigniew Jędrzejewski-Szmek 436654
Zbigniew Jędrzejewski-Szmek 436654
(cherry picked from commit d34b7c117bd016cb9ef2c36d474c9a917924abda)
Zbigniew Jędrzejewski-Szmek 436654
---
Zbigniew Jędrzejewski-Szmek 436654
 shell-completion/zsh/_systemctl.in | 60 +++++++++++++++++++++++---------------
Zbigniew Jędrzejewski-Szmek 436654
 1 file changed, 37 insertions(+), 23 deletions(-)
Zbigniew Jędrzejewski-Szmek 436654
Zbigniew Jędrzejewski-Szmek 436654
diff --git a/shell-completion/zsh/_systemctl.in b/shell-completion/zsh/_systemctl.in
Zbigniew Jędrzejewski-Szmek 436654
index db9bdb60c5..17736de01c 100644
Zbigniew Jędrzejewski-Szmek 436654
--- a/shell-completion/zsh/_systemctl.in
Zbigniew Jędrzejewski-Szmek 436654
+++ b/shell-completion/zsh/_systemctl.in
Zbigniew Jędrzejewski-Szmek 436654
@@ -65,7 +65,7 @@
Zbigniew Jędrzejewski-Szmek 436654
   if (( CURRENT == 1 )); then
Zbigniew Jędrzejewski-Szmek 436654
     _describe -t commands 'systemctl command' _systemctl_cmds || compadd "$@"
Zbigniew Jędrzejewski-Szmek 436654
   else
Zbigniew Jędrzejewski-Szmek 436654
-    local curcontext="$curcontext"
Zbigniew Jędrzejewski-Szmek 436654
+    local curcontext="$curcontext" expl
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
     cmd="${${_systemctl_cmds[(r)$words[1]:*]%%:*}}"
Zbigniew Jędrzejewski-Szmek 436654
     # Deal with any aliases
Zbigniew Jędrzejewski-Szmek 436654
@@ -172,7 +172,8 @@ for fun in is-active is-failed is-enabled status show cat mask preset help list-
Zbigniew Jędrzejewski-Szmek 436654
   (( $+functions[_systemctl_$fun] )) || _systemctl_$fun()
Zbigniew Jędrzejewski-Szmek 436654
   {
Zbigniew Jędrzejewski-Szmek 436654
     _systemctl_really_all_units
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" -a - _sys_really_all_units
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl unit \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" -a - _sys_really_all_units
Zbigniew Jędrzejewski-Szmek 436654
   }
Zbigniew Jędrzejewski-Szmek 436654
 done
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
@@ -180,34 +181,39 @@ done
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_disable] )) || _systemctl_disable()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
     local _sys_unit_state; _systemctl_unit_state
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" - ${(k)_sys_unit_state[(R)enabled]}
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl 'enabled unit' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" - ${(k)_sys_unit_state[(R)enabled]}
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_reenable] )) || _systemctl_reenable()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
     local _sys_unit_state; _systemctl_unit_state
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" - ${(k)_sys_unit_state[(R)(enabled|disabled)]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl 'enabled/disabled unit' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" - ${(k)_sys_unit_state[(R)(enabled|disabled)]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for DISABLED_UNITS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_enable] )) || _systemctl_enable()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
   local _sys_unit_state; _systemctl_unit_state
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - ${(k)_sys_unit_state[(R)disabled]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-units expl 'disabled unit' \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - ${(k)_sys_unit_state[(R)disabled]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for FAILED_UNITS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_reset-failed] )) || _systemctl_reset-failed()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
   local _sys_failed_units; _systemctl_failed_units
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" -a - _sys_failed_units || _message "no failed unit found"
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-units expl 'failed unit' \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" -a - _sys_failed_units || _message "no failed unit found"
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for STARTABLE_UNITS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_start] )) || _systemctl_start()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
    local _sys_startable_units; _systemctl_startable_units
Zbigniew Jędrzejewski-Szmek 436654
-   compadd "$@" - ${_sys_startable_units[*]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
+   _wanted systemd-units expl 'startable unit' \
Zbigniew Jędrzejewski-Szmek 436654
+     compadd "$@" - ${_sys_startable_units[*]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for STOPPABLE_UNITS
Zbigniew Jędrzejewski-Szmek 436654
@@ -215,8 +221,9 @@ for fun in stop kill try-restart condrestart ; do
Zbigniew Jędrzejewski-Szmek 436654
   (( $+functions[_systemctl_$fun] )) || _systemctl_$fun()
Zbigniew Jędrzejewski-Szmek 436654
   {
Zbigniew Jędrzejewski-Szmek 436654
     local _sys_active_units; _systemctl_active_units
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" - $( _filter_units_by_property CanStop yes \
Zbigniew Jędrzejewski-Szmek 436654
-      ${_sys_active_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl 'stoppable unit' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" - $( _filter_units_by_property CanStop yes \
Zbigniew Jędrzejewski-Szmek 436654
+        ${_sys_active_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
   }
Zbigniew Jędrzejewski-Szmek 436654
 done
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
@@ -224,8 +231,9 @@ done
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_isolate] )) || _systemctl_isolate()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
   _systemctl_all_units
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - $( _filter_units_by_property AllowIsolate yes \
Zbigniew Jędrzejewski-Szmek 436654
-    ${_sys_all_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-units expl 'isolatable unit' \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - $( _filter_units_by_property AllowIsolate yes \
Zbigniew Jędrzejewski-Szmek 436654
+      ${_sys_all_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for RELOADABLE_UNITS
Zbigniew Jędrzejewski-Szmek 436654
@@ -233,8 +241,9 @@ for fun in reload reload-or-try-restart force-reload ; do
Zbigniew Jędrzejewski-Szmek 436654
   (( $+functions[_systemctl_$fun] )) || _systemctl_$fun()
Zbigniew Jędrzejewski-Szmek 436654
   {
Zbigniew Jędrzejewski-Szmek 436654
     local _sys_active_units; _systemctl_active_units
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" - $( _filter_units_by_property CanReload yes \
Zbigniew Jędrzejewski-Szmek 436654
-      ${_sys_active_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl 'reloadable unit' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" - $( _filter_units_by_property CanReload yes \
Zbigniew Jędrzejewski-Szmek 436654
+        ${_sys_active_units[*]} )
Zbigniew Jędrzejewski-Szmek 436654
   }
Zbigniew Jędrzejewski-Szmek 436654
 done
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
@@ -243,7 +252,8 @@ for fun in restart reload-or-restart ; do
Zbigniew Jędrzejewski-Szmek 436654
   (( $+functions[_systemctl_$fun] )) || _systemctl_$fun()
Zbigniew Jędrzejewski-Szmek 436654
   {
Zbigniew Jędrzejewski-Szmek 436654
     local _sys_restartable_units; _systemctl_restartable_units
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" - ${_sys_restartable_units[*]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-units expl 'restartable unit' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" - ${_sys_restartable_units[*]} $(_systemctl_get_template_names)
Zbigniew Jędrzejewski-Szmek 436654
   }
Zbigniew Jędrzejewski-Szmek 436654
 done
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
@@ -251,28 +261,32 @@ done
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_unmask] )) || _systemctl_unmask()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
   local _sys_unit_state; _systemctl_unit_state
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - ${(k)_sys_unit_state[(R)masked]} || _message "no masked units found"
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-units expl 'masked unit' \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - ${(k)_sys_unit_state[(R)masked]} || _message "no masked units found"
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for JOBS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_cancel] )) || _systemctl_cancel()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - ${${(f)"$(__systemctl list-jobs)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
-    _message "no jobs found"
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-jobs expl job \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - ${${(f)"$(__systemctl list-jobs)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
+      _message "no jobs found"
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for SNAPSHOTS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_delete] )) || _systemctl_delete()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - ${${(f)"$(__systemctl list-units --type snapshot --all)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
-    _message "no snapshots found"
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-snapshots expl snapshot \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - ${${(f)"$(__systemctl list-units --type snapshot --all)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
+      _message "no snapshots found"
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for TARGETS
Zbigniew Jędrzejewski-Szmek 436654
 (( $+functions[_systemctl_set-default] )) || _systemctl_set-default()
Zbigniew Jędrzejewski-Szmek 436654
 {
Zbigniew Jędrzejewski-Szmek 436654
-  compadd "$@" - ${${(f)"$(__systemctl list-unit-files --type target --all)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
-    _message "no targets found"
Zbigniew Jędrzejewski-Szmek 436654
+  _wanted systemd-targets expl target \
Zbigniew Jędrzejewski-Szmek 436654
+    compadd "$@" - ${${(f)"$(__systemctl list-unit-files --type target --all)"}%% *} ||
Zbigniew Jędrzejewski-Szmek 436654
+      _message "no targets found"
Zbigniew Jędrzejewski-Szmek 436654
 }
Zbigniew Jędrzejewski-Szmek 436654
 
Zbigniew Jędrzejewski-Szmek 436654
 # Completion functions for ENVS
Zbigniew Jędrzejewski-Szmek 436654
@@ -284,8 +298,8 @@ for fun in set-environment unset-environment ; do
Zbigniew Jędrzejewski-Szmek 436654
     if [[ "${fun}" = "set-environment" ]]; then
Zbigniew Jędrzejewski-Szmek 436654
       suf='-S='
Zbigniew Jędrzejewski-Szmek 436654
     fi
Zbigniew Jędrzejewski-Szmek 436654
-
Zbigniew Jędrzejewski-Szmek 436654
-    compadd "$@" ${suf} - ${${(f)"$(systemctl show-environment)"}%%=*}
Zbigniew Jędrzejewski-Szmek 436654
+    _wanted systemd-environment expl 'environment variable' \
Zbigniew Jędrzejewski-Szmek 436654
+      compadd "$@" ${suf} - ${${(f)"$(systemctl show-environment)"}%%=*}
Zbigniew Jędrzejewski-Szmek 436654
   }
Zbigniew Jędrzejewski-Szmek 436654
 done
Zbigniew Jędrzejewski-Szmek 436654