61 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * Processes an entire attribute array for corrections needing multiple values.
 | |
|  *
 | |
|  * Occasionally, a certain attribute will need to be removed and popped onto
 | |
|  * another value.  Instead of creating a complex return syntax for
 | |
|  * HTMLPurifier_AttrDef, we just pass the whole attribute array to a
 | |
|  * specialized object and have that do the special work.  That is the
 | |
|  * family of HTMLPurifier_AttrTransform.
 | |
|  *
 | |
|  * An attribute transformation can be assigned to run before or after
 | |
|  * HTMLPurifier_AttrDef validation.  See HTMLPurifier_HTMLDefinition for
 | |
|  * more details.
 | |
|  */
 | |
| 
 | |
| abstract class HTMLPurifier_AttrTransform
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * Abstract: makes changes to the attributes dependent on multiple values.
 | |
|      *
 | |
|      * @param array $attr Assoc array of attributes, usually from
 | |
|      *              HTMLPurifier_Token_Tag::$attr
 | |
|      * @param HTMLPurifier_Config $config Mandatory HTMLPurifier_Config object.
 | |
|      * @param HTMLPurifier_Context $context Mandatory HTMLPurifier_Context object
 | |
|      * @return array Processed attribute array.
 | |
|      */
 | |
|     abstract public function transform($attr, $config, $context);
 | |
| 
 | |
|     /**
 | |
|      * Prepends CSS properties to the style attribute, creating the
 | |
|      * attribute if it doesn't exist.
 | |
|      * @param array &$attr Attribute array to process (passed by reference)
 | |
|      * @param string $css CSS to prepend
 | |
|      */
 | |
|     public function prependCSS(&$attr, $css)
 | |
|     {
 | |
|         $attr['style'] = isset($attr['style']) ? $attr['style'] : '';
 | |
|         $attr['style'] = $css . $attr['style'];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Retrieves and removes an attribute
 | |
|      * @param array &$attr Attribute array to process (passed by reference)
 | |
|      * @param mixed $key Key of attribute to confiscate
 | |
|      * @return mixed
 | |
|      */
 | |
|     public function confiscateAttr(&$attr, $key)
 | |
|     {
 | |
|         if (!isset($attr[$key])) {
 | |
|             return null;
 | |
|         }
 | |
|         $value = $attr[$key];
 | |
|         unset($attr[$key]);
 | |
|         return $value;
 | |
|     }
 | |
| }
 | |
| 
 | |
| // vim: et sw=4 sts=4
 | 
