diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-11-30 18:02:43 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-11-30 18:02:43 +0000 |
commit | 5697f69baa942ae117c66322bca0088cbb38557f (patch) | |
tree | e86bbaa4edb48940a45b372e27f0b32b94a05476 /iseq.c | |
parent | 57a83c4c9ac1de6da5184972cc10e33f44f6f747 (diff) | |
download | ruby-5697f69baa942ae117c66322bca0088cbb38557f.tar.gz |
* iseq.c: add RubyVM::InstructionSequence (ISeq) inspection methods.
* ISeq#path returns path of this ISeq written.
* ISeq#absolute_path returns absolute path.
* ISeq#label returns label (method name and so on).
* ISeq#base_label returns base label (see Thread::Backtrace::Location).
* ISeq#first_lineno returns first line number of this ISeq.
* ISeq.of(obj) returns ISeq object which obj (Proc or Method)
is contains.
* test/ruby/test_iseq.rb: add tests.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38085 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'iseq.c')
-rw-r--r-- | iseq.c | 91 |
1 files changed, 73 insertions, 18 deletions
@@ -799,6 +799,46 @@ iseq_inspect(VALUE self) RSTRING_PTR(iseq->location.label), RSTRING_PTR(iseq->location.path)); } +static VALUE +iseq_path(VALUE self) +{ + rb_iseq_t *iseq; + GetISeqPtr(self, iseq); + return iseq->location.path; +} + +static VALUE +iseq_absolute_path(VALUE self) +{ + rb_iseq_t *iseq; + GetISeqPtr(self, iseq); + return iseq->location.absolute_path; +} + +static VALUE +iseq_label(VALUE self) +{ + rb_iseq_t *iseq; + GetISeqPtr(self, iseq); + return iseq->location.label; +} + +static VALUE +iseq_base_label(VALUE self) +{ + rb_iseq_t *iseq; + GetISeqPtr(self, iseq); + return iseq->location.base_label; +} + +static VALUE +iseq_first_lineno(VALUE self) +{ + rb_iseq_t *iseq; + GetISeqPtr(self, iseq); + return iseq->location.first_lineno; +} + static VALUE iseq_data_to_ary(rb_iseq_t *iseq); @@ -1290,6 +1330,28 @@ rb_iseq_disasm(VALUE self) return str; } +static VALUE +iseq_s_of(VALUE klass, VALUE body) +{ + VALUE ret = Qnil; + rb_iseq_t *iseq; + + rb_secure(1); + + if (rb_obj_is_proc(body)) { + rb_proc_t *proc; + GetProcPtr(body, proc); + iseq = proc->block.iseq; + if (RUBY_VM_NORMAL_ISEQ_P(iseq)) { + ret = iseq->self; + } + } + else if ((iseq = rb_method_get_iseq(body)) != 0) { + ret = iseq->self; + } + return ret; +} + /* * call-seq: * InstructionSequence.disasm(body) -> str @@ -1342,27 +1404,12 @@ rb_iseq_disasm(VALUE self) * 0012 leave * */ + static VALUE iseq_s_disasm(VALUE klass, VALUE body) { - VALUE ret = Qnil; - rb_iseq_t *iseq; - - rb_secure(1); - - if (rb_obj_is_proc(body)) { - rb_proc_t *proc; - GetProcPtr(body, proc); - iseq = proc->block.iseq; - if (RUBY_VM_NORMAL_ISEQ_P(iseq)) { - ret = rb_iseq_disasm(iseq->self); - } - } - else if ((iseq = rb_method_get_iseq(body)) != 0) { - ret = rb_iseq_disasm(iseq->self); - } - - return ret; + VALUE iseqval = iseq_s_of(klass, body); + return NIL_P(iseqval) ? Qnil : rb_iseq_disasm(iseqval); } const char * @@ -2019,6 +2066,13 @@ Init_ISeq(void) rb_define_method(rb_cISeq, "to_a", iseq_to_a, 0); rb_define_method(rb_cISeq, "eval", iseq_eval, 0); + /* location APIs */ + rb_define_method(rb_cISeq, "path", iseq_path, 0); + rb_define_method(rb_cISeq, "absolute_path", iseq_absolute_path, 0); + rb_define_method(rb_cISeq, "label", iseq_label, 0); + rb_define_method(rb_cISeq, "base_label", iseq_base_label, 0); + rb_define_method(rb_cISeq, "first_lineno", iseq_first_lineno, 0); + /* experimental */ rb_define_method(rb_cISeq, "line_trace_all", rb_iseq_line_trace_all, 0); rb_define_method(rb_cISeq, "line_trace_specify", rb_iseq_line_trace_specify, 2); @@ -2039,4 +2093,5 @@ Init_ISeq(void) rb_define_singleton_method(rb_cISeq, "compile_option=", iseq_s_compile_option_set, 1); rb_define_singleton_method(rb_cISeq, "disasm", iseq_s_disasm, 1); rb_define_singleton_method(rb_cISeq, "disassemble", iseq_s_disasm, 1); + rb_define_singleton_method(rb_cISeq, "of", iseq_s_of, 1); } |