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.
|
* iseq.c (rb_iseq_first_lineno): constified.
|
||||||
|
|
||||||
|
|
|
@ -70,4 +70,23 @@ class TestLambdaParameters < Test::Unit::TestCase
|
||||||
BasicObject.new.instance_eval {->() {called = true}.()}
|
BasicObject.new.instance_eval {->() {called = true}.()}
|
||||||
assert_equal(true, called, bug5966)
|
assert_equal(true, called, bug5966)
|
||||||
end
|
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
|
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;
|
VALUE err_line = 0;
|
||||||
|
|
||||||
if (iseq) {
|
if (iseq) {
|
||||||
int line_no = 1;
|
int line_no = rb_iseq_first_lineno(iseq);
|
||||||
|
|
||||||
if (iseq->line_info_size) {
|
|
||||||
line_no = iseq->line_info_table[0].line_no;
|
|
||||||
}
|
|
||||||
|
|
||||||
err_line = rb_sprintf("%s:%d:in `%s'",
|
err_line = rb_sprintf("%s:%d:in `%s'",
|
||||||
RSTRING_PTR(iseq->filename),
|
RSTRING_PTR(iseq->filename),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue