117 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
/**
 | 
						|
 * Definition that allows a set of elements, but disallows empty children.
 | 
						|
 */
 | 
						|
class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Lookup table of allowed elements.
 | 
						|
     * @public
 | 
						|
     */
 | 
						|
    public $elements = array();
 | 
						|
    /**
 | 
						|
     * Whether or not the last passed node was all whitespace.
 | 
						|
     */
 | 
						|
    protected $whitespace = false;
 | 
						|
    /**
 | 
						|
     * @param $elements List of allowed element names (lowercase).
 | 
						|
     */
 | 
						|
    public function __construct($elements) {
 | 
						|
        if (is_string($elements)) {
 | 
						|
            $elements = str_replace(' ', '', $elements);
 | 
						|
            $elements = explode('|', $elements);
 | 
						|
        }
 | 
						|
        $keys = array_keys($elements);
 | 
						|
        if ($keys == array_keys($keys)) {
 | 
						|
            $elements = array_flip($elements);
 | 
						|
            foreach ($elements as $i => $x) {
 | 
						|
                $elements[$i] = true;
 | 
						|
                if (empty($i)) unset($elements[$i]); // remove blank
 | 
						|
            }
 | 
						|
        }
 | 
						|
        $this->elements = $elements;
 | 
						|
    }
 | 
						|
    public $allow_empty = false;
 | 
						|
    public $type = 'required';
 | 
						|
    public function validateChildren($tokens_of_children, $config, $context) {
 | 
						|
        // Flag for subclasses
 | 
						|
        $this->whitespace = false;
 | 
						|
 | 
						|
        // if there are no tokens, delete parent node
 | 
						|
        if (empty($tokens_of_children)) return false;
 | 
						|
 | 
						|
        // the new set of children
 | 
						|
        $result = array();
 | 
						|
 | 
						|
        // current depth into the nest
 | 
						|
        $nesting = 0;
 | 
						|
 | 
						|
        // whether or not we're deleting a node
 | 
						|
        $is_deleting = false;
 | 
						|
 | 
						|
        // whether or not parsed character data is allowed
 | 
						|
        // this controls whether or not we silently drop a tag
 | 
						|
        // or generate escaped HTML from it
 | 
						|
        $pcdata_allowed = isset($this->elements['#PCDATA']);
 | 
						|
 | 
						|
        // a little sanity check to make sure it's not ALL whitespace
 | 
						|
        $all_whitespace = true;
 | 
						|
 | 
						|
        // some configuration
 | 
						|
        $escape_invalid_children = $config->get('Core.EscapeInvalidChildren');
 | 
						|
 | 
						|
        // generator
 | 
						|
        $gen = new HTMLPurifier_Generator($config, $context);
 | 
						|
 | 
						|
        foreach ($tokens_of_children as $token) {
 | 
						|
            if (!empty($token->is_whitespace)) {
 | 
						|
                $result[] = $token;
 | 
						|
                continue;
 | 
						|
            }
 | 
						|
            $all_whitespace = false; // phew, we're not talking about whitespace
 | 
						|
 | 
						|
            $is_child = ($nesting == 0);
 | 
						|
 | 
						|
            if ($token instanceof HTMLPurifier_Token_Start) {
 | 
						|
                $nesting++;
 | 
						|
            } elseif ($token instanceof HTMLPurifier_Token_End) {
 | 
						|
                $nesting--;
 | 
						|
            }
 | 
						|
 | 
						|
            if ($is_child) {
 | 
						|
                $is_deleting = false;
 | 
						|
                if (!isset($this->elements[$token->name])) {
 | 
						|
                    $is_deleting = true;
 | 
						|
                    if ($pcdata_allowed && $token instanceof HTMLPurifier_Token_Text) {
 | 
						|
                        $result[] = $token;
 | 
						|
                    } elseif ($pcdata_allowed && $escape_invalid_children) {
 | 
						|
                        $result[] = new HTMLPurifier_Token_Text(
 | 
						|
                            $gen->generateFromToken($token)
 | 
						|
                        );
 | 
						|
                    }
 | 
						|
                    continue;
 | 
						|
                }
 | 
						|
            }
 | 
						|
            if (!$is_deleting || ($pcdata_allowed && $token instanceof HTMLPurifier_Token_Text)) {
 | 
						|
                $result[] = $token;
 | 
						|
            } elseif ($pcdata_allowed && $escape_invalid_children) {
 | 
						|
                $result[] =
 | 
						|
                    new HTMLPurifier_Token_Text(
 | 
						|
                        $gen->generateFromToken($token)
 | 
						|
                    );
 | 
						|
            } else {
 | 
						|
                // drop silently
 | 
						|
            }
 | 
						|
        }
 | 
						|
        if (empty($result)) return false;
 | 
						|
        if ($all_whitespace) {
 | 
						|
            $this->whitespace = true;
 | 
						|
            return false;
 | 
						|
        }
 | 
						|
        if ($tokens_of_children == $result) return true;
 | 
						|
        return $result;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
// vim: et sw=4 sts=4
 |