diff options
author | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2001-07-20 15:20:25 +0000 |
---|---|---|
committer | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2001-07-20 15:20:25 +0000 |
commit | b384ac5f656c7ae2ff9ca27b41763250cd51dfb1 (patch) | |
tree | e2794a921f30efcb80b971720e009b9a76628c1a /gc.c | |
parent | e8dd9d4c14e96184599254b41f194830f97c71dd (diff) | |
download | ruby-b384ac5f656c7ae2ff9ca27b41763250cd51dfb1.tar.gz ruby-b384ac5f656c7ae2ff9ca27b41763250cd51dfb1.tar.xz ruby-b384ac5f656c7ae2ff9ca27b41763250cd51dfb1.zip |
* gc.c (ruby_xrealloc): fix a dangling bug which led memory
reallocation to fail even though the second try after a GC
succeeds.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@1639 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -134,11 +134,12 @@ ruby_xrealloc(ptr, size) if (!mem) { rb_gc(); RUBY_CRITICAL(mem = realloc(ptr, size)); - if (!mem) + if (!mem) { if (size >= 50 * 1024 * 1024) { rb_raise(rb_eNoMemError, "tried to re-allocate too big memory"); } mem_error("failed to allocate memory(realloc)"); + } } return mem; |