ruby-changes:6080
From: ko1 <ko1@a...>
Date: Fri, 27 Jun 2008 06:54:51 +0900 (JST)
Subject: [ruby-changes:6080] Ruby:r17592 (trunk): * vm_eval.c (vm_call_super): fix to call method_missing.
ko1 2008-06-27 06:52:44 +0900 (Fri, 27 Jun 2008)
New Revision: 17592
Modified files:
trunk/ChangeLog
trunk/vm_eval.c
Log:
* vm_eval.c (vm_call_super): fix to call method_missing.
[ruby-core:15719], [ruby-core:17340]
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=17592&r2=17591&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/vm_eval.c?r1=17592&r2=17591&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 17591)
+++ ChangeLog (revision 17592)
@@ -1,3 +1,8 @@
+Fri Jun 27 06:50:56 2008 Koichi Sasada <ko1@a...>
+
+ * vm_eval.c (vm_call_super): fix to call method_missing.
+ [ruby-core:15719], [ruby-core:17340]
+
Fri Jun 27 00:00:14 2008 Nobuyoshi Nakada <nobu@r...>
* ruby.c (set_arg0, ruby_prog_init): freeze $0. a patch from Keita
Index: vm_eval.c
===================================================================
--- vm_eval.c (revision 17591)
+++ vm_eval.c (revision 17592)
@@ -148,10 +148,12 @@
body = body->nd_body;
}
else {
- dp(recv);
- dp(klass);
- dpi(id);
- rb_bug("vm_call_super: not found");
+ VALUE *argv_m = ALLOCA_N(VALUE, argc+1);
+ MEMCPY(argv_m + 1, argv, VALUE, argc);
+ argv_m[0] = ID2SYM(id);
+ th->method_missing_reason = 0;
+ th->passed_block = 0;
+ return rb_funcall2(recv, idMethodMissing, argc + 1, argv);
}
return vm_call0(th, klass, recv, id, id, argc, argv, body, CALL_SUPER);
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/