summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-11-30 04:01:17 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-11-30 04:01:17 +0000
commit402ae1e8ca080c890a2c7e3575cbebcbc7f0fbac (patch)
tree0a2129c0d8252ce1af14d9356dc7bcb6a63d1292
parentf333001d40d7ebff0d6db1f3f3aa8b38aaacbd6e (diff)
downloadruby-402ae1e8ca080c890a2c7e3575cbebcbc7f0fbac.tar.gz
ruby-402ae1e8ca080c890a2c7e3575cbebcbc7f0fbac.tar.xz
ruby-402ae1e8ca080c890a2c7e3575cbebcbc7f0fbac.zip
* eval.c (rb_eval): [ruby-core:03856]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@7421 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog2
-rw-r--r--env.h3
-rw-r--r--eval.c4
3 files changed, 7 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 1aeb4d169..13af04d60 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
Tue Nov 30 00:49:08 2004 Yukihiro Matsumoto <matz@ruby-lang.org>
+ * eval.c (rb_eval): [ruby-core:03856]
+
* io.c (rb_io_sysread): use temporary lock. [ruby-dev:24992]
Tue Nov 30 00:12:57 2004 Kazuo Saito <ksaito@uranus.dti.ne.jp>
diff --git a/env.h b/env.h
index c8aba3744..1019e6b56 100644
--- a/env.h
+++ b/env.h
@@ -29,8 +29,7 @@ RUBY_EXTERN struct FRAME {
void rb_gc_mark_frame _((struct FRAME *));
-#define FRAME_ALLOCA 0
-#define FRAME_MALLOC 1
+#define FRAME_DMETH 1
RUBY_EXTERN struct SCOPE {
struct RBasic super;
diff --git a/eval.c b/eval.c
index bb4ffba4c..c718e79b6 100644
--- a/eval.c
+++ b/eval.c
@@ -3250,6 +3250,9 @@ rb_eval(self, n)
}
}
if (nd_type(node) == NODE_ZSUPER) {
+ if (ruby_frame->flags & FRAME_DMETH) {
+ rb_raise(rb_eRuntimeError, "super: specify arguments explicitly");
+ }
argc = ruby_frame->argc;
argv = ruby_scope->local_vars + 2;
}
@@ -5550,6 +5553,7 @@ rb_call0(klass, recv, id, oid, argc, argv, body, nosuper)
break;
case NODE_BMETHOD:
+ ruby_frame->flags |= FRAME_DMETH;
result = proc_invoke(body->nd_cval, rb_ary_new4(argc, argv), recv, klass);
break;