Class: Bundler::UI::Shell
- Inherits:
-
Object
- Object
- Bundler::UI::Shell
- Defined in:
- lib/bundler/ui/shell.rb
Constant Summary collapse
- LEVELS =
%w[silent error warn confirm info debug].freeze
Instance Attribute Summary collapse
-
#shell ⇒ Object
writeonly
Sets the attribute shell.
Instance Method Summary collapse
- #add_color(string, *color) ⇒ Object
- #ask(msg) ⇒ Object
- #confirm(msg, newline = nil) ⇒ Object
- #debug(msg, newline = nil) ⇒ Object
- #debug? ⇒ Boolean
- #error(msg, newline = nil, color = :red) ⇒ Object
- #info(msg, newline = nil) ⇒ Object
-
#initialize(options = {}) ⇒ Shell
constructor
A new instance of Shell.
- #level(name = nil) ⇒ Object
- #level=(level) ⇒ Object
- #no? ⇒ Boolean
- #quiet? ⇒ Boolean
- #silence(&blk) ⇒ Object
- #trace(e, newline = nil, force = false) ⇒ Object
- #unprinted_warnings ⇒ Object
- #warn(msg, newline = nil, color = :yellow) ⇒ Object
- #yes?(msg) ⇒ Boolean
Constructor Details
#initialize(options = {}) ⇒ Shell
Returns a new instance of Shell.
12 13 14 15 16 17 |
# File 'lib/bundler/ui/shell.rb', line 12 def initialize( = {}) Thor::Base.shell = ["no-color"] ? Thor::Shell::Basic : nil @shell = Thor::Base.shell.new @level = ENV["DEBUG"] ? "debug" : "info" @warning_history = [] end |
Instance Attribute Details
#shell=(value) ⇒ Object (writeonly)
Sets the attribute shell
10 11 12 |
# File 'lib/bundler/ui/shell.rb', line 10 def shell=(value) @shell = value end |
Instance Method Details
#add_color(string, *color) ⇒ Object
19 20 21 |
# File 'lib/bundler/ui/shell.rb', line 19 def add_color(string, *color) @shell.set_color(string, *color) end |
#ask(msg) ⇒ Object
56 57 58 |
# File 'lib/bundler/ui/shell.rb', line 56 def ask(msg) @shell.ask(msg) end |
#confirm(msg, newline = nil) ⇒ Object
27 28 29 |
# File 'lib/bundler/ui/shell.rb', line 27 def confirm(msg, newline = nil) tell_me(msg, :green, newline) if level("confirm") end |
#debug(msg, newline = nil) ⇒ Object
44 45 46 |
# File 'lib/bundler/ui/shell.rb', line 44 def debug(msg, newline = nil) tell_me(msg, nil, newline) if debug? end |
#debug? ⇒ Boolean
48 49 50 |
# File 'lib/bundler/ui/shell.rb', line 48 def debug? level("debug") end |
#error(msg, newline = nil, color = :red) ⇒ Object
39 40 41 42 |
# File 'lib/bundler/ui/shell.rb', line 39 def error(msg, newline = nil, color = :red) return unless level("error") tell_err(msg, color, newline) end |
#info(msg, newline = nil) ⇒ Object
23 24 25 |
# File 'lib/bundler/ui/shell.rb', line 23 def info(msg, newline = nil) tell_me(msg, nil, newline) if level("info") end |
#level(name = nil) ⇒ Object
73 74 75 76 77 78 79 |
# File 'lib/bundler/ui/shell.rb', line 73 def level(name = nil) return @level unless name unless index = LEVELS.index(name) raise "#{name.inspect} is not a valid level" end index <= LEVELS.index(@level) end |
#level=(level) ⇒ Object
68 69 70 71 |
# File 'lib/bundler/ui/shell.rb', line 68 def level=(level) raise ArgumentError unless LEVELS.include?(level.to_s) @level = level.to_s end |
#no? ⇒ Boolean
64 65 66 |
# File 'lib/bundler/ui/shell.rb', line 64 def no? @shell.no?(msg) end |
#quiet? ⇒ Boolean
52 53 54 |
# File 'lib/bundler/ui/shell.rb', line 52 def quiet? level("quiet") end |
#silence(&blk) ⇒ Object
87 88 89 |
# File 'lib/bundler/ui/shell.rb', line 87 def silence(&blk) with_level("silent", &blk) end |
#trace(e, newline = nil, force = false) ⇒ Object
81 82 83 84 85 |
# File 'lib/bundler/ui/shell.rb', line 81 def trace(e, newline = nil, force = false) return unless debug? || force msg = "#{e.class}: #{e.message}\n#{e.backtrace.join("\n ")}" tell_err(msg, nil, newline) end |
#unprinted_warnings ⇒ Object
91 92 93 |
# File 'lib/bundler/ui/shell.rb', line 91 def unprinted_warnings [] end |
#warn(msg, newline = nil, color = :yellow) ⇒ Object
31 32 33 34 35 36 37 |
# File 'lib/bundler/ui/shell.rb', line 31 def warn(msg, newline = nil, color = :yellow) return unless level("warn") return if @warning_history.include? msg @warning_history << msg tell_err(msg, color, newline) end |
#yes?(msg) ⇒ Boolean
60 61 62 |
# File 'lib/bundler/ui/shell.rb', line 60 def yes?(msg) @shell.yes?(msg) end |