diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-18 23:47:01 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-18 23:47:01 +0900 |
| commit | 53a282ac0e0da85994233dac1daabb6381669e51 (patch) | |
| tree | 7e78a206db8c5ac7fe7e6dbfb706a1776f9e8054 | |
| parent | 31b2980acb7218b0cc13cbc658208cde641a7ff8 (diff) | |
| download | mruby-53a282ac0e0da85994233dac1daabb6381669e51.tar.gz mruby-53a282ac0e0da85994233dac1daabb6381669e51.zip | |
stricter check for double resume; close #1885
| -rw-r--r-- | mrbgems/mruby-fiber/src/fiber.c | 2 | ||||
| -rw-r--r-- | mrbgems/mruby-fiber/test/fiber.rb | 13 |
2 files changed, 14 insertions, 1 deletions
diff --git a/mrbgems/mruby-fiber/src/fiber.c b/mrbgems/mruby-fiber/src/fiber.c index f67e02e56..381ede062 100644 --- a/mrbgems/mruby-fiber/src/fiber.c +++ b/mrbgems/mruby-fiber/src/fiber.c @@ -164,7 +164,7 @@ fiber_resume(mrb_state *mrb, mrb_value self) mrb_raise(mrb, E_ARGUMENT_ERROR, "can't cross C function boundary"); } } - if (c->status == MRB_FIBER_RUNNING) { + if (c->status == MRB_FIBER_RUNNING || (mrb->c->prev && mrb->c->prev != mrb->root_c)) { mrb_raise(mrb, E_RUNTIME_ERROR, "double resume"); } if (c->status == MRB_FIBER_TERMINATED) { diff --git a/mrbgems/mruby-fiber/test/fiber.rb b/mrbgems/mruby-fiber/test/fiber.rb index 5e42e9c57..8838208f6 100644 --- a/mrbgems/mruby-fiber/test/fiber.rb +++ b/mrbgems/mruby-fiber/test/fiber.rb @@ -88,3 +88,16 @@ assert('Double resume of Fiber') do assert_false f1.alive? assert_false f2.alive? end + +assert('Recursive resume of Fiber') do + f1, f2 = nil, nil + f1 = Fiber.new { assert_raise(RuntimeError) { f2.resume } } + f2 = Fiber.new { + f1.resume + Fiber.yield 0 + } + assert_equal 0, f2.resume + f2.resume + assert_false f1.alive? + assert_false f2.alive? +end |
