From 2a754a733045da9965e88d1f31e650ea6b3f2b6c Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 13 Nov 2014 09:10:40 +0000 Subject: proc.c: make lambda directly * vm.c (rb_vm_make_proc_lambda): similar to rb_vm_make_proc() with is_lambda argument. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48397 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- proc.c | 13 ++----------- 1 file changed, 2 insertions(+), 11 deletions(-) (limited to 'proc.c') diff --git a/proc.c b/proc.c index d5f042fb42..c2e0dde9f1 100644 --- a/proc.c +++ b/proc.c @@ -566,10 +566,7 @@ proc_new(VALUE klass, int is_lambda) rb_control_frame_t *cfp = th->cfp; rb_block_t *block; - if ((block = rb_vm_control_frame_block_ptr(cfp)) != 0) { - /* block found */ - } - else { + if (!(block = rb_vm_control_frame_block_ptr(cfp))) { cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp); if ((block = rb_vm_control_frame_block_ptr(cfp)) != 0) { @@ -596,13 +593,7 @@ proc_new(VALUE klass, int is_lambda) } } - procval = rb_vm_make_proc(th, block, klass); - - if (is_lambda) { - rb_proc_t *proc; - GetProcPtr(procval, proc); - proc->is_lambda = TRUE; - } + procval = rb_vm_make_proc_lambda(th, block, klass, is_lambda); return procval; } -- cgit v1.2.3