mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
18e01f6381
The order of making binding should be stack (frame) top to bottom. [Bug #7635] And also fix issue of collecting klass. Collecting klass is same as TracePoint#defined_class. (previous version, it returns T_ICLASS (internal objects). * test/-ext-/debug/test_debug.rb: add a test. * ext/-test-/debug/extconf.rb, init.c, inspector.c: ditto. * vm_backtrace.c: remove magic number and add enum CALLER_BINDING_*. * vm_backtrace.c, include/ruby/debug.h: add new C api (experimental) rb_debug_inspector_frame_self_get(). * vm.c, vm_core.h, vm_trace.c: move decl. of rb_vm_control_frame_id_and_class() and constify first parameter. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38970 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
32 lines
923 B
C
32 lines
923 B
C
#include "ruby/ruby.h"
|
|
#include "ruby/debug.h"
|
|
|
|
static VALUE
|
|
callback(const rb_debug_inspector_t *dbg_context, void *data)
|
|
{
|
|
VALUE locs = rb_debug_inspector_backtrace_locations(dbg_context);
|
|
int i, len = RARRAY_LENINT(locs);
|
|
VALUE binds = rb_ary_new();
|
|
for (i = 0; i < len; ++i) {
|
|
VALUE entry = rb_ary_new();
|
|
rb_ary_push(binds, entry);
|
|
rb_ary_push(entry, rb_debug_inspector_frame_self_get(dbg_context, i));
|
|
rb_ary_push(entry, rb_debug_inspector_frame_binding_get(dbg_context, i));
|
|
rb_ary_push(entry, rb_debug_inspector_frame_class_get(dbg_context, i));
|
|
rb_ary_push(entry, rb_debug_inspector_frame_iseq_get(dbg_context, i));
|
|
rb_ary_push(entry, rb_ary_entry(locs, i));
|
|
}
|
|
return binds;
|
|
}
|
|
|
|
static VALUE
|
|
debug_inspector(VALUE self)
|
|
{
|
|
return rb_debug_inspector_open(callback, NULL);
|
|
}
|
|
|
|
void
|
|
Init_inspector(VALUE klass)
|
|
{
|
|
rb_define_module_function(klass, "inspector", debug_inspector, 0);
|
|
}
|