add completion for fwupdmgr 1.2.9 (https://github.com/hughsie/fwupd)
This commit is contained in:
		
							parent
							
								
									d1c0b5d50d
								
							
						
					
					
						commit
						5b5e9fda12
					
				|  | @ -0,0 +1,293 @@ | |||
| #compdef fwupdmgr | ||||
| # ------------------------------------------------------------------------------ | ||||
| # Description | ||||
| # ----------- | ||||
| # | ||||
| #  Completion script for fwupdmgr 1.2.9 (https://github.com/hughsie/fwupd). | ||||
| # | ||||
| # ------------------------------------------------------------------------------ | ||||
| # Authors | ||||
| # ------- | ||||
| # | ||||
| #  * Julien Nicoulaud <julien.nicoulaud@gmail.com> | ||||
| # | ||||
| # ------------------------------------------------------------------------------ | ||||
| 
 | ||||
| 
 | ||||
| _fwupdmgr() { | ||||
| 
 | ||||
|   local context state state_descr line | ||||
|   typeset -A opt_args | ||||
| 
 | ||||
|   _arguments -C \ | ||||
|     '(- : *)'{-h,--help}'[display help information]' \ | ||||
|     '(- : *)'{-v,--version}'[display version information]' \ | ||||
|     {-v,--verbose}'[show extra debugging information]' \ | ||||
|     --offline'[schedule installation for next reboot when possible]' \ | ||||
|     --allow-reinstall'[allow re-installing existing firmware versions]' \ | ||||
|     --allow-older'[allow downgrading firmware versions]' \ | ||||
|     --force'[override warnings and force the action]' \ | ||||
|     '(-y, --assume-yes)'{-y,--assume-yes}'[answer yes to all questions]' \ | ||||
|     --sign'[sign the uploaded data with the client certificate]' \ | ||||
|     --no-unreported-check'[do not check for unreported history]' \ | ||||
|     --no-metadata-check'[do not check for old metadata]' \ | ||||
|     --no-reboot-check'[do not check for reboot after update]' \ | ||||
|     --no-history'[do not write to the history database]' \ | ||||
|     --show-all-devices'[show devices that are not updatable]' \ | ||||
|     '(-): :->command' \ | ||||
|     '(-)*:: :->arguments' \ | ||||
|   && ret=0 | ||||
| 
 | ||||
|   case $state in | ||||
|     (command) | ||||
|       _fwupdmgr_commands | ||||
|     ;; | ||||
|     (arguments) | ||||
|       curcontext=${curcontext%:*:*}:fwupdmgr-$words[1]: | ||||
|       if (( $+functions[_fwupdmgr_${words[1]}_args] )); then | ||||
|         _fwupdmgr_${words[1]}_args | ||||
|       else | ||||
|         _message "unknown command ${words[1]}" && ret=1 | ||||
|       fi | ||||
|     ;; | ||||
|     (*) | ||||
|       _message "unknown state $state" && ret=1 | ||||
|     ;; | ||||
|   esac | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_commands] )) || | ||||
| _fwupdmgr_commands() { | ||||
|   local commands=( | ||||
|     'activate:activate devices' | ||||
|     'clear-history:erase all firmware update history' | ||||
|     'clear-offline:clears any updates scheduled to be updated offline' | ||||
|     'clear-results:clears the results from the last update' | ||||
|     'disable-remote:disables a given remote' | ||||
|     'downgrade:downgrades the firmware on a device' | ||||
|     'enable-remote:enables a given remote' | ||||
|     'get-approved-firmware:gets the list of approved firmware' | ||||
|     'get-details:gets details about a firmware file' | ||||
|     'get-devices:get all devices that support firmware updates' | ||||
|     'get-history:show history of firmware updates' | ||||
|     'get-releases:gets the releases for a device' | ||||
|     'get-remotes:gets the configured remotes' | ||||
|     'get-results:gets the results from the last update' | ||||
|     'get-topology:get all devices according to the system topology' | ||||
|     'get-updates:gets the list of updates for connected hardware' | ||||
|     'install:install a firmware file on this hardware' | ||||
|     'modify-config:modifies a daemon configuration value' | ||||
|     'modify-remote:modifies a given remote' | ||||
|     'refresh:refresh metadata from remote server' | ||||
|     'report-history:share firmware history with the developers' | ||||
|     'set-approved-firmware:sets the list of approved firmware' | ||||
|     'unlock:unlocks the device for firmware access' | ||||
|     'update:updates all firmware to latest versions available' | ||||
|     'verify:gets the cryptographic hash of the dumped firmware' | ||||
|     'verify-update:update the stored metadata with current ROM contents' | ||||
|   ) | ||||
|   _describe -t commands commands commands | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_activate_args] )) || | ||||
| _fwupdmgr_activate_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_clear-history_args] )) || | ||||
| _fwupdmgr_clear-history_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_clear-results_args] )) || | ||||
| _fwupdmgr_clear-results_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_disable-remote_args] )) || | ||||
| _fwupdmgr_disable-remote_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_remote_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_downgrade_args] )) || | ||||
| _fwupdmgr_downgrade_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_enable-remote_args] )) || | ||||
| _fwupdmgr_enable-remote_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_remote_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-approved-firmware_args] )) || | ||||
| _fwupdmgr_get-approved-firmware_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-details_args] )) || | ||||
| _fwupdmgr_get-details_args() { | ||||
|   _files | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-devices_args] )) || | ||||
| _fwupdmgr_get-devices_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-history_args] )) || | ||||
| _fwupdmgr_get-history_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-releases_args] )) || | ||||
| _fwupdmgr_get-releases_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-remotes_args] )) || | ||||
| _fwupdmgr_get-remotes_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-results_args] )) || | ||||
| _fwupdmgr_get-results_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-topology_args] )) || | ||||
| _fwupdmgr_get-topology_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_get-updates_args] )) || | ||||
| _fwupdmgr_get-updates_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_install_args] )) || | ||||
| _fwupdmgr_install_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_files' \ | ||||
|     '2: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_TODO_args] )) || | ||||
| _fwupdmgr_TODO_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_modify-config_args] )) || | ||||
| _fwupdmgr_modify-config_args() { | ||||
|   local ret=1 | ||||
|   if compset -P '*,'; then | ||||
|     _wanted config-value expl 'config value' _fwupdmgr_config_values ${IPREFIX%=} && ret=0 | ||||
|   else | ||||
|     _wanted config-key expl 'config key' _fwupdmgr_config_keys -qS, && ret=0 | ||||
|   fi | ||||
|   return ret | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_modify-remote_args] )) || | ||||
| _fwupdmgr_modify-remote_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_remote_ids' \ | ||||
|     '2: :_fwupdmgr_remote_keys' \ | ||||
|     '3: :_fwupdmgr_remote_values' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_refresh_args] )) || | ||||
| _fwupdmgr_refresh_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_files' \ | ||||
|     '2:file signature:' \ | ||||
|     '3: :_fwupdmgr_remote_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_report-history_args] )) || | ||||
| _fwupdmgr_report-history_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_set-approved-firmware_args] )) || | ||||
| _fwupdmgr_set-approved-firmware_args() { | ||||
|   _message 'checksum' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_unlock_args] )) || | ||||
| _fwupdmgr_unlock_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_update_args] )) || | ||||
| _fwupdmgr_update_args() { | ||||
|   _message 'no more arguments' && ret=0 | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_verify_args] )) || | ||||
| _fwupdmgr_verify_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_verify-update_args] )) || | ||||
| _fwupdmgr_verify-update_args() { | ||||
|   _arguments -C \ | ||||
|     '1: :_fwupdmgr_device_ids' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_device_ids] )) || | ||||
| _fwupdmgr_device_ids() { | ||||
|   # TODO add device name as description | ||||
|   local devices=($(_call_program devices fwupdmgr get-devices | grep -Po 'DeviceId:\s+\K(.*)')) | ||||
|   _describe -t devices 'device ID' devices | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_remote_ids] )) || | ||||
| _fwupdmgr_remote_ids() { | ||||
|   # TODO add remote description | ||||
|   local remotes=($(_call_program remotes fwupdmgr get-remotes | grep -Po 'Remote ID:\s+\K(.*)')) | ||||
|   _describe -t remotes 'remote ID' remotes | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_checksums] )) || | ||||
| _fwupdmgr_checksums() { | ||||
|   _guard '[^\-]#' 'checksum' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_config_keys] )) || | ||||
| _fwupdmgr_config_keys() { | ||||
|   _guard '[^\-]#' 'config key' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_config_values] )) || | ||||
| _fwupdmgr_config_values() { | ||||
|   _guard '[^\-]#' 'config value' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_remote_keys] )) || | ||||
| _fwupdmgr_remote_keys() { | ||||
|   _guard '[^\-]#' 'remote key' | ||||
| } | ||||
| 
 | ||||
| (( $+functions[_fwupdmgr_remote_values] )) || | ||||
| _fwupdmgr_remote_values() { | ||||
|   _guard '[^\-]#' 'remote value' | ||||
| } | ||||
| 
 | ||||
| _fwupdmgr "$@" | ||||
| 
 | ||||
| # Local Variables: | ||||
| # mode: Shell-Script | ||||
| # sh-indentation: 2 | ||||
| # indent-tabs-mode: nil | ||||
| # sh-basic-offset: 2 | ||||
| # End: | ||||
| # vim: ft=zsh sw=2 ts=2 et | ||||
		Loading…
	
		Reference in New Issue