vagrant/plugins/commands/destroy/command.rb

72 lines
2.2 KiB
Ruby
Raw Normal View History

2012-04-19 20:59:48 +00:00
module VagrantPlugins
module CommandDestroy
class Command < Vagrant.plugin("1", :command)
2010-08-25 06:05:40 +00:00
def execute
options = {}
2011-12-17 19:05:49 +00:00
opts = OptionParser.new do |opts|
opts.banner = "Usage: vagrant destroy [vm-name]"
opts.separator ""
opts.on("-f", "--force", "Destroy without confirmation.") do |f|
options[:force] = f
end
2011-12-17 19:05:49 +00:00
end
# Parse the options
argv = parse_options(opts)
return if !argv
@logger.debug("'Destroy' each target VM...")
with_target_vms(argv, :reverse => true) do |vm|
vm.action(:destroy)
next
2010-08-25 06:05:40 +00:00
if vm.created?
# Boolean whether we should actually go through with the destroy
# or not. This is true only if the "--force" flag is set or if the
# user confirms it.
do_destroy = false
if options[:force]
do_destroy = true
else
choice = nil
begin
choice = @env.ui.ask(I18n.t("vagrant.commands.destroy.confirmation",
:name => vm.name))
rescue Interrupt
# Ctrl-C was pressed (or SIGINT). We just exit immediately
# with a non-zero exit status.
return 1
2012-04-19 20:59:48 +00:00
rescue Vagrant::Errors::UIExpectsTTY
# We raise a more specific error but one which basically
# means the same thing.
2012-04-19 20:59:48 +00:00
raise Vagrant::Errors::DestroyRequiresForce
end
do_destroy = choice.upcase == "Y"
end
if do_destroy
@logger.info("Destroying: #{vm.name}")
vm.destroy
else
@logger.info("Not destroying #{vm.name} since confirmation was declined.")
@env.ui.success(I18n.t("vagrant.commands.destroy.will_not_destroy",
:name => vm.name), :prefix => false)
end
2010-08-25 06:05:40 +00:00
else
2011-12-17 19:05:49 +00:00
@logger.info("Not destroying #{vm.name}, since it isn't created.")
2011-12-27 02:14:09 +00:00
vm.ui.info I18n.t("vagrant.commands.common.vm_not_created")
2010-08-25 06:05:40 +00:00
end
end
# Success, exit status 0
0
end
2010-08-25 06:05:40 +00:00
end
end
end