mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Postponing the Bundler merge.
I faced a big issue about Bundler with ruby core. I have no time to resolve it issue before 2.5 final release. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61416 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
73bed03128
commit
7825e8363d
1100 changed files with 19 additions and 71581 deletions
|
@ -1,19 +0,0 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
require "bundler/ui"
|
||||
require "rubygems/user_interaction"
|
||||
|
||||
module Bundler
|
||||
module UI
|
||||
class RGProxy < ::Gem::SilentUI
|
||||
def initialize(ui)
|
||||
@ui = ui
|
||||
super()
|
||||
end
|
||||
|
||||
def say(message)
|
||||
@ui && @ui.debug(message)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
|
@ -1,144 +0,0 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
require "bundler/vendored_thor"
|
||||
|
||||
module Bundler
|
||||
module UI
|
||||
class Shell
|
||||
LEVELS = %w[silent error warn confirm info debug].freeze
|
||||
|
||||
attr_writer :shell
|
||||
|
||||
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"
|
||||
@warning_history = []
|
||||
end
|
||||
|
||||
def add_color(string, *color)
|
||||
@shell.set_color(string, *color)
|
||||
end
|
||||
|
||||
def info(msg, newline = nil)
|
||||
tell_me(msg, nil, newline) if level("info")
|
||||
end
|
||||
|
||||
def confirm(msg, newline = nil)
|
||||
tell_me(msg, :green, newline) if level("confirm")
|
||||
end
|
||||
|
||||
def warn(msg, newline = nil)
|
||||
return unless level("warn")
|
||||
return if @warning_history.include? msg
|
||||
@warning_history << msg
|
||||
|
||||
return tell_err(msg, :yellow, newline) if Bundler.feature_flag.error_on_stderr?
|
||||
tell_me(msg, :yellow, newline)
|
||||
end
|
||||
|
||||
def error(msg, newline = nil)
|
||||
return unless level("error")
|
||||
return tell_err(msg, :red, newline) if Bundler.feature_flag.error_on_stderr?
|
||||
tell_me(msg, :red, newline)
|
||||
end
|
||||
|
||||
def debug(msg, newline = nil)
|
||||
tell_me(msg, nil, newline) if debug?
|
||||
end
|
||||
|
||||
def debug?
|
||||
level("debug")
|
||||
end
|
||||
|
||||
def quiet?
|
||||
level("quiet")
|
||||
end
|
||||
|
||||
def ask(msg)
|
||||
@shell.ask(msg)
|
||||
end
|
||||
|
||||
def yes?(msg)
|
||||
@shell.yes?(msg)
|
||||
end
|
||||
|
||||
def no?
|
||||
@shell.no?(msg)
|
||||
end
|
||||
|
||||
def level=(level)
|
||||
raise ArgumentError unless LEVELS.include?(level.to_s)
|
||||
@level = level.to_s
|
||||
end
|
||||
|
||||
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
|
||||
|
||||
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
|
||||
|
||||
def silence(&blk)
|
||||
with_level("silent", &blk)
|
||||
end
|
||||
|
||||
def unprinted_warnings
|
||||
[]
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
# valimism
|
||||
def tell_me(msg, color = nil, newline = nil)
|
||||
msg = word_wrap(msg) if newline.is_a?(Hash) && newline[:wrap]
|
||||
if newline.nil?
|
||||
@shell.say(msg, color)
|
||||
else
|
||||
@shell.say(msg, color, newline)
|
||||
end
|
||||
end
|
||||
|
||||
def tell_err(message, color = nil, newline = nil)
|
||||
newline = message.to_s !~ /( |\t)\Z/ unless newline
|
||||
message = word_wrap(message) if newline.is_a?(Hash) && newline[:wrap]
|
||||
|
||||
color = nil if color && !$stderr.tty?
|
||||
|
||||
buffer = @shell.send(:prepare_message, message, *color)
|
||||
buffer << "\n" if newline && !message.to_s.end_with?("\n")
|
||||
|
||||
@shell.send(:stderr).print(buffer)
|
||||
@shell.send(:stderr).flush
|
||||
end
|
||||
|
||||
def strip_leading_spaces(text)
|
||||
spaces = text[/\A\s+/, 0]
|
||||
spaces ? text.gsub(/#{spaces}/, "") : text
|
||||
end
|
||||
|
||||
def word_wrap(text, line_width = @shell.terminal_width)
|
||||
strip_leading_spaces(text).split("\n").collect do |line|
|
||||
line.length > line_width ? line.gsub(/(.{1,#{line_width}})(\s+|$)/, "\\1\n").strip : line
|
||||
end * "\n"
|
||||
end
|
||||
|
||||
def with_level(level)
|
||||
original = @level
|
||||
@level = level
|
||||
yield
|
||||
ensure
|
||||
@level = original
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
|
@ -1,69 +0,0 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
module Bundler
|
||||
module UI
|
||||
class Silent
|
||||
attr_writer :shell
|
||||
|
||||
def initialize
|
||||
@warnings = []
|
||||
end
|
||||
|
||||
def add_color(string, color)
|
||||
string
|
||||
end
|
||||
|
||||
def info(message, newline = nil)
|
||||
end
|
||||
|
||||
def confirm(message, newline = nil)
|
||||
end
|
||||
|
||||
def warn(message, newline = nil)
|
||||
@warnings |= [message]
|
||||
end
|
||||
|
||||
def error(message, newline = nil)
|
||||
end
|
||||
|
||||
def debug(message, newline = nil)
|
||||
end
|
||||
|
||||
def debug?
|
||||
false
|
||||
end
|
||||
|
||||
def quiet?
|
||||
false
|
||||
end
|
||||
|
||||
def ask(message)
|
||||
end
|
||||
|
||||
def yes?(msg)
|
||||
raise "Cannot ask yes? with a silent shell"
|
||||
end
|
||||
|
||||
def no?
|
||||
raise "Cannot ask no? with a silent shell"
|
||||
end
|
||||
|
||||
def level=(name)
|
||||
end
|
||||
|
||||
def level(name = nil)
|
||||
end
|
||||
|
||||
def trace(message, newline = nil, force = false)
|
||||
end
|
||||
|
||||
def silence
|
||||
yield
|
||||
end
|
||||
|
||||
def unprinted_warnings
|
||||
@warnings
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue