summaryrefslogtreecommitdiff
path: root/string.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-06-14 01:53:32 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-06-14 01:53:32 +0000
commit9729275473b8dc5ec9f8bac313d786b9dc377548 (patch)
treec434b9b771499cd49ac771f344c8f1a28bc02e09 /string.c
parent308960a44e3ad1e0760e98dc88bc210c621d5969 (diff)
string.c: fix wrong capa
* string.c (rb_str_resize): update capa only when buffer get reallocated. http://d.hatena.ne.jp/nagachika/20140613/ruby_trunk_changes_46413_46420#r46413 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46424 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r--string.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/string.c b/string.c
index faf12f23e8..a8fd16ece3 100644
--- a/string.c
+++ b/string.c
@@ -1972,6 +1972,7 @@ rb_str_resize(VALUE str, long len)
slen = RSTRING_LEN(str);
{
+ long capa;
const int termlen = TERM_LEN(str);
if (STR_EMBED_P(str)) {
if (len == slen) return str;
@@ -1996,11 +1997,12 @@ rb_str_resize(VALUE str, long len)
if (len == slen) return str;
str_make_independent_expand(str, len - slen);
}
- else if (slen < len || (RSTRING(str)->as.heap.aux.capa - len) > (len < 1024 ? len : 1024)) {
+ else if ((capa = RSTRING(str)->as.heap.aux.capa) < len ||
+ (capa - len) > (len < 1024 ? len : 1024)) {
REALLOC_N(RSTRING(str)->as.heap.ptr, char, len + termlen);
+ RSTRING(str)->as.heap.aux.capa = len;
}
else if (len == slen) return str;
- RSTRING(str)->as.heap.aux.capa = len;
RSTRING(str)->as.heap.len = len;
TERM_FILL(RSTRING(str)->as.heap.ptr + len, termlen); /* sentinel */
}