diff options
| author | mirichi <[email protected]> | 2013-06-22 08:06:48 +0900 |
|---|---|---|
| committer | mirichi <[email protected]> | 2013-06-22 08:06:48 +0900 |
| commit | a01845b502a902ee1de2f34645177e64fafbb551 (patch) | |
| tree | 86d9a57bc44974d111dabb5e46d4f3e89ffe026d /src/string.c | |
| parent | a5f63e486473595d67601851f00b6bb96b377a8d (diff) | |
| parent | 8cb730ae4e63a953819023a2e31265d758b9fe42 (diff) | |
| download | mruby-a01845b502a902ee1de2f34645177e64fafbb551.tar.gz mruby-a01845b502a902ee1de2f34645177e64fafbb551.zip | |
Merge remote-tracking branch 'remotes/mruby/master'
Diffstat (limited to 'src/string.c')
| -rw-r--r-- | src/string.c | 14 |
1 files changed, 3 insertions, 11 deletions
diff --git a/src/string.c b/src/string.c index 77f81ecc6..328266df9 100644 --- a/src/string.c +++ b/src/string.c @@ -104,10 +104,9 @@ mrb_str_resize(mrb_state *mrb, mrb_value str, mrb_int len) mrb_str_modify(mrb, s); slen = s->len; if (len != slen) { - if (slen < len || slen -len > 1024) { - s->ptr = (char *)mrb_realloc(mrb, s->ptr, len+1); + if (slen < len || slen - len > 256) { + RESIZE_CAPA(s, len); } - s->aux.capa = len; s->len = len; s->ptr[len] = '\0'; /* sentinel */ } @@ -261,14 +260,7 @@ mrb_str_new_cstr(mrb_state *mrb, const char *p) len = 0; } - s = mrb_obj_alloc_string(mrb); - s->ptr = (char *)mrb_malloc(mrb, len+1); - if (p) { - memcpy(s->ptr, p, len); - } - s->ptr[len] = 0; - s->len = (mrb_int)len; - s->aux.capa = (mrb_int)len; + s = str_new(mrb, p, len); return mrb_obj_value(s); } |
