13 $definition =
$config->getHTMLDefinition();
15 $stack = array($parent->toNode());
16 foreach ($tokens as
$token) {
18 $token->carryover = null;
21 $r = array_pop($stack);
24 $r->endCol = $token->col;
25 $r->endLine = $token->line;
26 $r->endArmor = $token->armor;
29 $node = $token->toNode();
30 $stack[count($stack)-1]->children[] = $node;
42 $closingTokens = array();
45 while (!
$nodes[$level]->isEmpty()) {
46 $node =
$nodes[$level]->shift();
52 $closingTokens[$level][] =
$end;
57 foreach ($node->children as $childNode) {
58 $nodes[$level]->push($childNode);
63 if ($level && isset($closingTokens[$level])) {
64 while (
$token = array_pop($closingTokens[$level])) {
static flatten($node, $config, $context)
Concrete end token class.
Converts a stream of HTMLPurifier_Token into an HTMLPurifier_Node, and back again.
Concrete element node class.
A simple array-backed queue, based off of the classic Okasaki persistent amortized queue...
Concrete start token class.
static arborize($tokens, $config, $context)