summaryrefslogtreecommitdiff
path: root/string.c
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-11 14:26:26 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-11 14:26:26 +0000
commite350fe247af325d9c148b27617dce77750e989a4 (patch)
treed4748ae70305f736defc94c82cfec9142c54d31d /string.c
parent857b3018dd7b76828b0d61921cb24de59778765f (diff)
* string.c (string.c): call rb_str_buf_append to update encoding of
str1, even if str2 is empty. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14996 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r--string.c34
1 files changed, 15 insertions, 19 deletions
diff --git a/string.c b/string.c
index c031431819..9b79453755 100644
--- a/string.c
+++ b/string.c
@@ -1194,26 +1194,22 @@ rb_str_append(VALUE str, VALUE str2)
int cr, cr2;
StringValue(str2);
- if (RSTRING_LEN(str2) > 0) {
- if (STR_ASSOC_P(str)) {
- long len = RSTRING_LEN(str)+RSTRING_LEN(str2);
- enc = rb_enc_check(str, str2);
- cr = ENC_CODERANGE(str);
- if ((cr2 = ENC_CODERANGE(str2)) > cr) cr = cr2;
- rb_str_modify(str);
- REALLOC_N(RSTRING(str)->as.heap.ptr, char, len+1);
- memcpy(RSTRING(str)->as.heap.ptr + RSTRING(str)->as.heap.len,
- RSTRING_PTR(str2), RSTRING_LEN(str2)+1);
- RSTRING(str)->as.heap.len = len;
- rb_enc_associate(str, enc);
- ENC_CODERANGE_SET(str, cr);
- }
- else {
- return rb_str_buf_append(str, str2);
- }
+ if (RSTRING_LEN(str2) > 0 && STR_ASSOC_P(str)) {
+ long len = RSTRING_LEN(str)+RSTRING_LEN(str2);
+ enc = rb_enc_check(str, str2);
+ cr = ENC_CODERANGE(str);
+ if ((cr2 = ENC_CODERANGE(str2)) > cr) cr = cr2;
+ rb_str_modify(str);
+ REALLOC_N(RSTRING(str)->as.heap.ptr, char, len+1);
+ memcpy(RSTRING(str)->as.heap.ptr + RSTRING(str)->as.heap.len,
+ RSTRING_PTR(str2), RSTRING_LEN(str2)+1);
+ RSTRING(str)->as.heap.len = len;
+ rb_enc_associate(str, enc);
+ ENC_CODERANGE_SET(str, cr);
+ OBJ_INFECT(str, str2);
+ return str;
}
- OBJ_INFECT(str, str2);
- return str;
+ return rb_str_buf_append(str, str2);
}