summaryrefslogtreecommitdiffhomepage
path: root/src/string.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-06-24 00:41:48 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2013-06-24 00:41:48 +0900
commitec9fdd5c4ca8cfc31b96048124c1925d2e20698e (patch)
tree07d2754d7a6f23bc240e38f709231168847b1e35 /src/string.c
parentb01670a3d391de3c7df868a8285e570564ea46cd (diff)
parent8cb730ae4e63a953819023a2e31265d758b9fe42 (diff)
downloadmruby-ec9fdd5c4ca8cfc31b96048124c1925d2e20698e.tar.gz
mruby-ec9fdd5c4ca8cfc31b96048124c1925d2e20698e.zip
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/string.c')
-rw-r--r--src/string.c14
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);
}