summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-15 07:26:48 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-15 07:26:48 +0000
commit815bc02fdc3faf9ab3eca9022636439ee3e11cc4 (patch)
tree258efbf9f7faed290d931bc63cc46a6ed2251b68
parentef520e2faf2a8e5cc5beedcf1c2d5286a6e234a3 (diff)
downloadruby-815bc02fdc3faf9ab3eca9022636439ee3e11cc4.tar.gz
ruby-815bc02fdc3faf9ab3eca9022636439ee3e11cc4.tar.xz
ruby-815bc02fdc3faf9ab3eca9022636439ee3e11cc4.zip
* vm_insnhelper.c (vm_callee_setup_arg_complex): uses cfp from
blockptr instead of the current cfp. [ruby-core:20544] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@20748 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--bootstraptest/test_block.rb18
-rw-r--r--vm_insnhelper.c3
3 files changed, 25 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 933fccb0c..a281b1edd 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Mon Dec 15 16:26:46 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * vm_insnhelper.c (vm_callee_setup_arg_complex): uses cfp from
+ blockptr instead of the current cfp. [ruby-core:20544]
+
Mon Dec 15 14:56:59 2008 Yuki Sonoda (Yugui) <yugui@yugui.jp>
* test/ruby/test_metaclass.rb: new test case for metaclass hierarchy.
diff --git a/bootstraptest/test_block.rb b/bootstraptest/test_block.rb
index 2db149063..ce7f00b03 100644
--- a/bootstraptest/test_block.rb
+++ b/bootstraptest/test_block.rb
@@ -487,6 +487,24 @@ assert_equal 'ok', %q{
}, '[ruby-talk:266422]'
assert_equal 'ok', %q{
+ class C
+ define_method(:xyz) do |o, k, &block|
+ block.call(o, k)
+ end
+ end
+ C.new.xyz("o","k") {|o, k| o+k}
+}, '[ruby-core:20544]'
+
+assert_equal 'ok', %q{
+ class C
+ define_method(:xyz) do |*args, &block|
+ block.call(*args)
+ end
+ end
+ C.new.xyz("o","k") {|*args| args.join("")}
+}, '[ruby-core:20544]'
+
+assert_equal 'ok', %q{
STDERR.reopen(STDOUT)
class C
define_method(:foo) do |&block|
diff --git a/vm_insnhelper.c b/vm_insnhelper.c
index b3815b692..5c3348f3b 100644
--- a/vm_insnhelper.c
+++ b/vm_insnhelper.c
@@ -186,7 +186,8 @@ vm_callee_setup_arg_complex(rb_thread_t *th, const rb_iseq_t * iseq,
if (blockptr->proc == 0) {
rb_proc_t *proc;
- blockval = vm_make_proc(th, th->cfp, blockptr, rb_cProc);
+ blockval = vm_make_proc(th, RUBY_VM_GET_CFP_FROM_BLOCK_PTR(blockptr),
+ blockptr, rb_cProc);
GetProcPtr(blockval, proc);
*block = &proc->block;