From: Marko Myllynen Date: Thu, 14 Nov 2013 04:02:23 +0000 (-0500) Subject: zsh-completion: add bootctl X-Git-Tag: v209~1435 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=51d0f1c9f6a378f3bf11179e5794dc2c13b49644 zsh-completion: add bootctl --- diff --git a/Makefile.am b/Makefile.am index 789ca026b..558aa1bf0 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1730,6 +1730,10 @@ bootctl_LDADD = \ bin_PROGRAMS += \ bootctl + +dist_zshcompletion_DATA += \ + shell-completion/zsh/_bootctl + endif # ------------------------------------------------------------------------------ diff --git a/shell-completion/zsh/_bootctl b/shell-completion/zsh/_bootctl new file mode 100644 index 000000000..7d2453cc2 --- /dev/null +++ b/shell-completion/zsh/_bootctl @@ -0,0 +1,25 @@ +#compdef bootctl + +(( $+functions[_bootctl_command] )) || _bootctl_command() +{ + local -a _bootctl_cmds + _bootctl_cmds=( + "status:Show current firmware and boot settings" + ) + 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.]' \ + '*::bootctl command:_bootctl_command'