diff options
-rw-r--r-- | lib/rubygems.rb | 1 | ||||
-rwxr-xr-x | lib/rubygems/core_ext/kernel_warn.rb | 11 | ||||
-rw-r--r-- | test/rubygems/test_require.rb | 18 |
3 files changed, 28 insertions, 2 deletions
diff --git a/lib/rubygems.rb b/lib/rubygems.rb index 858d910610..9716464718 100644 --- a/lib/rubygems.rb +++ b/lib/rubygems.rb @@ -1392,5 +1392,6 @@ Gem::Specification.load_defaults require 'rubygems/core_ext/kernel_gem' require 'rubygems/core_ext/kernel_require' +require 'rubygems/core_ext/kernel_warn' Gem.use_gemdeps diff --git a/lib/rubygems/core_ext/kernel_warn.rb b/lib/rubygems/core_ext/kernel_warn.rb index 1291e72870..319fdfe606 100755 --- a/lib/rubygems/core_ext/kernel_warn.rb +++ b/lib/rubygems/core_ext/kernel_warn.rb @@ -9,8 +9,15 @@ if RUBY_VERSION >= "2.5" module_function define_method(:warn) {|*messages, uplevel: nil| if uplevel - while (loc, = caller_locations(uplevel, 1); loc && loc.path.start_with?(path)) - uplevel += 1 + uplevel, = [uplevel].pack("l!").unpack("l!") + if uplevel >= 0 + start = 0 + begin + loc, = caller_locations(start, 1) + break start += uplevel unless loc + start += 1 + end while (loc.path.start_with?(path) or (uplevel -= 1) >= 0) + uplevel = start end original_warn.call(*messages, uplevel: uplevel) else diff --git a/test/rubygems/test_require.rb b/test/rubygems/test_require.rb index ed856c7648..6af896507a 100644 --- a/test/rubygems/test_require.rb +++ b/test/rubygems/test_require.rb @@ -412,6 +412,24 @@ class TestGemRequire < Gem::TestCase end end + if RUBY_VERSION >= "2.5" + def test_no_kernel_require_in_warn_with_uplevel + lib = File.realpath("../../../lib", __FILE__) + Dir.mktmpdir("warn_test") do |dir| + File.write(dir + "/sub.rb", "warn 'uplevel', 'test', uplevel: 1\n") + File.write(dir + "/main.rb", "require 'sub'\n") + _, err = capture_subprocess_io do + system(@@ruby, "-w", "-rpp", "--disable=gems", "-I", lib, "-C", dir, "-I.", "main.rb") + end + assert_equal "main.rb:1: warning: uplevel\ntest\n", err + _, err = capture_subprocess_io do + system(@@ruby, "-w", "-rpp", "--enable=gems", "-I", lib, "-C", dir, "-I.", "main.rb") + end + assert_equal "main.rb:1: warning: uplevel\ntest\n", err + end + end + end + def silence_warnings old_verbose, $VERBOSE = $VERBOSE, false yield |