aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorHiroshi SHIBATA <hsbt@ruby-lang.org>2023-12-07 10:56:34 +0900
committerHiroshi SHIBATA <hsbt@ruby-lang.org>2023-12-07 11:37:08 +0900
commit214f6d6598be8437284dede9eb9a041a3ebfb24e (patch)
tree07bdd14f63d36d5055d47d9a0262725a1b362b60 /lib
parent4f213ea1baa590c463c3554a6ff418d10dc291e0 (diff)
downloadruby-214f6d6598be8437284dede9eb9a041a3ebfb24e.tar.gz
Move replace_require into bundled_gems.rb
Diffstat (limited to 'lib')
-rw-r--r--lib/bundled_gems.rb19
-rw-r--r--lib/bundler/rubygems_integration.rb21
2 files changed, 20 insertions, 20 deletions
diff --git a/lib/bundled_gems.rb b/lib/bundled_gems.rb
index 391cf3d3a0..7c454e453e 100644
--- a/lib/bundled_gems.rb
+++ b/lib/bundled_gems.rb
@@ -56,6 +56,25 @@ module Gem::BUNDLED_GEMS
DLEXT = /\.#{Regexp.union(dlext)}\z/
LIBEXT = /\.#{Regexp.union("rb", *dlext)}\z/
+ def self.replace_require(specs)
+ return if [::Kernel.singleton_class, ::Kernel].any? {|klass| klass.respond_to?(:no_warning_require) }
+
+ [::Kernel.singleton_class, ::Kernel].each do |kernel_class|
+ kernel_class.send(:alias_method, :no_warning_require, :require)
+ kernel_class.send(:define_method, :require) do |name|
+ if message = ::Gem::BUNDLED_GEMS.warning?(name, specs: specs) # rubocop:disable Style/HashSyntax
+ warn message, :uplevel => 1
+ end
+ kernel_class.send(:no_warning_require, name)
+ end
+ if kernel_class == ::Kernel
+ kernel_class.send(:private, :require)
+ else
+ kernel_class.send(:public, :require)
+ end
+ end
+ end
+
def self.find_gem(path)
if !path
return
diff --git a/lib/bundler/rubygems_integration.rb b/lib/bundler/rubygems_integration.rb
index 9cd4d37928..cf60f2c9b8 100644
--- a/lib/bundler/rubygems_integration.rb
+++ b/lib/bundler/rubygems_integration.rb
@@ -238,25 +238,6 @@ module Bundler
end
end
- def replace_require(specs)
- return if [::Kernel.singleton_class, ::Kernel].any? {|klass| klass.respond_to?(:no_warning_require) }
-
- [::Kernel.singleton_class, ::Kernel].each do |kernel_class|
- kernel_class.send(:alias_method, :no_warning_require, :require)
- kernel_class.send(:define_method, :require) do |name|
- if message = ::Gem::BUNDLED_GEMS.warning?(name, specs: specs) # rubocop:disable Style/HashSyntax
- warn message, :uplevel => 1
- end
- kernel_class.send(:no_warning_require, name)
- end
- if kernel_class == ::Kernel
- kernel_class.send(:private, :require)
- else
- kernel_class.send(:public, :require)
- end
- end
- end
-
def replace_gem(specs, specs_by_name)
executables = nil
@@ -379,7 +360,7 @@ module Bundler
require "bundled_gems"
rescue LoadError
end unless defined?(::Gem::BUNDLED_GEMS)
- replace_require(specs) if defined?(::Gem::BUNDLED_GEMS)
+ Gem::BUNDLED_GEMS.replace_require(specs) if defined?(::Gem::BUNDLED_GEMS)
replace_gem(specs, specs_by_name)
stub_rubygems(specs)
replace_bin_path(specs_by_name)