summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-11 07:55:23 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-11 07:55:23 +0000
commit7a2fcea0346afd85c9da1fa94993f47e9b1dda16 (patch)
treea6464d20dbcc5b3ab88888d6d314bdf9b61c909c
parent3aaf1f8d9630d0cb3e6f11a87eef6c503371da7c (diff)
downloadruby-7a2fcea0346afd85c9da1fa94993f47e9b1dda16.tar.gz
ruby-7a2fcea0346afd85c9da1fa94993f47e9b1dda16.tar.xz
ruby-7a2fcea0346afd85c9da1fa94993f47e9b1dda16.zip
* string.c (rb_str_append): performance improvement.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@14992 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--string.c14
2 files changed, 11 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index 7e480811b..9bfc80af0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Fri Jan 11 16:55:21 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * string.c (rb_str_append): performance improvement.
+
Fri Jan 11 12:35:56 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* configure.in: moved broken syscall checks from process.c etc.
diff --git a/string.c b/string.c
index 4b10503e8..c03143181 100644
--- a/string.c
+++ b/string.c
@@ -1194,25 +1194,25 @@ rb_str_append(VALUE str, VALUE str2)
int cr, cr2;
StringValue(str2);
- enc = rb_enc_check(str, str2);
- cr = ENC_CODERANGE(str);
- if ((cr2 = ENC_CODERANGE(str2)) > cr) cr = cr2;
- rb_str_modify(str);
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 {
- rb_str_buf_append(str, str2);
+ return rb_str_buf_append(str, str2);
}
}
OBJ_INFECT(str, str2);
- rb_enc_associate(str, enc);
- ENC_CODERANGE_SET(str, cr);
return str;
}