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
 |