mirror of
https://github.com/ruby/ruby.git
synced 2026-01-27 04:24:23 +00:00
[ruby/prism] Fix warn polyfill when no uplevel is provided
An unspecified uplevel is not the same as an uplevel of 1:
```
$ irb
irb(main):001> warn("foo")
foo
=> nil
irb(main):002> warn("foo", uplevel: 1)
/home/user/.rbenv/versions/2.7.8/lib/ruby/gems/2.7.0/gems/irb-1.14.0/lib/irb/workspace.rb:121: warning: foo
=> nil
```
https://github.com/ruby/prism/commit/dcedd14357
This commit is contained in:
parent
8ad5a0a8d9
commit
9299cf31b1
@ -7,17 +7,14 @@ if (method = Kernel.instance_method(:warn)).respond_to?(:parameters) ? method.pa
|
||||
Kernel.prepend(
|
||||
Module.new {
|
||||
def warn(*msgs, uplevel: nil, category: nil) # :nodoc:
|
||||
uplevel =
|
||||
case uplevel
|
||||
when nil
|
||||
1
|
||||
when Integer
|
||||
uplevel + 1
|
||||
else
|
||||
uplevel.to_int + 1
|
||||
end
|
||||
|
||||
super(*msgs, uplevel: uplevel)
|
||||
case uplevel
|
||||
when nil
|
||||
super(*msgs)
|
||||
when Integer
|
||||
super(*msgs, uplevel: uplevel + 1)
|
||||
else
|
||||
super(*msgs, uplevel: uplevel.to_int + 1)
|
||||
end
|
||||
end
|
||||
}
|
||||
)
|
||||
@ -25,17 +22,14 @@ if (method = Kernel.instance_method(:warn)).respond_to?(:parameters) ? method.pa
|
||||
Object.prepend(
|
||||
Module.new {
|
||||
def warn(*msgs, uplevel: nil, category: nil) # :nodoc:
|
||||
uplevel =
|
||||
case uplevel
|
||||
when nil
|
||||
1
|
||||
when Integer
|
||||
uplevel + 1
|
||||
else
|
||||
uplevel.to_int + 1
|
||||
end
|
||||
|
||||
super(*msgs, uplevel: uplevel)
|
||||
case uplevel
|
||||
when nil
|
||||
super(*msgs)
|
||||
when Integer
|
||||
super(*msgs, uplevel: uplevel + 1)
|
||||
else
|
||||
super(*msgs, uplevel: uplevel.to_int + 1)
|
||||
end
|
||||
end
|
||||
}
|
||||
)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user