Skip to content

Commit

Permalink
Move replace_require into bundled_gems.rb
Browse files Browse the repository at this point in the history
  • Loading branch information
hsbt committed Dec 7, 2023
1 parent 4f213ea commit 214f6d6
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 20 deletions.
19 changes: 19 additions & 0 deletions lib/bundled_gems.rb
Expand Up @@ -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
Expand Down
21 changes: 1 addition & 20 deletions lib/bundler/rubygems_integration.rb
Expand Up @@ -238,25 +238,6 @@ def reverse_rubygems_kernel_mixin
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

Expand Down Expand Up @@ -379,7 +360,7 @@ def replace_entrypoints(specs)
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)
Expand Down

0 comments on commit 214f6d6

Please sign in to comment.