diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-17 16:12:03 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-17 16:12:03 +0000 |
commit | 69dd06ae685b41ed9a77c4b2bdfa5587c12c5019 (patch) | |
tree | c3bf7730029ffff998bca90fb4468ce664480858 | |
parent | 2c5463fe99df8868e53817af834f1ecec9875515 (diff) | |
download | ruby-69dd06ae685b41ed9a77c4b2bdfa5587c12c5019.tar.gz |
* eval.c (frame_func_id): return proper method ID.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13082 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | eval.c | 17 | ||||
-rw-r--r-- | test/ruby/test_method.rb | 9 | ||||
-rw-r--r-- | version.h | 6 |
4 files changed, 28 insertions, 8 deletions
@@ -1,3 +1,7 @@ +Sat Aug 18 01:12:01 2007 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval.c (frame_func_id): return proper method ID. + Fri Aug 17 22:43:11 2007 Koichi Sasada <ko1@atdot.net> * compile.c (iseq_compile_each): massign should return rvalue(s). @@ -1612,12 +1612,19 @@ frame_func_id(rb_control_frame_t *cfp) if (!iseq) { return cfp->method_id; } - else if (RUBY_VM_IFUNC_P(iseq)) { - return rb_intern("<ifunc>"); - } - else { - return rb_intern(RSTRING_PTR(iseq->name)); + while (iseq) { + if (RUBY_VM_IFUNC_P(iseq)) { + return rb_intern("<ifunc>"); + } + if (iseq->defined_method_id) { + return iseq->defined_method_id; + } + if (iseq->local_iseq == iseq) { + break; + } + iseq = iseq->parent_iseq; } + return 0; } ID diff --git a/test/ruby/test_method.rb b/test/ruby/test_method.rb index 5f436406a5..c7bd443785 100644 --- a/test/ruby/test_method.rb +++ b/test/ruby/test_method.rb @@ -43,4 +43,13 @@ class TestMethod < Test::Unit::TestCase um.bind(Base.new) end end + + def test_callee + assert_equal(:test_callee, __method__) + assert_equal(:m, Class.new {def m; __method__; end}.new.m) + assert_equal(:m, Class.new {def m; tap{return __method__}; end}.new.m) + assert_equal(:m, Class.new {define_method(:m) {__method__}}.new.m) + assert_equal(:m, Class.new {define_method(:m) {tap{return __method__}}}.new.m) + assert_nil(eval("class TestCallee; __method__; end")) + end end @@ -1,7 +1,7 @@ #define RUBY_VERSION "1.9.0" -#define RUBY_RELEASE_DATE "2007-08-17" +#define RUBY_RELEASE_DATE "2007-08-18" #define RUBY_VERSION_CODE 190 -#define RUBY_RELEASE_CODE 20070817 +#define RUBY_RELEASE_CODE 20070818 #define RUBY_PATCHLEVEL 0 #define RUBY_VERSION_MAJOR 1 @@ -9,7 +9,7 @@ #define RUBY_VERSION_TEENY 0 #define RUBY_RELEASE_YEAR 2007 #define RUBY_RELEASE_MONTH 8 -#define RUBY_RELEASE_DAY 17 +#define RUBY_RELEASE_DAY 18 #ifdef RUBY_EXTERN RUBY_EXTERN const char ruby_version[]; |