diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-01 04:09:27 -0700 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-01 04:09:27 -0700 |
| commit | 7c2f68862ea9cc58f62cbe2b87b4c4dc2b0294f5 (patch) | |
| tree | 3453d1e298e96335708fa75d2e737546357374a9 /src | |
| parent | 57cf264420acb625f4614353a088eb5b884f9c44 (diff) | |
| parent | c7ff1bd88150c8f61f7483ea857f198ca1992fc7 (diff) | |
| download | mruby-7c2f68862ea9cc58f62cbe2b87b4c4dc2b0294f5.tar.gz mruby-7c2f68862ea9cc58f62cbe2b87b4c4dc2b0294f5.zip | |
Merge pull request #1121 from monaka/pr-check-malloc-failed2
Check malloc failed
Diffstat (limited to 'src')
| -rw-r--r-- | src/gc.c | 14 |
1 files changed, 14 insertions, 0 deletions
@@ -157,6 +157,20 @@ mrb_realloc(mrb_state *mrb, void *p, size_t len) mrb_garbage_collect(mrb); p2 = (mrb->allocf)(mrb, p, len, mrb->ud); } + + if (!p2 && len) { + if (mrb->out_of_memory) { + /* mrb_panic(mrb); */ + } + else { + mrb->out_of_memory = 1; + mrb_raise(mrb, E_RUNTIME_ERROR, "Out of memory"); + } + } + else { + mrb->out_of_memory = 0; + } + return p2; } |
