\HTMLPurifier_Strategy_FixNesting

Takes a well formed list of tokens and fixes their nesting.

HTML elements dictate which elements are allowed to be their children, for example, you can't have a p tag in a span tag. Other elements have much more rigorous definitions: tables, for instance, require a specific order for their elements. There are also constraints not expressible by document type definitions, such as the chameleon nature of ins/del tags and global child exclusions.

The first major objective of this strategy is to iterate through all the nodes and determine whether or not their children conform to the element's definition. If they do not, the child definition may optionally supply an amended list of elements that is valid or require that the entire node be deleted (and the previous node rescanned).

The second objective is to ensure that explicitly excluded elements of an element do not appear in its children. Code that accomplishes this task is pervasive through the strategy, though the two are distinct tasks and could, theoretically, be seperated (although it's not recommended).

Summary

Methods
Properties
Constants
execute()
No public properties found
No constants found
No protected methods found
No protected properties found
N/A
No private methods found
No private properties found
N/A

Methods

execute()

execute(\HTMLPurifier_Token[]  $tokens, \HTMLPurifier_Config  $config, \HTMLPurifier_Context  $context) : array|\HTMLPurifier_Token[]

Executes the strategy on the tokens.

Parameters

\HTMLPurifier_Token[] $tokens
\HTMLPurifier_Config $config
\HTMLPurifier_Context $context

Returns

array|\HTMLPurifier_Token[] —