vaguerent/bin/vagrant
2011-12-01 21:56:55 -08:00

34 lines
927 B
Ruby
Executable File

#!/usr/bin/env ruby
require 'vagrant'
require 'vagrant/cli'
env = Vagrant::Environment.new
begin
# Begin logging early here
env.logger.info("vagrant") { "`vagrant` invoked: #{ARGV.inspect}" }
# Disable color if the proper argument was passed
ui = nil
if !$stdout.tty? || ARGV.include?("--no-color")
ui = Vagrant::UI::Basic.new(env)
else
ui = Vagrant::UI::Colored.new(env)
end
# Set the UI early in case any errors are raised, and load
# the config immediately, so we gather any new commands from
# plugins
env.ui = ui
env.load!
# Kick start the CLI
Vagrant::CLI.start(ARGV, :env => env)
rescue Vagrant::Errors::VagrantError => e
opts = { :prefix => false }
env.ui.error e.message, opts if e.message
env.ui.error e.backtrace.join("\n"), opts if ENV["VAGRANT_DEBUG"]
exit e.status_code if e.respond_to?(:status_code)
exit 999 # An error occurred with no status code defined
end