aboutsummaryrefslogtreecommitdiffstats
path: root/encoding.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 /encoding.c
parent5daecbc0e14f840059db48f34f6b000df54c40cc (diff)
downloadruby-2d1d6c470563375ec4d71353fdf8de3aa4c40ef2.tar.gz
* 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 'encoding.c')
-rw-r--r--encoding.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/encoding.c b/encoding.c
index e2d3cdd8da..289fba72f9 100644
--- a/encoding.c
+++ b/encoding.c
@@ -45,9 +45,14 @@ enc_new(rb_encoding *encoding)
}
VALUE
-rb_enc_from_encoding(rb_encoding *enc)
+rb_enc_from_encoding(rb_encoding *encoding)
{
- return enc_initialized_p(enc) ? ENC_FROM_ENCODING(enc) : enc_new(enc);
+ VALUE enc;
+ if (enc_initialized_p(encoding))
+ return ENC_FROM_ENCODING(encoding);
+ enc = enc_new(encoding);
+ rb_enc_associate(enc, encoding);
+ return enc;
}
static rb_encoding *
@@ -136,7 +141,8 @@ rb_enc_register(const char *name, rb_encoding *encoding)
encoding = ent->enc;
encoding->name = name;
if (rb_cEncoding) {
- enc_new(encoding);
+ VALUE enc = enc_new(encoding);
+ rb_enc_associate_index(enc, newsize);
}
else {
encoding->auxiliary_data = ENC_UNINITIALIZED;
@@ -229,6 +235,8 @@ enc_capable(VALUE obj)
case T_REGEXP:
case T_FILE:
return Qtrue;
+ case T_DATA:
+ if (RDATA(obj)->dmark == enc_mark) return Qtrue;
default:
return Qfalse;
}