[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/

In This Thread

Prev Next