[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]