summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2019-12-05 09:40:44 +0900
committerGitHub <[email protected]>2019-12-05 09:40:44 +0900
commit52318b3359683a3127728d4b0299f0f63703c346 (patch)
treed5298c35e448a615d6c7bd293647bdff5825ecba
parentbc22991ac3ec08fa9e48fc46e49e69115a386ed9 (diff)
parenta030446a94fc18bd2b6881f697417df3f0ddb179 (diff)
downloadmruby-52318b3359683a3127728d4b0299f0f63703c346.tar.gz
mruby-52318b3359683a3127728d4b0299f0f63703c346.zip
Merge pull request #4851 from shuujii/refine-mrb_alloca
Refine `mrb_alloca()`
-rw-r--r--src/gc.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/gc.c b/src/gc.c
index 2fe1d59c9..40c85a373 100644
--- a/src/gc.c
+++ b/src/gc.c
@@ -280,8 +280,9 @@ mrb_free(mrb_state *mrb, void *p)
MRB_API void*
mrb_alloca(mrb_state *mrb, size_t size)
{
- mrb_value str = mrb_str_new(mrb, NULL, size);
- return RSTRING_PTR(str);
+ struct RString *s;
+ s = (struct RString*)mrb_obj_alloc(mrb, MRB_TT_STRING, mrb->string_class);
+ return s->as.heap.ptr = (char*)mrb_malloc(mrb, size);
}
static mrb_bool