46 lines
1.2 KiB
PHP
46 lines
1.2 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* Definition that allows a set of elements, and allows no children.
|
||
|
* @note This is a hack to reuse code from HTMLPurifier_ChildDef_Required,
|
||
|
* really, one shouldn't inherit from the other. Only altered behavior
|
||
|
* is to overload a returned false with an array. Thus, it will never
|
||
|
* return false.
|
||
|
*/
|
||
|
class HTMLPurifier_ChildDef_Optional extends HTMLPurifier_ChildDef_Required
|
||
|
{
|
||
|
/**
|
||
|
* @type bool
|
||
|
*/
|
||
|
public $allow_empty = true;
|
||
|
|
||
|
/**
|
||
|
* @type string
|
||
|
*/
|
||
|
public $type = 'optional';
|
||
|
|
||
|
/**
|
||
|
* @param array $children
|
||
|
* @param HTMLPurifier_Config $config
|
||
|
* @param HTMLPurifier_Context $context
|
||
|
* @return array
|
||
|
*/
|
||
|
public function validateChildren($children, $config, $context)
|
||
|
{
|
||
|
$result = parent::validateChildren($children, $config, $context);
|
||
|
// we assume that $children is not modified
|
||
|
if ($result === false) {
|
||
|
if (empty($children)) {
|
||
|
return true;
|
||
|
} elseif ($this->whitespace) {
|
||
|
return $children;
|
||
|
} else {
|
||
|
return array();
|
||
|
}
|
||
|
}
|
||
|
return $result;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// vim: et sw=4 sts=4
|