summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornormal <normal@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-05-03 01:24:09 +0000
committernormal <normal@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-05-03 01:24:09 +0000
commit0e32c7c10abb1080c88af76574bcc2aa25c78cd5 (patch)
treedefcf5a858f08857f5dbe88117e0fbb95b7f63c5
parent9b6dec6cac17a507792add61247772ac76d23f48 (diff)
Revert "ext/cgi/escape: preserve String subclass in result"
This reverts commit 6afea14043b0c0e603f26c89ae0d043f65852668 r63328 I misread the original bug report and got results flipped. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@63330 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ext/cgi/escape/escape.c10
-rw-r--r--test/cgi/test_cgi_util.rb21
2 files changed, 5 insertions, 26 deletions
diff --git a/ext/cgi/escape/escape.c b/ext/cgi/escape/escape.c
index a36770bc11..ced1b182eb 100644
--- a/ext/cgi/escape/escape.c
+++ b/ext/cgi/escape/escape.c
@@ -59,7 +59,7 @@ optimized_escape_html(VALUE str)
case '<':
case '>':
if (!dest) {
- dest = rb_str_new_with_class(str, 0, 0);
+ dest = rb_str_buf_new(len);
}
rb_str_cat(dest, cstr + beg, i - beg);
@@ -151,7 +151,7 @@ optimized_unescape_html(VALUE str)
i += clen;
if (overflow || cc >= charlimit || cstr[i] != ';') continue;
if (!dest) {
- dest = rb_str_new_with_class(str, 0, 0);
+ dest = rb_str_buf_new(len);
}
rb_str_cat(dest, cstr + beg, plen);
if (charlimit > 256) {
@@ -168,7 +168,7 @@ optimized_unescape_html(VALUE str)
continue;
}
if (!dest) {
- dest = rb_str_new_with_class(str, 0, 0);
+ dest = rb_str_buf_new(len);
}
rb_str_cat(dest, cstr + beg, plen);
rb_str_cat(dest, &c, 1);
@@ -219,7 +219,7 @@ optimized_escape(VALUE str)
const unsigned char c = (unsigned char)cstr[i];
if (!url_unreserved_char(c)) {
if (!dest) {
- dest = rb_str_new_with_class(str, 0, 0);
+ dest = rb_str_buf_new(len);
}
rb_str_cat(dest, cstr + beg, i - beg);
@@ -278,7 +278,7 @@ optimized_unescape(VALUE str, VALUE encoding)
}
if (!dest) {
- dest = rb_str_new_with_class(str, 0, 0);
+ dest = rb_str_buf_new(len);
}
rb_str_cat(dest, cstr + beg, i - beg);
diff --git a/test/cgi/test_cgi_util.rb b/test/cgi/test_cgi_util.rb
index 786e6f18a3..f2f5575efb 100644
--- a/test/cgi/test_cgi_util.rb
+++ b/test/cgi/test_cgi_util.rb
@@ -197,25 +197,4 @@ class CGIUtilTest < Test::Unit::TestCase
assert_equal('&lt;BR&gt;<A HREF="url"></A>', unescape_element(escapeHTML('<BR><A HREF="url"></A>'), "A", "IMG"))
assert_equal('&lt;BR&gt;<A HREF="url"></A>', unescape_element(escapeHTML('<BR><A HREF="url"></A>'), ["A", "IMG"]))
end
-
- def test_escape_string_subclass
- sc = Class.new(String).freeze
- str = sc.new('>')
- msg = '[ruby-core:86847] [Bug #14732]'
- assert_not_instance_of String, str
-
- html = escapeHTML(str)
- assert_instance_of sc, html, msg
- assert_equal '&gt;', html
- orig = unescapeHTML(html)
- assert_instance_of sc, orig, msg
- assert_equal '>', orig
-
- url = escape(str)
- assert_instance_of sc, url, msg
- assert_equal '%3E', url
- orig = unescape(url)
- assert_instance_of sc, orig, msg
- assert_equal '>', orig
- end
end