mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-08 15:11:51 +00:00
Fix infinite loop involving wrapping formedness.
Signed-off-by: Edward Z. Yang <ezyang@mit.edu>
This commit is contained in:
parent
3166b8a10f
commit
875b0febde
2
NEWS
2
NEWS
@ -12,6 +12,8 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
4.1.1, unknown release date
|
4.1.1, unknown release date
|
||||||
- Emit an error for CollectErrors if a body is extracted
|
- Emit an error for CollectErrors if a body is extracted
|
||||||
- Fix bug where in background-position for center keyword handling.
|
- Fix bug where in background-position for center keyword handling.
|
||||||
|
- Fix infinite loop when a wrapper element is inserted in a context
|
||||||
|
where it's not allowed. Thanks Lars <lars@renoz.dk> for reporting.
|
||||||
|
|
||||||
4.1.0, released 2010-04-26
|
4.1.0, released 2010-04-26
|
||||||
! Support proprietary height attribute on table element
|
! Support proprietary height attribute on table element
|
||||||
|
@ -165,6 +165,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
|
|||||||
$token = $tokens[$t];
|
$token = $tokens[$t];
|
||||||
|
|
||||||
//echo '<br>'; printTokens($tokens, $t); printTokens($this->stack);
|
//echo '<br>'; printTokens($tokens, $t); printTokens($this->stack);
|
||||||
|
//flush();
|
||||||
|
|
||||||
// quick-check: if it's not a tag, no need to process
|
// quick-check: if it's not a tag, no need to process
|
||||||
if (empty($token->is_tag)) {
|
if (empty($token->is_tag)) {
|
||||||
@ -221,11 +222,14 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($autoclose && $definition->info[$token->name]->wrap) {
|
if ($autoclose && $definition->info[$token->name]->wrap) {
|
||||||
// check if this is actually a wrap (mmm wraps!)
|
// Check if an element can be wrapped by another
|
||||||
|
// element to make it valid in a context (for
|
||||||
|
// example, <ul><ul> needs a <li> in between)
|
||||||
$wrapname = $definition->info[$token->name]->wrap;
|
$wrapname = $definition->info[$token->name]->wrap;
|
||||||
$wrapdef = $definition->info[$wrapname];
|
$wrapdef = $definition->info[$wrapname];
|
||||||
$elements = $wrapdef->child->getAllowedElements($config);
|
$elements = $wrapdef->child->getAllowedElements($config);
|
||||||
if (isset($elements[$token->name])) {
|
$parent_elements = $definition->info[$parent->name]->child->getAllowedElements($config);
|
||||||
|
if (isset($elements[$token->name]) && isset($parent_elements[$wrapname])) {
|
||||||
$newtoken = new HTMLPurifier_Token_Start($wrapname);
|
$newtoken = new HTMLPurifier_Token_Start($wrapname);
|
||||||
$this->insertBefore($newtoken);
|
$this->insertBefore($newtoken);
|
||||||
$reprocess = true;
|
$reprocess = true;
|
||||||
|
5
tests/HTMLPurifier/HTMLT/inline-list-loop.htmlt
Normal file
5
tests/HTMLPurifier/HTMLT/inline-list-loop.htmlt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
--HTML--
|
||||||
|
<i><ul></ul></i>
|
||||||
|
--EXPECT--
|
||||||
|
<i></i><i></i>
|
||||||
|
--# vim: et sw=4 sts=4
|
@ -118,8 +118,8 @@ class HTMLPurifier_Strategy_MakeWellFormedTest extends HTMLPurifier_StrategyHarn
|
|||||||
|
|
||||||
function testNestedOl() {
|
function testNestedOl() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<ol><ol></ol></ol>',
|
'<ol><ol><li>foo</li></ol></ol>',
|
||||||
'<ol><li><ol></ol></li></ol>'
|
'<ol><li><ol><li>foo</li></ol></li></ol>'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user