summaryrefslogtreecommitdiff
path: root/re.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-10-17 02:30:57 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-10-17 02:30:57 +0000
commit2d1d6c470563375ec4d71353fdf8de3aa4c40ef2 (patch)
tree9750062206ff7b66dfb959a7fc0042eeefc9031a /re.c
parent5daecbc0e14f840059db48f34f6b000df54c40cc (diff)
* encoding.c (rb_enc_from_encoding, rb_enc_register): associate index
to self. * encoding.c (enc_capable): Encoding objects are encoding capable. * re.c (rb_reg_s_union): check if encoding matching by exact encoding objects. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13732 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 're.c')
-rw-r--r--re.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/re.c b/re.c
index 605c40f176..c5679718c4 100644
--- a/re.c
+++ b/re.c
@@ -1783,7 +1783,7 @@ rb_reg_s_union(VALUE self, VALUE args0)
else {
int i;
VALUE source = rb_str_buf_new(0);
- VALUE tmp = rb_ary_entry(args0, 0);
+ VALUE enc0 = rb_obj_encoding(rb_ary_entry(args0, 0));
for (i = 0; i < argc; i++) {
volatile VALUE v;
@@ -1792,12 +1792,12 @@ 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(tmp, v);
+ rb_enc_check(enc0, v);
v = rb_reg_to_s(v);
}
else {
- rb_enc_check(tmp, e);
v = rb_reg_s_quote(Qnil, e);
+ rb_enc_check(enc0, rb_obj_encoding(v));
}
rb_str_append(source, v);
}