[rubygems/rubygems] Fix circular require warning
https://github.com/rubygems/rubygems/commit/241d0aafcd
This commit is contained in:
parent
d6cb62a88f
commit
53571de8e9
@ -69,99 +69,101 @@
|
|||||||
# end
|
# end
|
||||||
# end
|
# end
|
||||||
|
|
||||||
module Gem::Deprecate
|
module Gem
|
||||||
def self.skip # :nodoc:
|
module Deprecate
|
||||||
@skip ||= false
|
def self.skip # :nodoc:
|
||||||
end
|
@skip ||= false
|
||||||
|
|
||||||
def self.skip=(v) # :nodoc:
|
|
||||||
@skip = v
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
||||||
# Temporarily turn off warnings. Intended for tests only.
|
|
||||||
|
|
||||||
def skip_during
|
|
||||||
original = Gem::Deprecate.skip
|
|
||||||
Gem::Deprecate.skip = true
|
|
||||||
yield
|
|
||||||
ensure
|
|
||||||
Gem::Deprecate.skip = original
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.next_rubygems_major_version # :nodoc:
|
|
||||||
Gem::Version.new(Gem.rubygems_version.segments.first).bump
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
||||||
# Simple deprecation method that deprecates +name+ by wrapping it up
|
|
||||||
# in a dummy method. It warns on each call to the dummy method
|
|
||||||
# telling the user of +repl+ (unless +repl+ is :none) and the
|
|
||||||
# year/month that it is planned to go away.
|
|
||||||
|
|
||||||
def deprecate(name, repl, year, month)
|
|
||||||
class_eval do
|
|
||||||
old = "_deprecated_#{name}"
|
|
||||||
alias_method old, name
|
|
||||||
define_method name do |*args, &block|
|
|
||||||
klass = is_a? Module
|
|
||||||
target = klass ? "#{self}." : "#{self.class}#"
|
|
||||||
msg = [
|
|
||||||
"NOTE: #{target}#{name} is deprecated",
|
|
||||||
repl == :none ? " with no replacement" : "; use #{repl} instead",
|
|
||||||
format(". It will be removed on or after %4d-%02d.", year, month),
|
|
||||||
"\n#{target}#{name} called from #{Gem.location_of_caller.join(":")}",
|
|
||||||
]
|
|
||||||
warn "#{msg.join}." unless Gem::Deprecate.skip
|
|
||||||
send old, *args, &block
|
|
||||||
end
|
|
||||||
ruby2_keywords name if respond_to?(:ruby2_keywords, true)
|
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
##
|
def self.skip=(v) # :nodoc:
|
||||||
# Simple deprecation method that deprecates +name+ by wrapping it up
|
@skip = v
|
||||||
# in a dummy method. It warns on each call to the dummy method
|
|
||||||
# telling the user of +repl+ (unless +repl+ is :none) and the
|
|
||||||
# Rubygems version that it is planned to go away.
|
|
||||||
|
|
||||||
def rubygems_deprecate(name, replacement=:none)
|
|
||||||
class_eval do
|
|
||||||
old = "_deprecated_#{name}"
|
|
||||||
alias_method old, name
|
|
||||||
define_method name do |*args, &block|
|
|
||||||
klass = is_a? Module
|
|
||||||
target = klass ? "#{self}." : "#{self.class}#"
|
|
||||||
msg = [
|
|
||||||
"NOTE: #{target}#{name} is deprecated",
|
|
||||||
replacement == :none ? " with no replacement" : "; use #{replacement} instead",
|
|
||||||
". It will be removed in Rubygems #{Gem::Deprecate.next_rubygems_major_version}",
|
|
||||||
"\n#{target}#{name} called from #{Gem.location_of_caller.join(":")}",
|
|
||||||
]
|
|
||||||
warn "#{msg.join}." unless Gem::Deprecate.skip
|
|
||||||
send old, *args, &block
|
|
||||||
end
|
|
||||||
ruby2_keywords name if respond_to?(:ruby2_keywords, true)
|
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
# Deprecation method to deprecate Rubygems commands
|
##
|
||||||
def rubygems_deprecate_command(version = Gem::Deprecate.next_rubygems_major_version)
|
# Temporarily turn off warnings. Intended for tests only.
|
||||||
class_eval do
|
|
||||||
define_method "deprecated?" do
|
|
||||||
true
|
|
||||||
end
|
|
||||||
|
|
||||||
define_method "deprecation_warning" do
|
def skip_during
|
||||||
msg = [
|
original = Gem::Deprecate.skip
|
||||||
"#{command} command is deprecated",
|
Gem::Deprecate.skip = true
|
||||||
". It will be removed in Rubygems #{version}.\n",
|
yield
|
||||||
]
|
ensure
|
||||||
|
Gem::Deprecate.skip = original
|
||||||
|
end
|
||||||
|
|
||||||
alert_warning msg.join.to_s unless Gem::Deprecate.skip
|
def self.next_rubygems_major_version # :nodoc:
|
||||||
|
Gem::Version.new(Gem.rubygems_version.segments.first).bump
|
||||||
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Simple deprecation method that deprecates +name+ by wrapping it up
|
||||||
|
# in a dummy method. It warns on each call to the dummy method
|
||||||
|
# telling the user of +repl+ (unless +repl+ is :none) and the
|
||||||
|
# year/month that it is planned to go away.
|
||||||
|
|
||||||
|
def deprecate(name, repl, year, month)
|
||||||
|
class_eval do
|
||||||
|
old = "_deprecated_#{name}"
|
||||||
|
alias_method old, name
|
||||||
|
define_method name do |*args, &block|
|
||||||
|
klass = is_a? Module
|
||||||
|
target = klass ? "#{self}." : "#{self.class}#"
|
||||||
|
msg = [
|
||||||
|
"NOTE: #{target}#{name} is deprecated",
|
||||||
|
repl == :none ? " with no replacement" : "; use #{repl} instead",
|
||||||
|
format(". It will be removed on or after %4d-%02d.", year, month),
|
||||||
|
"\n#{target}#{name} called from #{Gem.location_of_caller.join(":")}",
|
||||||
|
]
|
||||||
|
warn "#{msg.join}." unless Gem::Deprecate.skip
|
||||||
|
send old, *args, &block
|
||||||
|
end
|
||||||
|
ruby2_keywords name if respond_to?(:ruby2_keywords, true)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
module_function :rubygems_deprecate, :rubygems_deprecate_command, :skip_during
|
##
|
||||||
|
# Simple deprecation method that deprecates +name+ by wrapping it up
|
||||||
|
# in a dummy method. It warns on each call to the dummy method
|
||||||
|
# telling the user of +repl+ (unless +repl+ is :none) and the
|
||||||
|
# Rubygems version that it is planned to go away.
|
||||||
|
|
||||||
|
def rubygems_deprecate(name, replacement=:none)
|
||||||
|
class_eval do
|
||||||
|
old = "_deprecated_#{name}"
|
||||||
|
alias_method old, name
|
||||||
|
define_method name do |*args, &block|
|
||||||
|
klass = is_a? Module
|
||||||
|
target = klass ? "#{self}." : "#{self.class}#"
|
||||||
|
msg = [
|
||||||
|
"NOTE: #{target}#{name} is deprecated",
|
||||||
|
replacement == :none ? " with no replacement" : "; use #{replacement} instead",
|
||||||
|
". It will be removed in Rubygems #{Gem::Deprecate.next_rubygems_major_version}",
|
||||||
|
"\n#{target}#{name} called from #{Gem.location_of_caller.join(":")}",
|
||||||
|
]
|
||||||
|
warn "#{msg.join}." unless Gem::Deprecate.skip
|
||||||
|
send old, *args, &block
|
||||||
|
end
|
||||||
|
ruby2_keywords name if respond_to?(:ruby2_keywords, true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Deprecation method to deprecate Rubygems commands
|
||||||
|
def rubygems_deprecate_command(version = Gem::Deprecate.next_rubygems_major_version)
|
||||||
|
class_eval do
|
||||||
|
define_method "deprecated?" do
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
|
define_method "deprecation_warning" do
|
||||||
|
msg = [
|
||||||
|
"#{command} command is deprecated",
|
||||||
|
". It will be removed in Rubygems #{version}.\n",
|
||||||
|
]
|
||||||
|
|
||||||
|
alert_warning msg.join.to_s unless Gem::Deprecate.skip
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
module_function :rubygems_deprecate, :rubygems_deprecate_command, :skip_during
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
@ -7,7 +7,6 @@
|
|||||||
|
|
||||||
# rubocop:enable Style/AsciiComments
|
# rubocop:enable Style/AsciiComments
|
||||||
|
|
||||||
require_relative "../rubygems"
|
|
||||||
require_relative "security"
|
require_relative "security"
|
||||||
require_relative "user_interaction"
|
require_relative "user_interaction"
|
||||||
|
|
||||||
|
@ -767,6 +767,18 @@ end
|
|||||||
expect(err).to be_empty
|
expect(err).to be_empty
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "can require rubygems without warnings, when using a local cache", rubygems: ">= 3.5.10" do
|
||||||
|
install_gemfile <<-G
|
||||||
|
source "#{file_uri_for(gem_repo1)}"
|
||||||
|
gem "rack"
|
||||||
|
G
|
||||||
|
|
||||||
|
bundle "package"
|
||||||
|
bundle %(exec ruby -w -e "require 'rubygems'")
|
||||||
|
|
||||||
|
expect(err).to be_empty
|
||||||
|
end
|
||||||
|
|
||||||
context "when the user has `MANPATH` set", :man do
|
context "when the user has `MANPATH` set", :man do
|
||||||
before { ENV["MANPATH"] = "/foo#{File::PATH_SEPARATOR}" }
|
before { ENV["MANPATH"] = "/foo#{File::PATH_SEPARATOR}" }
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user