ruby-changes:3602
From: ko1@a...
Date: Fri, 18 Jan 2008 01:48:45 +0900 (JST)
Subject: [ruby-changes:3602] nobu - Ruby:r15091 (trunk): * vm_insnhelper.c (vm_call_method): check argument number to
nobu 2008-01-18 01:48:18 +0900 (Fri, 18 Jan 2008)
New Revision: 15091
Modified files:
trunk/ChangeLog
trunk/vm_insnhelper.c
Log:
* vm_insnhelper.c (vm_call_method): check argument number to
attr_reader. [ruby-core:15120]
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15091&r2=15090&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/vm_insnhelper.c?r1=15091&r2=15090&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 15090)
+++ ChangeLog (revision 15091)
@@ -1,3 +1,8 @@
+Fri Jan 18 01:48:06 2008 Nobuyoshi Nakada <nobu@r...>
+
+ * vm_insnhelper.c (vm_call_method): check argument number to
+ attr_reader. [ruby-core:15120]
+
Fri Jan 18 00:49:31 2008 Nobuyoshi Nakada <nobu@r...>
* io.c (rb_io_check_readable): flush tied write IO too.
Index: vm_insnhelper.c
===================================================================
--- vm_insnhelper.c (revision 15090)
+++ vm_insnhelper.c (revision 15091)
@@ -495,45 +495,49 @@
switch (nd_type(node)) {
case RUBY_VM_METHOD_NODE:{
- vm_setup_method(th, cfp, num, blockptr, flag, (VALUE)node->nd_body, recv, klass);
- return Qundef;
+ vm_setup_method(th, cfp, num, blockptr, flag, (VALUE)node->nd_body, recv, klass);
+ return Qundef;
}
case NODE_CFUNC:{
- val = vm_call_cfunc(th, cfp, num, id, recv, mn->nd_clss, flag, node, blockptr);
- break;
+ val = vm_call_cfunc(th, cfp, num, id, recv, mn->nd_clss, flag, node, blockptr);
+ break;
}
case NODE_ATTRSET:{
- val = rb_ivar_set(recv, node->nd_vid, *(cfp->sp - 1));
- cfp->sp -= 2;
- break;
+ val = rb_ivar_set(recv, node->nd_vid, *(cfp->sp - 1));
+ cfp->sp -= 2;
+ break;
}
case NODE_IVAR:{
- val = rb_ivar_get(recv, node->nd_vid);
- cfp->sp -= 1;
- break;
+ if (num != 0) {
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 0)",
+ num);
+ }
+ val = rb_attr_get(recv, node->nd_vid);
+ cfp->sp -= 1;
+ break;
}
case NODE_BMETHOD:{
- VALUE *argv = cfp->sp - num;
- val = vm_call_bmethod(th, id, node->nd_cval, recv, klass, num, argv, blockptr);
- cfp->sp += - num - 1;
- break;
+ VALUE *argv = cfp->sp - num;
+ val = vm_call_bmethod(th, id, node->nd_cval, recv, klass, num, argv, blockptr);
+ cfp->sp += - num - 1;
+ break;
}
case NODE_ZSUPER:{
- klass = RCLASS_SUPER(mn->nd_clss);
- mn = rb_method_node(klass, id);
+ klass = RCLASS_SUPER(mn->nd_clss);
+ mn = rb_method_node(klass, id);
- if (mn != 0) {
- goto normal_method_dispatch;
- }
- else {
- goto start_method_dispatch;
- }
+ if (mn != 0) {
+ goto normal_method_dispatch;
+ }
+ else {
+ goto start_method_dispatch;
+ }
}
default:{
- printf("node: %s\n", ruby_node_name(nd_type(node)));
- rb_bug("eval_invoke_method: unreachable");
- /* unreachable */
- break;
+ printf("node: %s\n", ruby_node_name(nd_type(node)));
+ rb_bug("eval_invoke_method: unreachable");
+ /* unreachable */
+ break;
}
}
}
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/