core: Add the MachineReadable UI, --machine-readable flag

This commit is contained in:
Mitchell Hashimoto 2013-11-24 11:04:54 -08:00
parent 305af26fa2
commit c5a7ab7953
2 changed files with 59 additions and 0 deletions

View File

@ -55,6 +55,12 @@ if ARGV.include?("--color")
opts[:ui_class] = Vagrant::UI::Colored opts[:ui_class] = Vagrant::UI::Colored
end end
# Highest precedence is if we have enabled machine-readable output
if ARGV.include?("--machine-readable")
ARGV.delete("--machine-readable")
opts[:ui_class] = Vagrant::Ui::MachineReadable
end
# Default to colored output # Default to colored output
opts[:ui_class] ||= Vagrant::UI::Colored opts[:ui_class] ||= Vagrant::UI::Colored

View File

@ -31,6 +31,14 @@ module Vagrant
define_method(method) { |*args| } define_method(method) { |*args| }
end end
# For machine-readable output.
#
# @param [String] type The type of the data
# @param [Array] data The data associated with the type
def machine(type, *data)
@logger.info("Machine: #{type} #{data.inspect}")
end
# Returns a new UI class that is scoped to the given resource name. # Returns a new UI class that is scoped to the given resource name.
# Subclasses can then use this scope name to do whatever they please. # Subclasses can then use this scope name to do whatever they please.
# #
@ -51,6 +59,43 @@ module Vagrant
end end
end end
class MachineReadable < Interface
def initialize
super
@lock = Mutex.new
end
def ask(*args)
super
# Machine-readable can't ask for input
raise Errors::UIExpectsTTY
end
def machine(type, *data)
opts = {}
opts = data.pop if data.last.kind_of?(Hash)
target = opts[:scope] || ""
# Prepare the data by replacing characters that aren't outputted
data.each_index do |i|
data[i].gsub!(",", "%!(VAGRANT_COMMA)")
data[i].gsub!("\n", "\\n")
data[i].gsub!("\r", "\\r")
end
@lock.synchronize do
safe_puts("#{Time.now.utc.to_i},#{target},#{type},#{data.join(",")}")
end
end
def scope(scope_name)
BasicScope.new(self, scope_name)
end
end
# This is a UI implementation that outputs the text as is. It # This is a UI implementation that outputs the text as is. It
# doesn't add any color. # doesn't add any color.
class Basic < Interface class Basic < Interface
@ -172,6 +217,14 @@ module Vagrant
# By default do nothing, these aren't logged # By default do nothing, these aren't logged
define_method(method) { |*args| @ui.send(method, *args) } define_method(method) { |*args| @ui.send(method, *args) }
end end
def machine(type, *data)
opts = {}
opts = data.pop if data.last.is_a?(Hash)
opts[:scope] = @scope
data << opts
@ui.machine(type, *data)
end
end end
# This is a UI implementation that outputs color for various types # This is a UI implementation that outputs color for various types