mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* NEWS (REXML::Parsers::SAX2Parser): Add about this change.
* lib/rexml/parsers/sax2parser.rb (REXML::Parsers::SAX2Parser#parse): Fix wrong number of arguments. Document says "an array of the entity declaration" but it passes two or more arguments. This is a bug but it break backward compatibility. Reported by Ippei Obayashi. [Bug #8731] [ruby-dev:47582] * lib/rexml/sax2listener.rb (REXML::SAX2Listener#entitydecl): ditto. The listener template accepted two arguments. * test/rexml/parser/test_sax2.rb: Add tests for external ID case. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42514 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
7e8b43687c
commit
ce89dedde3
4 changed files with 37 additions and 4 deletions
|
@ -22,9 +22,9 @@ class TestSAX2Parser < Test::Unit::TestCase
|
|||
@entity_declarations = []
|
||||
end
|
||||
|
||||
def entitydecl(*args)
|
||||
def entitydecl(declaration)
|
||||
super
|
||||
@entity_declarations << args
|
||||
@entity_declarations << declaration
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -51,6 +51,33 @@ class TestSAX2Parser < Test::Unit::TestCase
|
|||
INTERNAL_SUBSET
|
||||
end
|
||||
end
|
||||
|
||||
class TestExternlID < self
|
||||
class TestSystem < self
|
||||
def test_without_ndata
|
||||
declaration = [
|
||||
"name",
|
||||
"SYSTEM", "system-literal",
|
||||
]
|
||||
assert_equal([declaration],
|
||||
parse(<<-INTERNAL_SUBSET))
|
||||
<!ENTITY name SYSTEM "system-literal">
|
||||
INTERNAL_SUBSET
|
||||
end
|
||||
end
|
||||
|
||||
class TestPublic < self
|
||||
def test_without_ndata
|
||||
declaration = [
|
||||
"name",
|
||||
"PUBLIC", "public-literal", "system-literal",
|
||||
]
|
||||
assert_equal([declaration], parse(<<-INTERNAL_SUBSET))
|
||||
<!ENTITY name PUBLIC "public-literal" "system-literal">
|
||||
INTERNAL_SUBSET
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue