diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-05-20 10:02:06 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-05-20 10:02:06 +0000 |
commit | bec6d3b1b9a5fcc4ed37c98814e114066cfcc0a5 (patch) | |
tree | 417b41b1ba1689e744d4b6e7936c00bfabb5c8a6 /eval.c | |
parent | 56a4cc27edbe89dc65147a6a5f667cb838cfabc3 (diff) | |
download | ruby-bec6d3b1b9a5fcc4ed37c98814e114066cfcc0a5.tar.gz |
* eval.c (rb_thread_save_context): prohibit rb_gc_force_recycle()
on thread saved ruby_dyna_vars. [ruby-dev:20236]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3837 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 2 |
1 files changed, 2 insertions, 0 deletions
@@ -7982,6 +7982,7 @@ rb_thread_save_context(th) th->stk_pos = (rb_gc_stack_start<pos)?rb_gc_stack_start :rb_gc_stack_start - len; if (len > th->stk_max) { + rb_gc(); REALLOC_N(th->stk_ptr, VALUE, len); th->stk_max = len; } @@ -7998,6 +7999,7 @@ rb_thread_save_context(th) th->wrapper = ruby_wrapper; th->cref = ruby_cref; th->dyna_vars = ruby_dyna_vars; + FL_SET(ruby_dyna_vars, DVAR_DONT_RECYCLE); th->block = ruby_block; th->flags &= THREAD_FLAGS_MASK; th->flags |= (rb_trap_immediate<<8) | scope_vmode; |