diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-09-30 06:47:18 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-09-30 06:47:18 +0000 |
commit | 804d95f721aac0c2b68447ab8e3020a2b7225ac4 (patch) | |
tree | 0e070df292a27b913eeff25dffdfc1bd58a29fd4 | |
parent | e2174922ff4092fcce5db4c6d17f3430c59a4713 (diff) | |
download | ruby-804d95f721aac0c2b68447ab8e3020a2b7225ac4.tar.gz |
vm_args.c: optimize symbol block passing
* vm_args.c (vm_caller_setup_arg_block): bypass Symbol#to_proc
call to optimize symbol block passing.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@51989 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | vm_args.c | 7 |
2 files changed, 11 insertions, 1 deletions
@@ -1,3 +1,8 @@ +Wed Sep 30 15:47:13 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * vm_args.c (vm_caller_setup_arg_block): bypass Symbol#to_proc + call to optimize symbol block passing. + Wed Sep 30 01:34:34 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> * parse.y (parser_free): fix memory leak at syntax error when @@ -776,7 +776,12 @@ vm_caller_setup_arg_block(const rb_thread_t *th, rb_control_frame_t *reg_cfp, proc = *(--reg_cfp->sp); - if (proc != Qnil) { + if (SYMBOL_P(proc) && rb_method_basic_definition_p(rb_cSymbol, idTo_proc)) { + calling->blockptr = RUBY_VM_GET_BLOCK_PTR_IN_CFP(reg_cfp); + calling->blockptr->iseq = (rb_iseq_t *)IFUNC_NEW(rb_sym_proc_call, SYM2ID(proc), 0); + calling->blockptr->proc = 0; + } + else if (!NIL_P(proc)) { if (!rb_obj_is_proc(proc)) { VALUE b; b = rb_check_convert_type(proc, T_DATA, "Proc", "to_proc"); |