2013-07-29 23:12:55 +04:00
#compdef systemd-analyze
2013-08-23 07:25:28 +04:00
_systemd_analyze_set-log-level() {
local -a _levels
_levels=(debug info notice warning err crit alert emerg)
_describe -t level 'logging level' _levels || compadd "$@"
}
2013-07-29 23:12:55 +04:00
_systemd_analyze_command(){
local -a _systemd_analyze_cmds
# Descriptions taken from systemd-analyze --help.
_systemd_analyze_cmds=(
'time:Print time spent in the kernel before reaching userspace'
'blame:Print list of running units ordered by time to init'
'critical-chain:Print a tree of the time critical chain of units'
'plot:Output SVG graphic showing service initialization'
'dot:Dump dependency graph (in dot(1) format)'
2013-10-22 02:53:57 +04:00
'dump:Dump server status'
2013-08-23 07:25:28 +04:00
'set-log-level:Set systemd log threshold'
2013-07-29 23:12:55 +04:00
)
if (( CURRENT == 1 )); then
_describe "options" _systemd_analyze_cmds
else
2013-08-23 07:25:28 +04:00
local curcontext="$curcontext"
cmd="${${_systemd_analyze_cmds[(r)$words[1]:*]%%:*}}"
if (( $#cmd )); then
if (( $+functions[_systemd_analyze_$cmd] )) && (( CURRENT == 2 )); then
_systemd_analyze_$cmd
else
_message "no more options"
fi
else
_message "unknown systemd-analyze command: $words[1]"
fi
2013-07-29 23:12:55 +04:00
fi
}
_arguments \
{-h,--help}'[Show help text.]' \
'--user[Shows performance data of user sessions instead of the system manager.]' \
'--order[When generating graph for dot, show only order]' \
'--require[When generating graph for dot, show only requirement]' \
'*::systemd-analyze commands:_systemd_analyze_command'