diff options
author | nagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-05-05 06:32:37 +0000 |
---|---|---|
committer | nagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-05-05 06:32:37 +0000 |
commit | 5358a5c016de6162433baf80c127be27ce2ca11c (patch) | |
tree | bbc94913a101e94cdc510e74d310921d1af653b9 /eval.c | |
parent | 09c2f41211709047eff6f8829ff7afc827ef288c (diff) | |
download | ruby-5358a5c016de6162433baf80c127be27ce2ca11c.tar.gz |
* eval.c (frame_func_id): __method__ return different name from
methods defined by Module#define_method with a same block.
[ruby-core:35386] fixes #4606
* eval (method_entry_of_iseq): new helper function. search control
frame stack for a method entry which has given iseq.
* test/ruby/test_method.rb: add tests for #4696
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@31436 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 23 |
1 files changed, 21 insertions, 2 deletions
@@ -753,12 +753,27 @@ rb_ensure(VALUE (*b_proc)(ANYARGS), VALUE data1, VALUE (*e_proc)(ANYARGS), VALUE return result; } +static const rb_method_entry_t * +method_entry_of_iseq(rb_control_frame_t *cfp, rb_iseq_t *iseq) +{ + rb_thread_t *th = GET_THREAD(); + rb_control_frame_t *cfp_limit; + + cfp_limit = (rb_control_frame_t *)(th->stack + th->stack_size); + while (cfp_limit > cfp) { + if (cfp->iseq == iseq) + return cfp->me; + cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp); + } + return 0; +} + static ID frame_func_id(rb_control_frame_t *cfp) { + const rb_method_entry_t *me_local; rb_iseq_t *iseq = cfp->iseq; - if (!iseq) { - if (!cfp->me) return 0; + if (cfp->me) { return cfp->me->def->original_id; } while (iseq) { @@ -767,6 +782,10 @@ frame_func_id(rb_control_frame_t *cfp) if (ifunc->nd_aid) return ifunc->nd_aid; return rb_intern("<ifunc>"); } + me_local = method_entry_of_iseq(cfp, iseq); + if (me_local) { + return me_local->def->original_id; + } if (iseq->defined_method_id) { return iseq->defined_method_id; } |