class Closure::Compiler
much to see here.
The Closure::Compiler is a basic wrapper around the actual JAR. There’s not
def command
def command [@java, '-jar', @jar, @options].flatten.join(' ') end
def compile(io)
JavaScript as a string or yields an IO object containing the response to a
Can compile a JavaScript string or open IO object. Returns the compiled
def compile(io) result, error = nil, nil pid = Closure::Popen.popen(*command) do |stdin, stdout, stderr| if io.respond_to? :read while buffer = io.read(4096) do stdin.write(buffer) end else stdin.write(io.to_s) end stdin.close out_thread = Thread.new { result = stdout.read } err_thread = Thread.new { error = stderr.read } out_thread.join and err_thread.join yield(StringIO.new(result)) if block_given? end Process.waitpid pid raise Error, error unless $?.success? result end
def initialize(options={})
def initialize(options={}) @java = options.delete(:java) || JAVA_COMMAND @jar = options.delete(:jar_file) || COMPILER_JAR @options = serialize_options(options) end
def serialize_options(options)
def serialize_options(options) options.map {|k, v| ["--#{k}", v.to_s] }.flatten end