mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 08:34:57 +00:00
LibXML: Actually append resolved references when parsing content
This commit is contained in:
parent
f25745ed27
commit
2f7527b0a4
2 changed files with 13 additions and 1 deletions
|
@ -29,3 +29,15 @@ TEST_CASE(character_reference_integer_overflow)
|
||||||
return Test::Crash::Failure::DidNotCrash;
|
return Test::Crash::Failure::DidNotCrash;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_CASE(predefined_character_reference)
|
||||||
|
{
|
||||||
|
XML::Parser parser("<a>Well hello &, <, >, ', and "!</a>"sv);
|
||||||
|
auto document = MUST(parser.parse());
|
||||||
|
|
||||||
|
auto const& node = document.root().content.get<XML::Node::Element>();
|
||||||
|
EXPECT_EQ(node.name, "a");
|
||||||
|
|
||||||
|
auto const& content = node.children[0]->content.get<XML::Node::Text>();
|
||||||
|
EXPECT_EQ(content.builder.string_view(), "Well hello &, <, >, ', and \"!");
|
||||||
|
}
|
||||||
|
|
|
@ -862,7 +862,7 @@ ErrorOr<void, ParseError> Parser::parse_content()
|
||||||
if (auto char_reference = reference.get_pointer<DeprecatedString>())
|
if (auto char_reference = reference.get_pointer<DeprecatedString>())
|
||||||
append_text(*char_reference);
|
append_text(*char_reference);
|
||||||
else
|
else
|
||||||
TRY(resolve_reference(reference.get<EntityReference>(), ReferencePlacement::Content));
|
append_text(TRY(resolve_reference(reference.get<EntityReference>(), ReferencePlacement::Content)));
|
||||||
goto try_char_data;
|
goto try_char_data;
|
||||||
}
|
}
|
||||||
if (auto result = parse_cdata_section(); !result.is_error()) {
|
if (auto result = parse_cdata_section(); !result.is_error()) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue