зеркало из https://github.com/github/ruby.git
* lib/rexml/parsers/ultralightparser.rb
(REXML::Parsers::UltraLightParser#parse): Fix wrong :start_doctype position. [Bug #9061] [ruby-dev:47778] Patch by Ippei Obayashi. Thanks!!! * test/rexml/parser/test_ultra_light.rb: Add a test for this case. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43693 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
bc3db2a512
Коммит
a66a9fbb10
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
Sat Nov 16 18:28:08 2013 Kouhei Sutou <kou@cozmixng.org>
|
||||||
|
|
||||||
|
* lib/rexml/parsers/ultralightparser.rb
|
||||||
|
(REXML::Parsers::UltraLightParser#parse): Fix wrong :start_doctype
|
||||||
|
position.
|
||||||
|
[Bug #9061] [ruby-dev:47778]
|
||||||
|
Patch by Ippei Obayashi. Thanks!!!
|
||||||
|
|
||||||
|
* test/rexml/parser/test_ultra_light.rb: Add a test for this case.
|
||||||
|
|
||||||
Sat Nov 16 02:13:56 2013 Masaya Tarui <tarui@ruby-lang.org>
|
Sat Nov 16 02:13:56 2013 Masaya Tarui <tarui@ruby-lang.org>
|
||||||
|
|
||||||
* cont.c : Introduce ensure rollback mechanism. Please see below.
|
* cont.c : Introduce ensure rollback mechanism. Please see below.
|
||||||
|
|
|
@ -27,7 +27,7 @@ module REXML
|
||||||
break
|
break
|
||||||
when :end_doctype
|
when :end_doctype
|
||||||
context = context[1]
|
context = context[1]
|
||||||
when :start_element, :doctype
|
when :start_element, :start_doctype
|
||||||
context << event
|
context << event
|
||||||
event[1,0] = [context]
|
event[1,0] = [context]
|
||||||
context = event
|
context = event
|
||||||
|
|
|
@ -0,0 +1,67 @@
|
||||||
|
require "test/unit"
|
||||||
|
require "rexml/parsers/ultralightparser"
|
||||||
|
|
||||||
|
class TestUltraLightParser < Test::Unit::TestCase
|
||||||
|
class TestDocumentTypeDeclaration < self
|
||||||
|
def test_entity_declaration
|
||||||
|
assert_equal([
|
||||||
|
[
|
||||||
|
:start_doctype,
|
||||||
|
:parent,
|
||||||
|
"root",
|
||||||
|
"SYSTEM",
|
||||||
|
"urn:x-test",
|
||||||
|
nil,
|
||||||
|
[:entitydecl, "name", "value"]
|
||||||
|
],
|
||||||
|
[:text, "\n"],
|
||||||
|
[:start_element, :parent, "root", {}],
|
||||||
|
[:text, "\n"],
|
||||||
|
],
|
||||||
|
parse(<<-INTERNAL_SUBSET))
|
||||||
|
<!ENTITY name "value">
|
||||||
|
INTERNAL_SUBSET
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
def xml(internal_subset)
|
||||||
|
<<-XML
|
||||||
|
<!DOCTYPE root SYSTEM "urn:x-test" [
|
||||||
|
#{internal_subset}
|
||||||
|
]>
|
||||||
|
<root/>
|
||||||
|
XML
|
||||||
|
end
|
||||||
|
|
||||||
|
def parse(internal_subset)
|
||||||
|
parser = REXML::Parsers::UltraLightParser.new(xml(internal_subset))
|
||||||
|
normalize(parser.parse)
|
||||||
|
end
|
||||||
|
|
||||||
|
def normalize(root)
|
||||||
|
root.collect do |child|
|
||||||
|
normalize_child(child)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def normalize_child(child)
|
||||||
|
tag = child.first
|
||||||
|
case tag
|
||||||
|
when :start_doctype
|
||||||
|
normalized_parent = :parent
|
||||||
|
normalized_doctype = child.dup
|
||||||
|
normalized_doctype[1] = normalized_parent
|
||||||
|
normalized_doctype
|
||||||
|
when :start_element
|
||||||
|
tag, parent, name, attributes, *children = child
|
||||||
|
normalized_parent = :parent
|
||||||
|
normalized_children = children.collect do |sub_child|
|
||||||
|
normalize_child(sub_child)
|
||||||
|
end
|
||||||
|
[tag, normalized_parent, name, attributes, *normalized_children]
|
||||||
|
else
|
||||||
|
child
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Загрузка…
Ссылка в новой задаче