mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* vm_insnhelper.c (argument_error): use line number at the beginning
of lambda, not the first code ob its body. [ruby-core:43314][Bug #6151] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35052 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
e2ca7837d1
commit
817eb7d17d
3 changed files with 25 additions and 6 deletions
|
@ -1,4 +1,8 @@
|
|||
Fri Mar 16 11:59:56 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
Fri Mar 16 12:00:42 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* vm_insnhelper.c (argument_error): use line number at the beginning
|
||||
of lambda, not the first code ob its body.
|
||||
[ruby-core:43314][Bug #6151]
|
||||
|
||||
* iseq.c (rb_iseq_first_lineno): constified.
|
||||
|
||||
|
|
|
@ -70,4 +70,23 @@ class TestLambdaParameters < Test::Unit::TestCase
|
|||
BasicObject.new.instance_eval {->() {called = true}.()}
|
||||
assert_equal(true, called, bug5966)
|
||||
end
|
||||
|
||||
def test_location_on_error
|
||||
bug6151 = '[ruby-core:43314]'
|
||||
called = 0
|
||||
line, f = __LINE__, lambda do
|
||||
called += 1
|
||||
true
|
||||
end
|
||||
e = assert_raise(ArgumentError) do
|
||||
f.call(42)
|
||||
end
|
||||
assert_send([e.backtrace.first, :start_with?, "#{__FILE__}:#{line}:"], bug6151)
|
||||
assert_equal(0, called)
|
||||
e = assert_raise(ArgumentError) do
|
||||
42.times(&f)
|
||||
end
|
||||
assert_send([e.backtrace.first, :start_with?, "#{__FILE__}:#{line}:"], bug6151)
|
||||
assert_equal(0, called)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -130,11 +130,7 @@ argument_error(const rb_iseq_t *iseq, int miss_argc, int min_argc, int max_argc)
|
|||
VALUE err_line = 0;
|
||||
|
||||
if (iseq) {
|
||||
int line_no = 1;
|
||||
|
||||
if (iseq->line_info_size) {
|
||||
line_no = iseq->line_info_table[0].line_no;
|
||||
}
|
||||
int line_no = rb_iseq_first_lineno(iseq);
|
||||
|
||||
err_line = rb_sprintf("%s:%d:in `%s'",
|
||||
RSTRING_PTR(iseq->filename),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue