diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-06-29 06:33:38 -0700 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-06-29 06:33:38 -0700 |
| commit | e33249e26712ac054cba4dd92ca1d26e09e1a601 (patch) | |
| tree | 2db39bf2504d58395d6a1ac89cf37abaf381c100 /src | |
| parent | 466d0ad7178f7e3ee0ae936ed4e85bc2b65f1ca2 (diff) | |
| parent | 68f31e94f564c48d8677acc8acf3ba46deebf94f (diff) | |
| download | mruby-e33249e26712ac054cba4dd92ca1d26e09e1a601.tar.gz mruby-e33249e26712ac054cba4dd92ca1d26e09e1a601.zip | |
Merge pull request #1318 from Fleurer/refactor_realloc
refactor mrb_realloc() in gc.c
Diffstat (limited to 'src')
| -rw-r--r-- | src/gc.c | 23 |
1 files changed, 13 insertions, 10 deletions
@@ -148,18 +148,28 @@ gettimeofday_time(void) #define GC_STEP_SIZE 1024 + void* -mrb_realloc(mrb_state *mrb, void *p, size_t len) +mrb_realloc_simple(mrb_state *mrb, void *p, size_t len) { void *p2; p2 = (mrb->allocf)(mrb, p, len, mrb->ud); - if (!p2 && len > 0 && mrb->heaps) { mrb_garbage_collect(mrb); p2 = (mrb->allocf)(mrb, p, len, mrb->ud); } + return p2; +} + + +void* +mrb_realloc(mrb_state *mrb, void *p, size_t len) +{ + void *p2; + + p2 = mrb_realloc_simple(mrb, p, len); if (!p2 && len) { if (mrb->out_of_memory) { /* mrb_panic(mrb); */ @@ -185,14 +195,7 @@ mrb_malloc(mrb_state *mrb, size_t len) void* mrb_malloc_simple(mrb_state *mrb, size_t len) { - void *p2; - - p2 = (mrb->allocf)(mrb, 0, len, mrb->ud); - if (!p2 && len > 0 && mrb->heaps) { - mrb_garbage_collect(mrb); - p2 = (mrb->allocf)(mrb, 0, len, mrb->ud); - } - return p2; + return mrb_realloc_simple(mrb, 0, len); } void* |
