Commit e33249e2 authored by Yukihiro "Matz" Matsumoto's avatar Yukihiro "Matz" Matsumoto

Merge pull request #1318 from Fleurer/refactor_realloc

refactor mrb_realloc() in gc.c
parents 466d0ad7 68f31e94
...@@ -242,6 +242,7 @@ mrb_sym mrb_intern(mrb_state *mrb,const char *cstr) ...@@ -242,6 +242,7 @@ mrb_sym mrb_intern(mrb_state *mrb,const char *cstr)
void *mrb_malloc(mrb_state*, size_t); /* raise RuntimeError if no mem */ void *mrb_malloc(mrb_state*, size_t); /* raise RuntimeError if no mem */
void *mrb_calloc(mrb_state*, size_t, size_t); /* ditto */ void *mrb_calloc(mrb_state*, size_t, size_t); /* ditto */
void *mrb_realloc(mrb_state*, void*, size_t); /* ditto */ void *mrb_realloc(mrb_state*, void*, size_t); /* ditto */
void *mrb_realloc_simple(mrb_state*, void*, size_t); /* return NULL if no memory available */
void *mrb_malloc_simple(mrb_state*, size_t); /* return NULL if no memory available */ void *mrb_malloc_simple(mrb_state*, size_t); /* return NULL if no memory available */
struct RBasic *mrb_obj_alloc(mrb_state*, enum mrb_vtype, struct RClass*); struct RBasic *mrb_obj_alloc(mrb_state*, enum mrb_vtype, struct RClass*);
void mrb_free(mrb_state*, void*); void mrb_free(mrb_state*, void*);
......
...@@ -148,18 +148,28 @@ gettimeofday_time(void) ...@@ -148,18 +148,28 @@ gettimeofday_time(void)
#define GC_STEP_SIZE 1024 #define GC_STEP_SIZE 1024
void* void*
mrb_realloc(mrb_state *mrb, void *p, size_t len) mrb_realloc_simple(mrb_state *mrb, void *p, size_t len)
{ {
void *p2; void *p2;
p2 = (mrb->allocf)(mrb, p, len, mrb->ud); p2 = (mrb->allocf)(mrb, p, len, mrb->ud);
if (!p2 && len > 0 && mrb->heaps) { if (!p2 && len > 0 && mrb->heaps) {
mrb_garbage_collect(mrb); mrb_garbage_collect(mrb);
p2 = (mrb->allocf)(mrb, p, len, mrb->ud); 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 (!p2 && len) {
if (mrb->out_of_memory) { if (mrb->out_of_memory) {
/* mrb_panic(mrb); */ /* mrb_panic(mrb); */
...@@ -185,14 +195,7 @@ mrb_malloc(mrb_state *mrb, size_t len) ...@@ -185,14 +195,7 @@ mrb_malloc(mrb_state *mrb, size_t len)
void* void*
mrb_malloc_simple(mrb_state *mrb, size_t len) mrb_malloc_simple(mrb_state *mrb, size_t len)
{ {
void *p2; return mrb_realloc_simple(mrb, 0, len);
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;
} }
void* void*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment