mirror of
https://github.com/systemd/systemd
synced 2024-10-15 04:24:19 +00:00
20927c0eec
* fix error * remove options that are no longer supported * add missing options * stop completion if an option `--help` or `--version` is supplied [[[ zjs: a note for the reader: zshcompsys(1) in the section about optspecs in _arguments says: > Each of the forms above may be preceded by a list in parentheses of option names and argument num‐ > bers. If the given option is on the command line, the options and arguments indicated in parentheses > will not be offered. For example, ‘(-two -three 1)-one:...' completes the option ‘-one'; if this ap‐ > pears on the command line, the options -two and -three and the first ordinary argument will not be > completed after it. ‘(-foo):...' specifies an ordinary argument completion; -foo will not be com‐ > pleted if that argument is already present. > > Other items may appear in the list of excluded options to indicate various other items that should > not be applied when the current specification is matched: a single star (\*) for the rest arguments > (i.e. a specification of the form ‘\*:...'); a colon (:) for all normal (non-option-) arguments; and a > hyphen (-) for all options. For example, if ‘(\*)' appears before an option and the option appears on > the command line, the list of remaining arguments (those shown in the above table beginning with > ‘\*:') will not be completed. The intended effect of the change is to remove irrelevant completion matches from the completion. tl;dr: (- : ) prevents further completion ]]]
87 lines
3.1 KiB
Plaintext
87 lines
3.1 KiB
Plaintext
#compdef bootctl
|
|
# SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
__bootctl() {
|
|
bootctl --no-pager $@ 2>/dev/null
|
|
}
|
|
|
|
_bootctl_comp_ids() {
|
|
local expl
|
|
local -a ids
|
|
__bootctl list | while read a b; do
|
|
if [[ "$a" == "id:" ]]; then
|
|
ids+="$b"
|
|
fi
|
|
done
|
|
_wanted id expl 'boot id' compadd "$@" -a ids
|
|
}
|
|
|
|
_bootctl_set-default() {
|
|
_bootctl_comp_ids
|
|
}
|
|
|
|
_bootctl_set-oneshot() {
|
|
_bootctl_comp_ids
|
|
}
|
|
|
|
_bootctl_unlink() {
|
|
_bootctl_comp_ids
|
|
}
|
|
|
|
_bootctl_reboot-to-firmware() {
|
|
local -a _completions
|
|
_completions=( yes no )
|
|
typeset -U _completions
|
|
_describe 'possible values' _completions
|
|
}
|
|
|
|
(( $+functions[_bootctl_commands] )) || _bootctl_commands()
|
|
{
|
|
local -a _bootctl_cmds
|
|
_bootctl_cmds=(
|
|
"status:Show status of installed systemd-boot and EFI variables"
|
|
"install:Install systemd-boot to the ESP and EFI variables"
|
|
"update:Update systemd-boot in the ESP and EFI variables"
|
|
"remove:Remove systemd-boot from the ESP and EFI variables"
|
|
"is-installed:Test whether systemd-boot is installed in the ESP"
|
|
"random-seed:Initialize random seed in ESP and EFI variables"
|
|
"systemd-efi-options:Query or set system options string in EFI variable"
|
|
"reboot-to-firmware:Query or set reboot-to-firmware EFI flag"
|
|
"list:List boot loader entries"
|
|
"set-default:Set the default boot loader entry"
|
|
"set-oneshot:Set the default boot loader entry only for the next boot"
|
|
"set-timeout:Set the menu timeout"
|
|
"set-timeout-oneshot:Set the menu timeout for the next boot only"
|
|
"unlink:Remove boot loader entry"
|
|
"cleanup:Remove files in ESP not referenced in any boot entry"
|
|
)
|
|
if (( CURRENT == 1 )); then
|
|
_describe -t commands 'bootctl command' _bootctl_cmds || compadd "$@"
|
|
else
|
|
local curcontext="$curcontext"
|
|
cmd="${${_bootctl_cmds[(r)$words[1]:*]%%:*}}"
|
|
if (( $+functions[_bootctl_$cmd] )); then
|
|
_bootctl_$cmd
|
|
else
|
|
_message "no more options"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
_arguments \
|
|
'(- *)'{-h,--help}'[Prints a short help text and exits.]' \
|
|
'(- *)--version[Prints a short version string and exits.]' \
|
|
'--esp-path=[Path to the EFI System Partition (ESP)]:path:_directories' \
|
|
'--boot-path=[Path to the $BOOT partition]:path:_directories' \
|
|
'(-p --print-esp-path)'{-p,--print-esp-path}'[Print path to the EFI system partition]' \
|
|
'(-x --print-boot-path)'{-x,--print-boot-path}'[Print path to the $BOOT partition]' \
|
|
'--make-machine-id-directory=[Control creation and deletion of the top-level machine ID directory.]:options:(yes no auto)' \
|
|
'--no-variables[Do not touch EFI variables]' \
|
|
'--no-pager[Do not pipe output into a pager]' \
|
|
'--graceful[Do not fail when locating ESP or writing fails]' \
|
|
'--dry-run[Dry run (unlink and cleanup)]' \
|
|
'--root=[Operate under the specified directory]:PATH' \
|
|
'--image=[Operate on the specified image]:PATH' \
|
|
'--install-source[Where to pick files when using --root=/--image=]:options:(image host auto)' \
|
|
'*::bootctl command:_bootctl_commands'
|