summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-10-17 05:21:10 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-10-17 05:21:10 +0000
commita5bef8dbc5df71e34369d1bf1753f233f44f5f1e (patch)
treebc809c74612a8b37dd0f438b42701d8f5eaaaf57
parent447a843c8104fc15310c74f16c74bc9f5fcaf3d6 (diff)
downloadruby-a5bef8dbc5df71e34369d1bf1753f233f44f5f1e.tar.gz
ruby-a5bef8dbc5df71e34369d1bf1753f233f44f5f1e.tar.xz
ruby-a5bef8dbc5df71e34369d1bf1753f233f44f5f1e.zip
* re.c (rb_reg_s_union): the last check was not complete.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@13733 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--re.c12
2 files changed, 13 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index b646fa33b..028d4d2d9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Wed Oct 17 13:54:28 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * re.c (rb_reg_s_union): the last check was not complete.
+
Wed Oct 17 11:30:55 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
* encoding.c (rb_enc_from_encoding, rb_enc_register): associate index
diff --git a/re.c b/re.c
index c5679718c..9501595bf 100644
--- a/re.c
+++ b/re.c
@@ -1783,7 +1783,8 @@ rb_reg_s_union(VALUE self, VALUE args0)
else {
int i;
VALUE source = rb_str_buf_new(0);
- VALUE enc0 = rb_obj_encoding(rb_ary_entry(args0, 0));
+ int mbs = Qfalse;
+ rb_encoding *enc = 0;
for (i = 0; i < argc; i++) {
volatile VALUE v;
@@ -1792,12 +1793,17 @@ rb_reg_s_union(VALUE self, VALUE args0)
rb_str_buf_cat2(source, "|");
v = rb_check_regexp_type(e);
if (!NIL_P(v)) {
- rb_enc_check(enc0, v);
v = rb_reg_to_s(v);
}
else {
v = rb_reg_s_quote(Qnil, e);
- rb_enc_check(enc0, rb_obj_encoding(v));
+ }
+ if (mbs || rb_enc_str_coderange(v) != ENC_CODERANGE_SINGLE) {
+ if (!enc) enc = rb_enc_get(v);
+ else if (mbs && enc != rb_enc_get(v)) {
+ rb_raise(rb_eArgError, "regexp encodings differ");
+ }
+ mbs = Qtrue;
}
rb_str_append(source, v);
}