Merge pull request #259 from lexinator/vagrant-improvments

call vagrant directly to get hostnames/box names
This commit is contained in:
Hideo Hattori 2014-09-16 22:57:27 +09:00
commit 45ce272126
1 changed files with 66 additions and 12 deletions

View File

@ -16,26 +16,33 @@
# #
# ------------------------------------------------------------------------------ # ------------------------------------------------------------------------------
# vagrant zsh completion
local -a _1st_arguments local -a _1st_arguments
_1st_arguments=( _1st_arguments=(
'box:Box commands' 'box:Box commands'
'connect:Connects to a shared, remote Vagrant environment'
'destroy:Destroys the vagrant environment' 'destroy:Destroys the vagrant environment'
'global-status:Shows the status of the global Vagrant environment.' 'docker-logs:Shows Docker logs'
'docker-run:Run one-off commands against a Docker container'
'global-status:Reports the status of all active Vagrant environments on the system'
'halt:Halts the currently running vagrant environment' 'halt:Halts the currently running vagrant environment'
'help:[TASK] Describe available tasks or one specific task' 'help:[TASK] Describe available tasks or one specific task'
'init:[box_name] [box_url] Initializes current folder for Vagrant usage' 'init:[box_name] [box_url] Initializes current folder for Vagrant usage'
'login:Authenticates against a Vagrant Cloud server to access protected boxes'
'package:Packages a vagrant environment for distribution' 'package:Packages a vagrant environment for distribution'
'plugin:Manage plugins' 'plugin:Manage plugins'
'provision:Run the provisioner' 'provision:Run the provisioner'
'reload:Reload the vagrant environment' 'reload:Reload the vagrant environment'
'resume:Resumes a suspend vagrant environment' 'resume:Resumes a suspend vagrant environment'
'share:Shares the Vagrant environment and allows remote access'
'ssh:SSH into the currently running environment' 'ssh:SSH into the currently running environment'
'ssh-config:outputs .ssh/config valid syntax for connecting to this environment via ssh.' 'ssh-config:outputs .ssh/config valid syntax for connecting to this environment via ssh'
'status:Shows the status of the current Vagrant environment.' 'status:Shows the status of the current Vagrant environment'
'suspend:Suspends the currently running vagrant environment' 'suspend:Suspends the currently running vagrant environment'
'up:Creates the vagrant environment' 'up:Creates the vagrant environment'
'version:Prints the Vagrant version information' 'version:Prints the currently installed Vagrant version and checks for new updates'
'--version:Prints the Vagrant version information'
) )
local -a _box_arguments local -a _box_arguments
@ -59,32 +66,79 @@ _plugin_arguments=(
__task_list () __task_list ()
{ {
local expl local expl
local -a tasks declare -a tasks
tasks=(box destroy global-status halt init package plugin provision reload resume ssh ssh_config status suspend up version) tasks=(box destroy global-status halt init package plugin provision \
reload resume ssh ssh_config status suspend up version)
_wanted tasks expl 'help' compadd $tasks _wanted tasks expl 'help' compadd $tasks
} }
__box_list () __box_list ()
{ {
_wanted application expl 'command' compadd $(command ls -1 ${VAGRANT_HOME:-$HOME/.vagrant.d}/boxes 2>/dev/null| sed -e 's/ /\\ /g') _wanted application expl 'command' compadd $(command vagrant box list | \
awk '{print $1}' | \
sed -e 's/ /\\ /g')
} }
__plugin_list () __plugin_list ()
{ {
_wanted application expl 'command' compadd $(command vagrant plugin list 2>/dev/null| cut -d' ' -f1) _wanted application expl 'command' compadd $(command vagrant plugin list \
2>/dev/null| cut -d' ' -f1)
}
_vagrant_caching_policy()
{
local reg_time comp_time check_file
case "${1##*/}" in
VAGRANT_VMS)
if [[ -z $VAGRANT_CWD ]]; then
check_file=./Vagrantfile
else
check_file=$VAGRANT_CWD/Vagrantfile
fi
;;
*)
echo "unknown type: $1"
return -1
;;
esac
case $(uname -s) in
Darwin) STATCMD="stat -f '%c'" ;;
*) STATCMD="stat -c '%Z'" ;;
esac
reg_time=${$(${(z)STATCMD} $check_file):Q}
comp_time=${$(${(z)STATCMD} $1):Q}
return $(( reg_time < comp_time ))
} }
__vm_list () __vm_list ()
{ {
_wanted application expl 'command' compadd $(command grep Vagrantfile -oe '^[^#]*\.vm\.define * ['\''":]\?\([a-zA-Z0-9\-_]\+\)['\''"]\?' 2>/dev/null | awk '{print $NF}' | sed 's/'\''//g'|sed 's/\"//g'|sed 's/^://' ) local cache_policy
zstyle -s ":completion:${curcontext}:" cache-policy cache_policy
zstyle ":completion:${curcontext}:" cache-policy \
${cache_policy:-_vagrant_caching_policy}
# Cache the list of VMs available
if ( [[ ${+_vagrant_vms} -eq 0 ]] || _cache_invalid VAGRANT_VMS ) &&
! _retrieve_cache VAGRANT_VMS;
then
_vagrant_vms=( $(_call_program path-all "vagrant status | \
awk '{print \$1}' | \
egrep -v '^$|^(Current|This|above|VM,)$'" ) )
_store_cache VAGRANT_VMS _vagrant_vms
fi
_wanted application expl 'command' compadd $_vagrant_vms
} }
__vagrant-box () __vagrant-box ()
{ {
local curcontext="$curcontext" state line local curcontext="$curcontext" state line
local -A opt_args typeset -A opt_args
_arguments -C \ _arguments -C \
':command:->command' \ ':command:->command' \
@ -163,7 +217,7 @@ case $state in
(plugin) (plugin)
__vagrant-plugin __vagrant-plugin
;; ;;
(up|provision|package|destroy|reload|ssh|halt|resume|status) (up|provision|package|destroy|reload|ssh|halt|resume|status|suspend)
_arguments ':feature:__vm_list' _arguments ':feature:__vm_list'
esac esac
;; ;;