Rvm2::Ui
Example output
Using :console handler:
[ ] Command 1
Log output 1
[x] Command 2
[ ] Command 3
Log output 2
[v] Command 3
[v] Command 1
Installation
Get the gem:
gem install rvm2-ui
Load it:
require 'rvm2/ui'
Usage
Different handlers can be loaded using pluginator group rvm2 type ui/output:
Rvm2::Ui.get(type = :console, rvm2_plugins = nil, *args)
the args will be passed to the handler constructor.
To get the default console output:
@ui = Rvm2::Ui.get
Wrapping code blocks
The command will produce checklist like item:
@ui.command('display name') do do_something end
Example output with :console output - before finish:
[ ] Group 1
after finish:
[v] Group 1
Logging output
The log allows giving messages, warnings and errors to user:
log(message, type = :log)
Supported types are :log, :warn, :warn_important, :error, any other type might be supported
or should be handled as :log with the capitalized type as prefix.
Example:
@ui.log("something went wrong", :error)
Would produce with console:
Error: something went wrong
Handling extra outputs
In some cases like running shell commands an stdout and stderr objects are available with IO
interface allowing proper output handling (not injecting text in random places):
@ui.command("test") do
@ui.stderr.puts("debugging output")
end
would produce with :console:
[ ] test
debugging output
[v] test
Combining multiple outputs
In some cases it might be useful to send the same output to different targets like UI and log:
Rvm2::UI.multi(rvm2_plugins)
Example use:
@ui = Rvm2::UI.multi
@ui.add(:console)
@ui.add(:log, "my_app.log")
@ui.log("text")
@ui.remove # removes the last added logger
Example - temporarily use logger:
@ui = Rvm2::UI.multi
@ui.add(:console)
@ui.with(:log, "my_app.log") do
@ui.log("text")
end
In both examples the output will be written to both standard output and log file.