summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-09-24 14:26:00 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-09-24 14:26:00 +0000
commitc0f0cff56f9bc43bbdbd823974414cef22031c1b (patch)
tree5f44bc1f12ee1a4f03f2244d2aa01ff7d5904599
parentd5a7c704ac0ddf15919d3c382888e23e027cfa84 (diff)
Check whether to skip every frame
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@64826 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--lib/rubygems.rb1
-rwxr-xr-xlib/rubygems/core_ext/kernel_warn.rb11
-rw-r--r--test/rubygems/test_require.rb18
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