|
|
@ -1,7 +1,35 @@ |
|
|
|
#compdef vagrant |
|
|
|
#compdef vagrant |
|
|
|
#autoload |
|
|
|
#autoload |
|
|
|
|
|
|
|
|
|
|
|
# vagrant zsh completion, based on homebrew completion |
|
|
|
# vagrant zsh completion |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local -a _1st_arguments |
|
|
|
|
|
|
|
_1st_arguments=( |
|
|
|
|
|
|
|
'box:Box commands' |
|
|
|
|
|
|
|
'destroy:Destroys the vagrant environment' |
|
|
|
|
|
|
|
'halt:Halts the currently running vagrant environment' |
|
|
|
|
|
|
|
'help:[TASK] Describe available tasks or one specific task' |
|
|
|
|
|
|
|
'init:[box_name] [box_url] Initializes current folder for Vagrant usage' |
|
|
|
|
|
|
|
'package:Packages a vagrant environment for distribution' |
|
|
|
|
|
|
|
'provision:Run the provisioner' |
|
|
|
|
|
|
|
'reload:Reload the vagrant environment' |
|
|
|
|
|
|
|
'resume:Resumes a suspend vagrant environment' |
|
|
|
|
|
|
|
'ssh:SSH into the currently running environment' |
|
|
|
|
|
|
|
'ssh_config:outputs .ssh/config valid syntax for connecting to this environment via ssh.' |
|
|
|
|
|
|
|
'status:Shows the status of the current Vagrant environment.' |
|
|
|
|
|
|
|
'suspend:Suspends the currently running vagrant environment' |
|
|
|
|
|
|
|
'up:Creates the vagrant environment' |
|
|
|
|
|
|
|
'version:Prints the Vagrant version information' |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local -a _box_arguments |
|
|
|
|
|
|
|
_box_arguments=( |
|
|
|
|
|
|
|
'add:NAME URI Add a box to the system' |
|
|
|
|
|
|
|
'help:COMMAND Describe subcommands or one specific subcommand' |
|
|
|
|
|
|
|
'list:Lists all installed boxes' |
|
|
|
|
|
|
|
'remove:NAME Remove a box from the system' |
|
|
|
|
|
|
|
'repackage:NAME Repackage an installed box into a `.box` file.' |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
__task_list () |
|
|
|
__task_list () |
|
|
|
{ |
|
|
|
{ |
|
|
@ -36,43 +64,15 @@ __vagrant-box () |
|
|
|
(options) |
|
|
|
(options) |
|
|
|
case $line[1] in |
|
|
|
case $line[1] in |
|
|
|
(repackage|remove) |
|
|
|
(repackage|remove) |
|
|
|
_arguments \ |
|
|
|
_arguments ':feature:__box_list' |
|
|
|
-F'[Fetch from origin before performing finish]' \ |
|
|
|
|
|
|
|
-r'[Rebase instead of merge]'\ |
|
|
|
|
|
|
|
':feature:__box_list' |
|
|
|
|
|
|
|
;; |
|
|
|
;; |
|
|
|
esac |
|
|
|
esac |
|
|
|
;; |
|
|
|
;; |
|
|
|
esac |
|
|
|
esac |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
local -a _1st_arguments |
|
|
|
|
|
|
|
_1st_arguments=( |
|
|
|
|
|
|
|
'box:Box commands' |
|
|
|
|
|
|
|
'destroy:Destroys the vagrant environment' |
|
|
|
|
|
|
|
'halt:Halts the currently running vagrant environment' |
|
|
|
|
|
|
|
'help:[TASK] Describe available tasks or one specific task' |
|
|
|
|
|
|
|
'init:[box_name] [box_url] Initializes current folder for Vagrant usage' |
|
|
|
|
|
|
|
'package:Packages a vagrant environment for distribution' |
|
|
|
|
|
|
|
'provision:Run the provisioner' |
|
|
|
|
|
|
|
'reload:Reload the vagrant environment' |
|
|
|
|
|
|
|
'resume:Resumes a suspend vagrant environment' |
|
|
|
|
|
|
|
'ssh:SSH into the currently running environment' |
|
|
|
|
|
|
|
'ssh_config:outputs .ssh/config valid syntax for connecting to this environment via ssh.' |
|
|
|
|
|
|
|
'status:Shows the status of the current Vagrant environment.' |
|
|
|
|
|
|
|
'suspend:Suspends the currently running vagrant environment' |
|
|
|
|
|
|
|
'up:Creates the vagrant environment' |
|
|
|
|
|
|
|
'version:Prints the Vagrant version information' |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local -a _box_arguments |
|
|
|
|
|
|
|
_box_arguments=( |
|
|
|
|
|
|
|
'add:NAME URI Add a box to the system' |
|
|
|
|
|
|
|
'help:COMMAND Describe subcommands or one specific subcommand' |
|
|
|
|
|
|
|
'list:Lists all installed boxes' |
|
|
|
|
|
|
|
'remove:NAME Remove a box from the system' |
|
|
|
|
|
|
|
'repackage:NAME Repackage an installed box into a `.box` file.' |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local expl |
|
|
|
local expl |
|
|
|
local -a boxes installed_boxes |
|
|
|
local -a boxes installed_boxes |
|
|
@ -84,7 +84,6 @@ _arguments -C \ |
|
|
|
':command:->command' \ |
|
|
|
':command:->command' \ |
|
|
|
'*::options:->options' |
|
|
|
'*::options:->options' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case $state in |
|
|
|
case $state in |
|
|
|
(command) |
|
|
|
(command) |
|
|
|
_describe -t commands "gem subcommand" _1st_arguments |
|
|
|
_describe -t commands "gem subcommand" _1st_arguments |
|
|
@ -94,10 +93,7 @@ case $state in |
|
|
|
(options) |
|
|
|
(options) |
|
|
|
case $line[1] in |
|
|
|
case $line[1] in |
|
|
|
(help) |
|
|
|
(help) |
|
|
|
_arguments \ |
|
|
|
_arguments ':feature:__task_list' |
|
|
|
-F'[Fetch from origin before performing finish]' \ |
|
|
|
|
|
|
|
-r'[Rebase instead of merge]'\ |
|
|
|
|
|
|
|
':feature:__task_list' |
|
|
|
|
|
|
|
;; |
|
|
|
;; |
|
|
|
|
|
|
|
|
|
|
|
(box) |
|
|
|
(box) |
|
|
|