summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-05-29 15:12:20 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-05-29 15:12:20 +0000
commit57569615ea556bdfb18ec4c04778b91b22da870a (patch)
tree71d92ed12292fff94be107a84485a1fc4bde2ee2
parente9b851af73549aa9c97af1a5fb2171152f0585a6 (diff)
merges r28072 from trunk into ruby_1_9_2.
-- * string.c (str_replace_shared): change embedded state atomically. [ruby-core:29953] [ruby-dev:41456] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_2@28075 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--string.c2
2 files changed, 6 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index efa9b8640a..76e067188d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat May 29 23:30:33 2010 Yusuke Endoh <mame@tsg.ne.jp>
+
+ * string.c (str_replace_shared): change embedded state atomically.
+ [ruby-core:29953] [ruby-dev:41456]
+
Fri May 28 00:32:25 2010 Yusuke Endoh <mame@tsg.ne.jp>
* insns.def (invokesuper): check consistency between class of self and
diff --git a/string.c b/string.c
index f2f49abaff..ae4289380f 100644
--- a/string.c
+++ b/string.c
@@ -613,8 +613,8 @@ str_replace_shared(VALUE str2, VALUE str)
STR_SET_EMBED_LEN(str2, RSTRING_LEN(str));
}
else {
- FL_SET(str2, STR_NOEMBED);
str = rb_str_new_frozen(str);
+ FL_SET(str2, STR_NOEMBED);
RSTRING(str2)->as.heap.len = RSTRING_LEN(str);
RSTRING(str2)->as.heap.ptr = RSTRING_PTR(str);
RSTRING(str2)->as.heap.aux.shared = str;