diff options
| author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-07-05 14:28:00 +0000 |
|---|---|---|
| committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-07-05 14:28:00 +0000 |
| commit | 863d48850a07bfef3f2e3744bd8d4a3fa274289f (patch) | |
| tree | aa3c166d9793d3d36bd75e4fbab1056130cec685 /eval.c | |
| parent | 25407d57a73b9ff175fa799a681a6933f1a19029 (diff) | |
| download | ruby-863d48850a07bfef3f2e3744bd8d4a3fa274289f.tar.gz ruby-863d48850a07bfef3f2e3744bd8d4a3fa274289f.tar.xz ruby-863d48850a07bfef3f2e3744bd8d4a3fa274289f.zip | |
* eval.c (rb_thread_save_context): must not switch contexts during
re-allocating stack. fixed: [ruby-core:05219]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@8726 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
| -rw-r--r-- | eval.c | 4 |
1 files changed, 3 insertions, 1 deletions
@@ -9971,7 +9971,9 @@ rb_thread_save_context(th) th->stk_len = 0; th->stk_pos = pos; if (len > th->stk_max) { - REALLOC_N(th->stk_ptr, VALUE, len); + VALUE *ptr = realloc(th->stk_ptr, sizeof(VALUE) * len); + if (!ptr) rb_memerror(); + th->stk_ptr = ptr; th->stk_max = len; } th->stk_len = len; |
