summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-12-20 13:41:47 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-12-20 13:41:47 +0000
commit548a6feac8fb0aab4146c0646bf0dfb13fe488d0 (patch)
tree327429d2fe23d3e7dcbbd8511b16e80af0ddcae1
parentbbcd49c836f34b2e0f0d2ce85709c28daa0bc560 (diff)
downloadruby-548a6feac8fb0aab4146c0646bf0dfb13fe488d0.tar.gz
ruby-548a6feac8fb0aab4146c0646bf0dfb13fe488d0.tar.xz
ruby-548a6feac8fb0aab4146c0646bf0dfb13fe488d0.zip
* eval.c (eval_under_i): evaluate source in caller's frame.
[ruby-dev:28076] * eval.c (rb_call_super): use original method name on exception. [ruby-dev:28078] git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@9725 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog8
-rw-r--r--eval.c9
2 files changed, 15 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 8d8be846f..820b4f900 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+Tue Dec 20 22:41:17 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * eval.c (eval_under_i): evaluate source in caller's frame.
+ [ruby-dev:28076]
+
+ * eval.c (rb_call_super): use original method name on exception.
+ [ruby-dev:28078]
+
Tue Dec 20 13:11:59 2005 Hirokazu Yamamoto <ocean@m2.ccsnet.ne.jp>
* ext/syck/rubyext.c: fixed GC problem (backported HEAD 1.55 - 1.62)
diff --git a/eval.c b/eval.c
index d049b7ff6..82a252714 100644
--- a/eval.c
+++ b/eval.c
@@ -6075,13 +6075,13 @@ rb_call_super(argc, argv)
if (ruby_frame->last_class == 0) {
rb_name_error(ruby_frame->last_func, "calling `super' from `%s' is prohibited",
- rb_id2name(ruby_frame->last_func));
+ rb_id2name(ruby_frame->orig_func));
}
self = ruby_frame->self;
klass = ruby_frame->last_class;
if (RCLASS(klass)->super == 0) {
- return method_missing(self, ruby_frame->last_func, argc, argv, CSTAT_SUPER);
+ return method_missing(self, ruby_frame->orig_func, argc, argv, CSTAT_SUPER);
}
PUSH_ITER(ruby_iter->iter ? ITER_PRE : ITER_NOT);
@@ -6476,6 +6476,11 @@ static VALUE
eval_under_i(args)
VALUE *args;
{
+ struct FRAME *f = ruby_frame;
+
+ if (f && (f = f->prev) && (f = f->prev)) {
+ ruby_frame = f;
+ }
return eval(args[0], args[1], Qnil, (char*)args[2], (int)args[3]);
}