From 946cf0e700fd7ed540f18a01a4796642ba2f10ae Mon Sep 17 00:00:00 2001 From: akr Date: Sat, 16 Feb 2008 09:02:12 +0000 Subject: * 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 --- string.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'string.c') 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) { -- cgit