2019-04-05 12:41:35 +03:00
#compdef systemd-analyze -*- shell-script -*-
2020-11-09 07:23:58 +03:00
# SPDX-License-Identifier: LGPL-2.1-or-later
2013-07-29 23:12:55 +04:00
2018-12-24 14:15:38 +03:00
(( $+functions[_systemd-analyze_log-level] )) ||
2019-04-05 12:39:14 +03:00
_systemd-analyze_log-level() {
local -a _levels
_levels=(debug info notice warning err crit alert emerg)
_describe -t level 'logging level' _levels || compadd "$@"
}
2013-08-23 07:25:28 +04:00
2018-12-24 14:15:38 +03:00
(( $+functions[_systemd-analyze_log-target] )) ||
2019-04-05 12:39:14 +03:00
_systemd-analyze_log-target() {
local -a _targets
_targets=(console journal kmsg journal-or-kmsg null)
_describe -t target 'logging target' _targets || compadd "$@"
}
2017-09-08 00:23:33 +03:00
2018-12-24 14:15:38 +03:00
(( $+functions[_systemd-analyze_verify] )) ||
2019-04-05 12:39:14 +03:00
_systemd-analyze_verify() {
_sd_unit_files
}
2014-07-22 05:11:56 +04:00
2018-12-24 14:15:38 +03:00
(( $+functions[_systemd-analyze_service-watchdogs] )) ||
2019-04-05 12:39:14 +03:00
_systemd-analyze_service-watchdogs() {
local -a _states
_states=(on off)
_describe -t state 'state' _states || compadd "$@"
}
2018-01-24 07:43:41 +03:00
2020-04-27 09:16:55 +03:00
(( $+functions[_systemd-analyze_cat-config] )) ||
_systemd-analyze_cat-config() {
_files -W '(/run/systemd/ /etc/systemd/ /usr/lib/systemd/)' -P 'systemd/'
}
(( $+functions[_systemd-analyze_security] )) ||
_systemd-analyze_security() {
_sd_unit_files
}
2018-12-24 14:15:38 +03:00
(( $+functions[_systemd-analyze_commands] )) ||
2019-04-05 12:39:14 +03:00
_systemd-analyze_commands(){
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)'
'dump:Dump server status'
2020-04-27 09:16:55 +03:00
'cat-config:Cat systemd config files'
'unit-files:List files and symlinks for units'
2019-04-05 12:39:14 +03:00
'unit-paths:List unit load paths'
2020-04-27 09:16:55 +03:00
'exit-status:List known exit statuses'
2019-04-05 12:39:14 +03:00
'syscall-filter:List syscalls in seccomp filter'
2020-04-27 09:16:55 +03:00
'condition:Evaluate Condition*= and Assert*= assignments'
2019-04-05 12:39:14 +03:00
'verify:Check unit files for correctness'
'calendar:Validate repetitive calendar time events'
2020-04-27 09:16:55 +03:00
'timestamp:Parse a systemd syntax timestamp'
'timespan:Parse a systemd syntax timespan'
'security:Analyze security settings of a service'
# 'log-level:Get/set systemd log threshold'
# 'log-target:Get/set systemd log target'
# 'service-watchdogs:Get/set service watchdog status'
2019-04-05 12:39:14 +03:00
)
2013-07-29 23:12:55 +04:00
2019-04-05 12:39:14 +03:00
if (( CURRENT == 1 )); then
_describe "options" _systemd_analyze_cmds
else
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
2013-08-23 07:25:28 +04:00
else
2019-04-05 12:39:14 +03:00
_message "unknown systemd-analyze command: $words[1]"
2013-08-23 07:25:28 +04:00
fi
fi
2019-04-05 12:39:14 +03:00
}
2013-07-29 23:12:55 +04:00
_arguments \
2015-01-12 23:43:45 +03:00
{-h,--help}'[Show help text]' \
'--version[Show package version]' \
'--system[Operate on system systemd instance]' \
'--user[Operate on user systemd instance]' \
2018-02-08 14:09:28 +03:00
'--global[Show global user instance config]' \
2015-01-12 23:43:45 +03:00
'--no-pager[Do not pipe output into a pager]' \
2015-01-26 17:29:14 +03:00
'--man=[Do (not) check for existence of man pages]:boolean:(1 0)' \
2013-07-29 23:12:55 +04:00
'--order[When generating graph for dot, show only order]' \
'--require[When generating graph for dot, show only requirement]' \
2015-01-12 23:43:45 +03:00
'--fuzz=[When printing the tree of the critical chain, print also services, which finished TIMESPAN earlier, than the latest in the branch]:TIMESPAN' \
'--from-pattern=[When generating a dependency graph, filter only origins]:GLOB' \
'--to-pattern=[When generating a dependency graph, filter only destinations]:GLOB' \
2014-07-22 05:11:56 +04:00
{-H+,--host=}'[Operate on remote host]:userathost:_sd_hosts_or_user_at_host' \
2015-04-22 21:07:38 +03:00
{-M+,--machine=}'[Operate on local container]:machine:_sd_machines' \
2018-12-24 14:15:38 +03:00
'*::systemd-analyze commands:_systemd-analyze_commands'