From e7dac48a9190169a241865cd706566b52e07b3b7 Mon Sep 17 00:00:00 2001 From: ko1 Date: Thu, 19 Jun 2008 15:43:25 +0000 Subject: * proc.c (proc_new): fix to return Proc object if block is already in heap. [ruby-core:15711] * bootstraptest/test_proc.rb: add a test. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@17442 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- proc.c | 4 ++++ 1 file changed, 4 insertions(+) (limited to 'proc.c') diff --git a/proc.c b/proc.c index eecff7ae12..f2d69c7317 100644 --- a/proc.c +++ b/proc.c @@ -358,6 +358,10 @@ proc_new(VALUE klass, int is_lambda) block = GC_GUARDED_PTR_REF(cfp->lfp[0]); + if (block->proc) { + return block->proc; + } + /* TODO: check more (cfp limit, called via cfunc, etc) */ while (cfp->dfp != block->dfp) { cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp); -- cgit v1.2.3