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].freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

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(options = {})
  Thor::Base.shell = options["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

Parameters:

  • value

    the value to set the attribute shell to.



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

Returns:

  • (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

Raises:

  • (ArgumentError)


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

Returns:

  • (Boolean)


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

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

#quiet?Boolean

Returns:

  • (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_me(msg, nil, newline)
end

#unprinted_warningsObject



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

Returns:

  • (Boolean)


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

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