chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
shell-completion/bash: add add-wants and add-requires
[elogind.git]
/
shell-completion
/
bash
/
systemd-analyze
diff --git
a/shell-completion/bash/systemd-analyze
b/shell-completion/bash/systemd-analyze
index 5bd676866b425eebe6a7ef41bc72089ea101c8af..77d1b542a238efd9669ece79d1b163170544b7d2 100644
(file)
--- a/
shell-completion/bash/systemd-analyze
+++ b/
shell-completion/bash/systemd-analyze
@@
-25,21
+25,31
@@
__contains_word () {
done
}
done
}
+__get_machines() {
+ local a b
+ machinectl list --no-legend --no-pager | { while read a b; do echo " $a"; done; };
+}
+
_systemd_analyze() {
local i verb comps
local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]}
_systemd_analyze() {
local i verb comps
local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]}
- local OPTS='--help --version --system --user --from-pattern --to-pattern --order --require'
+
+ local -A OPTS=(
+ [STANDALONE]='--help --version --system --user --from-pattern --to-pattern --order --require --no-pager'
+ [ARG]='-H --host -M --machine'
+ )
local -A VERBS=(
local -A VERBS=(
- [
NO_OPTION]='time blame plot
'
+ [
STANDALONE]='time blame plot dump
'
[CRITICAL_CHAIN]='critical-chain'
[DOT]='dot'
[LOG_LEVEL]='set-log-level'
[CRITICAL_CHAIN]='critical-chain'
[DOT]='dot'
[LOG_LEVEL]='set-log-level'
+ [VERIFY]='verify'
)
_init_completion || return
)
_init_completion || return
- for ((i=0;
$i <= $
COMP_CWORD; i++)); do
+ for ((i=0;
i <
COMP_CWORD; i++)); do
if __contains_word "${COMP_WORDS[i]}" ${VERBS[*]} &&
! __contains_word "${COMP_WORDS[i-1]}" ${OPTS[ARG]}; then
verb=${COMP_WORDS[i]}
if __contains_word "${COMP_WORDS[i]}" ${VERBS[*]} &&
! __contains_word "${COMP_WORDS[i-1]}" ${OPTS[ARG]}; then
verb=${COMP_WORDS[i]}
@@
-47,6
+57,19
@@
_systemd_analyze() {
fi
done
fi
done
+ if __contains_word "$prev" ${OPTS[ARG]}; then
+ case $prev in
+ --host|-H)
+ comps=$(compgen -A hostname)
+ ;;
+ --machine|-M)
+ comps=$( __get_machines )
+ ;;
+ esac
+ COMPREPLY=( $(compgen -W '$comps' -- "$cur") )
+ return 0
+ fi
+
if [[ -z $verb && $cur = -* ]]; then
COMPREPLY=( $(compgen -W '${OPTS[*]}' -- "$cur") )
return 0
if [[ -z $verb && $cur = -* ]]; then
COMPREPLY=( $(compgen -W '${OPTS[*]}' -- "$cur") )
return 0
@@
-55,7
+78,7
@@
_systemd_analyze() {
if [[ -z $verb ]]; then
comps=${VERBS[*]}
if [[ -z $verb ]]; then
comps=${VERBS[*]}
- elif __contains_word "$verb" ${VERBS[
NO_OPTION
]}; then
+ elif __contains_word "$verb" ${VERBS[
STANDALONE
]}; then
if [[ $cur = -* ]]; then
comps='--help --version --system --user'
fi
if [[ $cur = -* ]]; then
comps='--help --version --system --user'
fi
@@
-77,6
+100,14
@@
_systemd_analyze() {
comps='debug info notice warning err crit alert emerg'
fi
comps='debug info notice warning err crit alert emerg'
fi
+ elif __contains_word "$verb" ${VERBS[VERIFY]}; then
+ if [[ $cur = -* ]]; then
+ comps='--help --version --system --user --no-man'
+ else
+ comps=$( compgen -A file -- "$cur" )
+ compopt -o filenames
+ fi
+
fi
COMPREPLY=( $(compgen -W '$comps' -- "$cur") )
fi
COMPREPLY=( $(compgen -W '$comps' -- "$cur") )