diff --git a/ChangeLog b/ChangeLog index f1743a31cc..9208901393 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Sat Aug 18 01:12:01 2007 Nobuyoshi Nakada + + * eval.c (frame_func_id): return proper method ID. + Fri Aug 17 22:43:11 2007 Koichi Sasada * compile.c (iseq_compile_each): massign should return rvalue(s). diff --git a/eval.c b/eval.c index 1729079d6d..164703636e 100644 --- a/eval.c +++ b/eval.c @@ -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(""); - } - else { - return rb_intern(RSTRING_PTR(iseq->name)); + while (iseq) { + if (RUBY_VM_IFUNC_P(iseq)) { + return rb_intern(""); + } + 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 diff --git a/version.h b/version.h index 2148dce2b4..a940e26218 100644 --- a/version.h +++ b/version.h @@ -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[];