mirror of
https://github.com/systemd/systemd.git
synced 2025-03-28 02:50:16 +03:00
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.
This commit is contained in:
parent
79c1638303
commit
c2e09812e9
3
TODO
3
TODO
@ -1,6 +1,5 @@
|
||||
Bugfixes:
|
||||
* systemctl completion doesn't want to start failed systemd-tmpfiles-setup.service
|
||||
systemctl --system show -p Fr<TAB> default.target doesn't show anything
|
||||
* systemctl --system show -p Fr<TAB> default.target doesn't show anything
|
||||
|
||||
* check systemd-tmpfiles for selinux context hookup for mknod(), symlink() and similar
|
||||
|
||||
|
@ -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 \
|
||||
|
@ -455,7 +455,7 @@ _filter_units_by_property() {
|
||||
}
|
||||
|
||||
_systemctl_active_units() {_sys_active_units=( $(__systemctl list-units | { while read a b; do echo " $a"; done; }) )}
|
||||
_systemctl_inactive_units(){_sys_inactive_units=($(__systemctl list-units --all | { while read a b c d; do [[ $c == "inactive" ]] && echo " $a"; done; }) )}
|
||||
_systemctl_inactive_units(){_sys_inactive_units=($(__systemctl list-units --all | { while read a b c d; do [[ $c == "inactive" || $c == "failed" ]] && echo " $a"; done; }) )}
|
||||
_systemctl_failed_units() {_sys_failed_units=( $(__systemctl list-units --failed | { while read a b; do echo " $a"; done; }) )}
|
||||
_systemctl_enabled_units() {_sys_enabled_units=( $(__systemctl list-unit-files | { while read a b; do [[ $b == "enabled" ]] && echo " $a"; done; }) )}
|
||||
_systemctl_disabled_units(){_sys_disabled_units=($(__systemctl list-unit-files | { while read a b; do [[ $b == "disabled" ]] && echo " $a"; done; }) )}
|
||||
@ -475,7 +475,8 @@ for fun in disable reenable ; do
|
||||
(( $+functions[_systemctl_$fun] )) || _systemctl_$fun()
|
||||
{
|
||||
_systemctl_enabled_units
|
||||
compadd "$@" -a - _sys_enabled_units
|
||||
_systemctl_disabled_units
|
||||
compadd "$@" -a - _sys_enabled_units _sys_disabled_units
|
||||
}
|
||||
done
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user