[ruby-dev:50073] [Ruby trunk Bug#13432] set_trace_funcにproc->is_from_method = TRUEのオブジェクトを渡し、SystemStackErrorを発生させるとRubyVMが停止する
From:
the.deviant.world@...
Date:
2017-04-13 14:07:14 UTC
List:
ruby-dev #50073
Issue #13432 has been reported by masato_hi (Masato Hi).
----------------------------------------
Bug #13432: set_trace_funcにproc->is_from_method = TRUEのオブジェクトを渡し、SystemStackErrorを発生させるとRubyVMが停止する
https://bugs.ruby-lang.org/issues/13432
* Author: masato_hi (Masato Hi)
* Status: Open
* Priority: Normal
* Assignee:
* Target version:
* ruby -v: ruby 2.5.0dev (2017-04-13 trunk 58340) [x86_64-darwin16]
* Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN
----------------------------------------
以下のコードのように、Method#to_procで作成したProcオブジェクトをset_trace_funcに設定しSystemStackErrorを発生させるとRubyVMが停止する。
```
def trace_method(event, file, line, id, binding, klass); end
set_trace_func method(:trace_method).to_proc
def infinite_loop
infinite_loop
end
infinite_loop #=> RubyVM stops
```
以下のコードではこの問題は発生しない。
```
set_trace_func lambda {|event, file, line, id, binding, klass|
}
def infinite_loop
infinite_loop
end
infinite_loop #=> stack level too deep (SystemStackError)
```
--
https://bugs.ruby-lang.org/