summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-18 09:14:46 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-18 09:14:46 +0000
commit6f5c530ada2bb571458bef7cd8be8958c76f2737 (patch)
treedfca599b50661165e12f8d72ae14d89cd0dbf0ce
parent6d33d9cfb832fbd318cd460dfba5b1b3a2edfb5a (diff)
downloadruby-6f5c530ada2bb571458bef7cd8be8958c76f2737.tar.gz
ruby-6f5c530ada2bb571458bef7cd8be8958c76f2737.tar.xz
ruby-6f5c530ada2bb571458bef7cd8be8958c76f2737.zip
* string.c (rb_str_splice): propagate encoding.
* string.c (rb_str_subpat_set): ditto. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@14295 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--string.c5
2 files changed, 10 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 328f1ba02..73001cd73 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Tue Dec 18 18:09:15 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * string.c (rb_str_splice): propagate encoding.
+
+ * string.c (rb_str_subpat_set): ditto.
+
Tue Dec 18 17:27:12 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
* object.c (rb_obj_freeze): preserve frozen state of immediate
diff --git a/string.c b/string.c
index fb3a116c5..105fe6a15 100644
--- a/string.c
+++ b/string.c
@@ -2142,6 +2142,7 @@ rb_str_splice(VALUE str, long beg, long len, VALUE val)
beg = p - RSTRING_PTR(str); /* physical position */
len = e - p; /* physical length */
rb_str_splice_0(str, beg, len, val);
+ rb_enc_associate(str, enc);
}
void
@@ -2155,6 +2156,7 @@ rb_str_subpat_set(VALUE str, VALUE re, int nth, VALUE val)
{
VALUE match;
long start, end, len;
+ rb_encoding *enc;
if (rb_reg_search(re, str, 0, 0) < 0) {
rb_raise(rb_eIndexError, "regexp not matched");
@@ -2178,8 +2180,9 @@ rb_str_subpat_set(VALUE str, VALUE re, int nth, VALUE val)
end = RMATCH(match)->END(nth);
len = end - start;
StringValue(val);
- rb_enc_check(str, val);
+ enc = rb_enc_check(str, val);
rb_str_splice_0(str, start, len, val);
+ rb_enc_associate(str, enc);
}
static VALUE