summaryrefslogtreecommitdiffstats
path: root/string.c
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-16 09:02:12 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-16 09:02:12 +0000
commit946cf0e700fd7ed540f18a01a4796642ba2f10ae (patch)
treef42c40e7fe290c2f8923fddd828bf985ace80302 /string.c
parentdf2c1766b74d9606d9eb3290effaffcdf935f3c4 (diff)
downloadruby-946cf0e700fd7ed540f18a01a4796642ba2f10ae.tar.gz
ruby-946cf0e700fd7ed540f18a01a4796642ba2f10ae.tar.xz
ruby-946cf0e700fd7ed540f18a01a4796642ba2f10ae.zip
* encoding.c (rb_enc_compatible): empty strings are always compatible.
* string.c (rb_enc_cr_str_buf_cat): ditto. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15506 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r--string.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/string.c b/string.c
index 5d2d8bdfd..23f1d0add 100644
--- a/string.c
+++ b/string.c
@@ -597,7 +597,6 @@ rb_enc_strlen(const char *p, const char *e, rb_encoding *enc)
if (rb_enc_mbmaxlen(enc) == rb_enc_mbminlen(enc)) {
return (e - p) / rb_enc_mbminlen(enc);
}
-
else if (rb_enc_asciicompat(enc)) {
c = 0;
while (p < e) {
@@ -1303,6 +1302,13 @@ rb_enc_cr_str_buf_cat(VALUE str, const char *ptr, long len,
rb_encoding *str_enc = rb_enc_from_index(str_encindex);
rb_encoding *ptr_enc = rb_enc_from_index(ptr_encindex);
if (!rb_enc_asciicompat(str_enc) || !rb_enc_asciicompat(ptr_enc)) {
+ if (len == 0)
+ return str;
+ if (RSTRING_LEN(str) == 0) {
+ rb_str_buf_cat(str, ptr, len);
+ ENCODING_CODERANGE_SET(str, ptr_encindex, ptr_cr);
+ return str;
+ }
goto incompatible;
}
if (ptr_cr == ENC_CODERANGE_UNKNOWN) {