diff options
author | Samuel Williams <samuel.williams@oriontransfer.co.nz> | 2020-08-15 15:36:18 +1200 |
---|---|---|
committer | Samuel Williams <samuel.williams@oriontransfer.co.nz> | 2020-08-18 00:56:35 +1200 |
commit | 0a218a97ad31f06eb7f59ccdd428fd46c4b93982 (patch) | |
tree | 9f9e50845d2ee2b19044c78d4ced69af9c07e3da /vm_backtrace.c | |
parent | c45f5ff2b0b801a94ffe761d83a46760c3d6d33d (diff) |
Expose ec -> backtrace (internal) and use it to implement fiber backtrace.
See <https://bugs.ruby-lang.org/issues/16815> for more details.
Notes
Notes:
Merged: https://github.com/ruby/ruby/pull/3422
Diffstat (limited to 'vm_backtrace.c')
-rw-r--r-- | vm_backtrace.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/vm_backtrace.c b/vm_backtrace.c index 04b696c638..ba99527958 100644 --- a/vm_backtrace.c +++ b/vm_backtrace.c @@ -996,6 +996,16 @@ rb_vm_thread_backtrace_locations(int argc, const VALUE *argv, VALUE thval) return thread_backtrace_to_ary(argc, argv, thval, 0); } +VALUE rb_vm_backtrace(int argc, const VALUE * argv, struct rb_execution_context_struct * ec) +{ + return ec_backtrace_to_ary(ec, argc, argv, 0, 0, 1); +} + +VALUE rb_vm_backtrace_locations(int argc, const VALUE * argv, struct rb_execution_context_struct * ec) +{ + return ec_backtrace_to_ary(ec, argc, argv, 0, 0, 0); +} + /* * call-seq: * caller(start=1, length=nil) -> array or nil |