2011-12-17 19:53:26 +00:00
|
|
|
require 'optparse'
|
|
|
|
|
2012-04-19 20:59:48 +00:00
|
|
|
module VagrantPlugins
|
|
|
|
module CommandReload
|
|
|
|
class Command < Vagrant::Command::Base
|
2012-04-20 04:33:26 +00:00
|
|
|
# We assume that the `up` plugin exists and that we'll have access
|
|
|
|
# to this.
|
|
|
|
include Vagrant::CommandUp::StartMixins
|
2012-03-10 21:54:59 +00:00
|
|
|
|
2010-08-25 06:30:32 +00:00
|
|
|
def execute
|
2011-12-17 19:53:26 +00:00
|
|
|
options = {}
|
2012-03-11 22:32:17 +00:00
|
|
|
|
|
|
|
opts = OptionParser.new do |opts|
|
2011-12-17 19:53:26 +00:00
|
|
|
opts.banner = "Usage: vagrant reload [vm-name]"
|
2012-03-10 21:54:59 +00:00
|
|
|
opts.separator ""
|
|
|
|
build_start_options(opts, options)
|
2011-12-17 19:53:26 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# Parse the options
|
|
|
|
argv = parse_options(opts)
|
|
|
|
return if !argv
|
|
|
|
|
|
|
|
@logger.debug("'reload' each target VM...")
|
2012-03-11 22:32:17 +00:00
|
|
|
with_target_vms(argv) do |vm|
|
2010-08-25 06:30:32 +00:00
|
|
|
if vm.created?
|
2011-12-17 19:53:26 +00:00
|
|
|
@logger.info("Reloading: #{vm.name}")
|
2012-03-10 21:54:59 +00:00
|
|
|
vm.reload(options)
|
2010-08-25 06:30:32 +00:00
|
|
|
else
|
2011-12-17 19:53:26 +00:00
|
|
|
@logger.info("Not created: #{vm.name}. Not reloading.")
|
|
|
|
vm.ui.info I18n.t("vagrant.commands.common.vm_not_created")
|
2010-08-25 06:30:32 +00:00
|
|
|
end
|
|
|
|
end
|
2012-03-23 15:07:35 +00:00
|
|
|
|
|
|
|
# Success, exit status 0
|
|
|
|
0
|
|
|
|
end
|
2010-08-25 06:30:32 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|