summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/ruby/test_transcode.rb22
-rw-r--r--transcode.c6
-rw-r--r--version.h2
3 files changed, 1 insertions, 29 deletions
diff --git a/test/ruby/test_transcode.rb b/test/ruby/test_transcode.rb
index c8b0034e06..04c8248697 100644
--- a/test/ruby/test_transcode.rb
+++ b/test/ruby/test_transcode.rb
@@ -126,28 +126,6 @@ class TestTranscode < Test::Unit::TestCase
assert_equal("D\xFCrst".force_encoding('iso-8859-2'), "D\xFCrst".encode('iso-8859-2', 'iso-8859-1'))
end
- def test_encode_xml_multibyte
- encodings = %w'UTF-8 UTF-16LE UTF-16BE UTF-32LE UTF-32BE'
- encodings.each do |src_enc|
- encodings.each do |dst_enc|
- escaped = "<>".encode(src_enc).encode(dst_enc, :xml=>:text)
- assert_equal("&lt;&gt;", escaped.encode('UTF-8'), "failed encoding #{src_enc} to #{dst_enc} with xml: :text")
-
- escaped = '<">'.encode(src_enc).encode(dst_enc, :xml=>:attr)
- assert_equal('"&lt;&quot;&gt;"', escaped.encode('UTF-8'), "failed encoding #{src_enc} to #{dst_enc} with xml: :attr")
-
- escaped = "<>".encode(src_enc).force_encoding("UTF-8").encode(dst_enc, src_enc, :xml=>:text)
- assert_equal("&lt;&gt;", escaped.encode('UTF-8'), "failed encoding #{src_enc} to #{dst_enc} with xml: :text")
-
- escaped = '<">'.encode(src_enc).force_encoding("UTF-8").encode(dst_enc, src_enc, :xml=>:attr)
- assert_equal('"&lt;&quot;&gt;"', escaped.encode('UTF-8'), "failed encoding #{src_enc} to #{dst_enc} with xml: :attr")
- end
- end
- # regression test; U+6E7F (湿) uses the same bytes in ISO-2022-JP as "<>"
- assert_equal( "&lt;&gt;\u6E7F", "<>\u6E7F".encode("ISO-2022-JP").encode("ISO-2022-JP", :xml=>:text).encode("UTF-8"))
- assert_equal("\"&lt;&gt;\u6E7F\"", "<>\u6E7F".encode("ISO-2022-JP").encode("ISO-2022-JP", :xml=>:attr).encode("UTF-8"))
- end
-
def test_ascii_range
encodings = [
'US-ASCII', 'ASCII-8BIT',
diff --git a/transcode.c b/transcode.c
index d2abd9e0e5..a72afdc44b 100644
--- a/transcode.c
+++ b/transcode.c
@@ -2719,12 +2719,6 @@ str_transcode0(int argc, VALUE *argv, VALUE *self, int ecflags, VALUE ecopts)
}
}
else {
- if (senc && denc && !rb_enc_asciicompat(senc) && !rb_enc_asciicompat(denc)) {
- rb_encoding *utf8 = rb_utf8_encoding();
- str = rb_str_conv_enc(str, senc, utf8);
- senc = utf8;
- sname = "UTF-8";
- }
if (encoding_equal(sname, dname)) {
sname = "";
dname = "";
diff --git a/version.h b/version.h
index 217abd8721..f8e081701c 100644
--- a/version.h
+++ b/version.h
@@ -12,7 +12,7 @@
# define RUBY_VERSION_MINOR RUBY_API_VERSION_MINOR
#define RUBY_VERSION_TEENY 2
#define RUBY_RELEASE_DATE RUBY_RELEASE_YEAR_STR"-"RUBY_RELEASE_MONTH_STR"-"RUBY_RELEASE_DAY_STR
-#define RUBY_PATCHLEVEL 106
+#define RUBY_PATCHLEVEL 105
#define RUBY_RELEASE_YEAR 2021
#define RUBY_RELEASE_MONTH 7