summaryrefslogtreecommitdiff
path: root/shell-completion/bash/systemctl
diff options
context:
space:
mode:
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2013-04-10 19:31:58 -0400
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2013-04-10 19:47:21 -0400
commitc2e09812e9c088f1582ce542e43f6b5743b2e4fe (patch)
tree7b1916c2714487f17c0688e8d673591908843e18 /shell-completion/bash/systemctl
parent79c1638303142b81e1b72dd5bde0c656ccf19999 (diff)
shell-completion: show failed units as candidates for start
Also show disabled units as candidates for reenable, since it works and one may want to do enable-or-reenable in one line.
Diffstat (limited to 'shell-completion/bash/systemctl')
-rw-r--r--shell-completion/bash/systemctl9
1 files changed, 7 insertions, 2 deletions
diff --git a/shell-completion/bash/systemctl b/shell-completion/bash/systemctl
index b019d6aecf..aba76f6543 100644
--- a/shell-completion/bash/systemctl
+++ b/shell-completion/bash/systemctl
@@ -46,7 +46,7 @@ __get_all_units () { __systemctl $1 list-units --all \
__get_active_units () { __systemctl $1 list-units \
| { while read -r a b; do echo " $a"; done; }; }
__get_inactive_units () { __systemctl $1 list-units --all \
- | { while read -r a b c d; do [[ $c == "inactive" ]] && echo " $a"; done; }; }
+ | { while read -r a b c d; do [[ $c == "inactive" || $c == "failed " ]] && echo " $a"; done; }; }
__get_failed_units () { __systemctl $1 list-units \
| { while read -r a b c d; do [[ $c == "failed" ]] && echo " $a"; done; }; }
__get_enabled_units () { __systemctl $1 list-unit-files \
@@ -109,8 +109,9 @@ _systemctl () {
local -A VERBS=(
[ALL_UNITS]='is-active is-failed is-enabled status show mask preset'
- [ENABLED_UNITS]='disable reenable'
+ [ENABLED_UNITS]='disable'
[DISABLED_UNITS]='enable'
+ [REENABLABLE_UNITS]='reenable'
[FAILED_UNITS]='reset-failed'
[STARTABLE_UNITS]='start'
[STOPPABLE_UNITS]='stop condstop kill try-restart condrestart'
@@ -149,6 +150,10 @@ _systemctl () {
elif __contains_word "$verb" ${VERBS[DISABLED_UNITS]}; then
comps=$( __get_disabled_units $mode )
+ elif __contains_word "$verb" ${VERBS[REENABLABLE_UNITS]}; then
+ comps=$( __get_disabled_units $mode;
+ __get_enabled_units $mode )
+
elif __contains_word "$verb" ${VERBS[STARTABLE_UNITS]}; then
comps=$( __filter_units_by_property $mode CanStart yes \
$( __get_inactive_units $mode \