Actions
Bug #11972
closedCGI::pretty がコメント内のhtmlタグにより範囲を見失う
Status:
Closed
Assignee:
-
Target version:
-
ruby -v:
ruby 2.0.0p645 (2015-04-13 revision 50299) [universal.x86_64-darwin15]
Description
以下のようなコードで ArgumentError が再現します。
#!/usr/bin/env ruby
require 'cgi'
puts CGI.pretty(DATA.read)
__END__
<script>
// <!--
alert('<p></p>');
// -->
</script>
手元では CGI::pretty の1行目を
lines = string.gsub(/(?!\A)<[^!]?>/m, "\n\0").gsub(/<.?>(?!\n)/m, "\0\n")
というようにしてコメントを無視させることで回避してみました。
はてなブログの html コードをそのまま読ませて気づいたのですが、script 要素内で
html を挿入していたりすると発生するようです。
Actions
Like0
Like0