Class: Bundler::UI::Shell

Inherits:
Object
  • Object
show all
Defined in:
lib/bundler/ui/shell.rb

Constant Summary collapse

LEVELS =
%w(silent error warn confirm info debug)

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(options = {}) ⇒ Shell

Returns a new instance of Shell.



10
11
12
13
14
15
16
# File 'lib/bundler/ui/shell.rb', line 10

def initialize(options = {})
  if options["no-color"] || !STDOUT.tty?
    Thor::Base.shell = Thor::Shell::Basic
  end
  @shell = Thor::Base.shell.new
  @level = ENV['DEBUG'] ? "debug" : "info"
end

Instance Attribute Details

#shell=(value) ⇒ Object (writeonly)

Sets the attribute shell

Parameters:

  • value

    the value to set the attribute shell to.



8
9
10
# File 'lib/bundler/ui/shell.rb', line 8

def shell=(value)
  @shell = value
end

Instance Method Details

#ask(msg) ⇒ Object



47
48
49
# File 'lib/bundler/ui/shell.rb', line 47

def ask(msg)
  @shell.ask(msg)
end

#confirm(msg, newline = nil) ⇒ Object



22
23
24
# File 'lib/bundler/ui/shell.rb', line 22

def confirm(msg, newline = nil)
  tell_me(msg, :green, newline) if level("confirm")
end

#debug(msg, newline = nil) ⇒ Object



34
35
36
# File 'lib/bundler/ui/shell.rb', line 34

def debug(msg, newline = nil)
  tell_me(msg, nil, newline) if level("debug")
end

#debug?Boolean

Returns:

  • (Boolean)


38
39
40
41
# File 'lib/bundler/ui/shell.rb', line 38

def debug?
  # needs to be false instead of nil to be newline param to other methods
  level("debug")
end

#error(msg, newline = nil) ⇒ Object



30
31
32
# File 'lib/bundler/ui/shell.rb', line 30

def error(msg, newline = nil)
  tell_me(msg, :red, newline) if level("error")
end

#info(msg, newline = nil) ⇒ Object



18
19
20
# File 'lib/bundler/ui/shell.rb', line 18

def info(msg, newline = nil)
  tell_me(msg, nil, newline) if level("info")
end

#level(name = nil) ⇒ Object



64
65
66
# File 'lib/bundler/ui/shell.rb', line 64

def level(name = nil)
  name ? LEVELS.index(name) <= LEVELS.index(@level) : @level
end

#level=(level) ⇒ Object

Raises:

  • (ArgumentError)


59
60
61
62
# File 'lib/bundler/ui/shell.rb', line 59

def level=(level)
  raise ArgumentError unless LEVELS.include?(level.to_s)
  @level = level
end

#no?Boolean

Returns:

  • (Boolean)


55
56
57
# File 'lib/bundler/ui/shell.rb', line 55

def no?
  @shell.no?(msg)
end

#quiet?Boolean

Returns:

  • (Boolean)


43
44
45
# File 'lib/bundler/ui/shell.rb', line 43

def quiet?
  LEVELS.index(@level) <= LEVELS.index("warn")
end

#silenceObject



74
75
76
77
78
79
# File 'lib/bundler/ui/shell.rb', line 74

def silence
  old_level, @level = @level, "silent"
  yield
ensure
  @level = old_level
end

#trace(e, newline = nil) ⇒ Object



68
69
70
71
72
# File 'lib/bundler/ui/shell.rb', line 68

def trace(e, newline = nil)
  return unless debug?
  msg = "#{e.class}: #{e.message}\n#{e.backtrace.join("\n  ")}"
  tell_me(msg, nil, newline)
end

#warn(msg, newline = nil) ⇒ Object



26
27
28
# File 'lib/bundler/ui/shell.rb', line 26

def warn(msg, newline = nil)
  tell_me(msg, :yellow, newline) if level("warn")
end

#yes?(msg) ⇒ Boolean

Returns:

  • (Boolean)


51
52
53
# File 'lib/bundler/ui/shell.rb', line 51

def yes?(msg)
  @shell.yes?(msg)
end