92 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
/**
 | 
						|
 * Responsible for creating definition caches.
 | 
						|
 */
 | 
						|
class HTMLPurifier_DefinitionCacheFactory
 | 
						|
{
 | 
						|
 | 
						|
    protected $caches = array('Serializer' => array());
 | 
						|
    protected $implementations = array();
 | 
						|
    protected $decorators = array();
 | 
						|
 | 
						|
    /**
 | 
						|
     * Initialize default decorators
 | 
						|
     */
 | 
						|
    public function setup() {
 | 
						|
        $this->addDecorator('Cleanup');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Retrieves an instance of global definition cache factory.
 | 
						|
     */
 | 
						|
    public static function instance($prototype = null) {
 | 
						|
        static $instance;
 | 
						|
        if ($prototype !== null) {
 | 
						|
            $instance = $prototype;
 | 
						|
        } elseif ($instance === null || $prototype === true) {
 | 
						|
            $instance = new HTMLPurifier_DefinitionCacheFactory();
 | 
						|
            $instance->setup();
 | 
						|
        }
 | 
						|
        return $instance;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Registers a new definition cache object
 | 
						|
     * @param $short Short name of cache object, for reference
 | 
						|
     * @param $long Full class name of cache object, for construction
 | 
						|
     */
 | 
						|
    public function register($short, $long) {
 | 
						|
        $this->implementations[$short] = $long;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Factory method that creates a cache object based on configuration
 | 
						|
     * @param $name Name of definitions handled by cache
 | 
						|
     * @param $config Instance of HTMLPurifier_Config
 | 
						|
     */
 | 
						|
    public function create($type, $config) {
 | 
						|
        $method = $config->get('Cache.DefinitionImpl');
 | 
						|
        if ($method === null) {
 | 
						|
            return new HTMLPurifier_DefinitionCache_Null($type);
 | 
						|
        }
 | 
						|
        if (!empty($this->caches[$method][$type])) {
 | 
						|
            return $this->caches[$method][$type];
 | 
						|
        }
 | 
						|
        if (
 | 
						|
          isset($this->implementations[$method]) &&
 | 
						|
          class_exists($class = $this->implementations[$method], false)
 | 
						|
        ) {
 | 
						|
            $cache = new $class($type);
 | 
						|
        } else {
 | 
						|
            if ($method != 'Serializer') {
 | 
						|
                trigger_error("Unrecognized DefinitionCache $method, using Serializer instead", E_USER_WARNING);
 | 
						|
            }
 | 
						|
            $cache = new HTMLPurifier_DefinitionCache_Serializer($type);
 | 
						|
        }
 | 
						|
        foreach ($this->decorators as $decorator) {
 | 
						|
            $new_cache = $decorator->decorate($cache);
 | 
						|
            // prevent infinite recursion in PHP 4
 | 
						|
            unset($cache);
 | 
						|
            $cache = $new_cache;
 | 
						|
        }
 | 
						|
        $this->caches[$method][$type] = $cache;
 | 
						|
        return $this->caches[$method][$type];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Registers a decorator to add to all new cache objects
 | 
						|
     * @param
 | 
						|
     */
 | 
						|
    public function addDecorator($decorator) {
 | 
						|
        if (is_string($decorator)) {
 | 
						|
            $class = "HTMLPurifier_DefinitionCache_Decorator_$decorator";
 | 
						|
            $decorator = new $class;
 | 
						|
        }
 | 
						|
        $this->decorators[$decorator->name] = $decorator;
 | 
						|
    }
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
// vim: et sw=4 sts=4
 |