diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-05-13 22:53:01 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-05-13 22:53:01 +0000 |
commit | 55e100683588c21fe5bf46b9d73fb12465f1f4dd (patch) | |
tree | e382f01726989a7f1aa736e9a29b11413a0b770c /eval.c | |
parent | 8d91dec5afac1cef5f84c3cfe5ca1e3dedaba20f (diff) | |
download | ruby-55e100683588c21fe5bf46b9d73fb12465f1f4dd.tar.gz ruby-55e100683588c21fe5bf46b9d73fb12465f1f4dd.tar.xz ruby-55e100683588c21fe5bf46b9d73fb12465f1f4dd.zip |
* eval.c (rb_call0): defer calling of rb_frame_self() until it
become really necessary.
* eval.c (rb_call): ditto.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@16408 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 7 |
1 files changed, 5 insertions, 2 deletions
@@ -1412,7 +1412,10 @@ rb_call0(VALUE klass, VALUE recv, ID mid, int argc, const VALUE *argv, int scope if (TYPE(defined_class) == T_ICLASS) { defined_class = RBASIC(defined_class)->klass; } - + + if (self == Qundef) { + self = rb_frame_self(); + } if (!rb_obj_is_kind_of(self, rb_class_real(defined_class))) { return method_missing(recv, mid, argc, argv, NOEX_PROTECTED); } @@ -1450,7 +1453,7 @@ rb_call0(VALUE klass, VALUE recv, ID mid, int argc, const VALUE *argv, int scope static VALUE rb_call(VALUE klass, VALUE recv, ID mid, int argc, const VALUE *argv, int scope) { - return rb_call0(klass, recv, mid, argc, argv, scope, rb_frame_self()); + return rb_call0(klass, recv, mid, argc, argv, scope, Qundef); } VALUE |