summaryrefslogtreecommitdiff
path: root/insns.def
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-01-05 12:00:08 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-01-05 12:00:08 +0000
commited9d4087f6bcccf82f08de670942cf51c4a0a54c (patch)
treeacece49eb09d0915d974c3beb46b152b766cfea0 /insns.def
parent21e39197e6351aa786a555f7304cbb5b98b599ef (diff)
* compile.c, compile.h : add ADD_CALL_RECEIVER() macro.
* insns.def (send) : use GET_SELF() direct if FCALL. * eval.c (rb_f_send) : check method dispatch type to permit nvoking private method when dispatch type is FCALL/VCALL * insns.def (opt_ltlt) : remove useless statement. * vm.h : remove unused macros. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11483 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'insns.def')
-rw-r--r--insns.def13
1 files changed, 10 insertions, 3 deletions
diff --git a/insns.def b/insns.def
index 99e35a7190..201e0db937 100644
--- a/insns.def
+++ b/insns.def
@@ -1158,7 +1158,16 @@ send
num_t flag = op_flag;
macro_eval_setup_send_arguments(num, blockptr, flag, blockiseq);
- recv = TOPN(num);
+
+ if (flag & VM_CALL_FCALL_BIT) {
+ /* method(...) */
+ recv = GET_SELF();
+ }
+ else {
+ /* recv.method(...) */
+ recv = TOPN(num);
+ }
+
klass = CLASS_OF(recv);
mn = eval_method_search(id, klass, ic);
@@ -2110,8 +2119,6 @@ opt_ltlt
(VALUE recv, VALUE obj)
(VALUE val)
{
- if (0) {
- }
if (!SPECIAL_CONST_P(recv)) {
if (0) {
}