aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-08-17 16:12:03 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-08-17 16:12:03 +0000
commit69dd06ae685b41ed9a77c4b2bdfa5587c12c5019 (patch)
treec3bf7730029ffff998bca90fb4468ce664480858
parent2c5463fe99df8868e53817af834f1ecec9875515 (diff)
downloadruby-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--ChangeLog4
-rw-r--r--eval.c17
-rw-r--r--test/ruby/test_method.rb9
-rw-r--r--version.h6
4 files changed, 28 insertions, 8 deletions
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 <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).
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("<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
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[];