94 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * Factory for token generation.
 | |
|  *
 | |
|  * @note Doing some benchmarking indicates that the new operator is much
 | |
|  *       slower than the clone operator (even discounting the cost of the
 | |
|  *       constructor).  This class is for that optimization.
 | |
|  *       Other then that, there's not much point as we don't
 | |
|  *       maintain parallel HTMLPurifier_Token hierarchies (the main reason why
 | |
|  *       you'd want to use an abstract factory).
 | |
|  * @todo Port DirectLex to use this
 | |
|  */
 | |
| class HTMLPurifier_TokenFactory
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * Prototypes that will be cloned.
 | |
|      * @private
 | |
|      */
 | |
|     // p stands for prototype
 | |
|     private $p_start, $p_end, $p_empty, $p_text, $p_comment;
 | |
| 
 | |
|     /**
 | |
|      * Generates blank prototypes for cloning.
 | |
|      */
 | |
|     public function __construct() {
 | |
|         $this->p_start  = new HTMLPurifier_Token_Start('', array());
 | |
|         $this->p_end    = new HTMLPurifier_Token_End('');
 | |
|         $this->p_empty  = new HTMLPurifier_Token_Empty('', array());
 | |
|         $this->p_text   = new HTMLPurifier_Token_Text('');
 | |
|         $this->p_comment= new HTMLPurifier_Token_Comment('');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a HTMLPurifier_Token_Start.
 | |
|      * @param $name Tag name
 | |
|      * @param $attr Associative array of attributes
 | |
|      * @return Generated HTMLPurifier_Token_Start
 | |
|      */
 | |
|     public function createStart($name, $attr = array()) {
 | |
|         $p = clone $this->p_start;
 | |
|         $p->__construct($name, $attr);
 | |
|         return $p;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a HTMLPurifier_Token_End.
 | |
|      * @param $name Tag name
 | |
|      * @return Generated HTMLPurifier_Token_End
 | |
|      */
 | |
|     public function createEnd($name) {
 | |
|         $p = clone $this->p_end;
 | |
|         $p->__construct($name);
 | |
|         return $p;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a HTMLPurifier_Token_Empty.
 | |
|      * @param $name Tag name
 | |
|      * @param $attr Associative array of attributes
 | |
|      * @return Generated HTMLPurifier_Token_Empty
 | |
|      */
 | |
|     public function createEmpty($name, $attr = array()) {
 | |
|         $p = clone $this->p_empty;
 | |
|         $p->__construct($name, $attr);
 | |
|         return $p;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a HTMLPurifier_Token_Text.
 | |
|      * @param $data Data of text token
 | |
|      * @return Generated HTMLPurifier_Token_Text
 | |
|      */
 | |
|     public function createText($data) {
 | |
|         $p = clone $this->p_text;
 | |
|         $p->__construct($data);
 | |
|         return $p;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a HTMLPurifier_Token_Comment.
 | |
|      * @param $data Data of comment token
 | |
|      * @return Generated HTMLPurifier_Token_Comment
 | |
|      */
 | |
|     public function createComment($data) {
 | |
|         $p = clone $this->p_comment;
 | |
|         $p->__construct($data);
 | |
|         return $p;
 | |
|     }
 | |
| 
 | |
| }
 | |
| 
 | |
| // vim: et sw=4 sts=4
 |