125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			PHP
		
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// constants are slow, so we use as few as possible
							 | 
						||
| 
								 | 
							
								if (!defined('HTMLPURIFIER_PREFIX')) {
							 | 
						||
| 
								 | 
							
								    define('HTMLPURIFIER_PREFIX', realpath(dirname(__FILE__) . '/..'));
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// accomodations for versions earlier than 5.0.2
							 | 
						||
| 
								 | 
							
								// borrowed from PHP_Compat, LGPL licensed, by Aidan Lister <aidan@php.net>
							 | 
						||
| 
								 | 
							
								if (!defined('PHP_EOL')) {
							 | 
						||
| 
								 | 
							
								    switch (strtoupper(substr(PHP_OS, 0, 3))) {
							 | 
						||
| 
								 | 
							
								        case 'WIN':
							 | 
						||
| 
								 | 
							
								            define('PHP_EOL', "\r\n");
							 | 
						||
| 
								 | 
							
								            break;
							 | 
						||
| 
								 | 
							
								        case 'DAR':
							 | 
						||
| 
								 | 
							
								            define('PHP_EOL', "\r");
							 | 
						||
| 
								 | 
							
								            break;
							 | 
						||
| 
								 | 
							
								        default:
							 | 
						||
| 
								 | 
							
								            define('PHP_EOL', "\n");
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Bootstrap class that contains meta-functionality for HTML Purifier such as
							 | 
						||
| 
								 | 
							
								 * the autoload function.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @note
							 | 
						||
| 
								 | 
							
								 *      This class may be used without any other files from HTML Purifier.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								class HTMLPurifier_Bootstrap
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Autoload function for HTML Purifier
							 | 
						||
| 
								 | 
							
								     * @param string $class Class to load
							 | 
						||
| 
								 | 
							
								     * @return bool
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function autoload($class)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $file = HTMLPurifier_Bootstrap::getPath($class);
							 | 
						||
| 
								 | 
							
								        if (!$file) {
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        // Technically speaking, it should be ok and more efficient to
							 | 
						||
| 
								 | 
							
								        // just do 'require', but Antonio Parraga reports that with
							 | 
						||
| 
								 | 
							
								        // Zend extensions such as Zend debugger and APC, this invariant
							 | 
						||
| 
								 | 
							
								        // may be broken.  Since we have efficient alternatives, pay
							 | 
						||
| 
								 | 
							
								        // the cost here and avoid the bug.
							 | 
						||
| 
								 | 
							
								        require_once HTMLPURIFIER_PREFIX . '/' . $file;
							 | 
						||
| 
								 | 
							
								        return true;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns the path for a specific class.
							 | 
						||
| 
								 | 
							
								     * @param string $class Class path to get
							 | 
						||
| 
								 | 
							
								     * @return string
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function getPath($class)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        if (strncmp('HTMLPurifier', $class, 12) !== 0) {
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        // Custom implementations
							 | 
						||
| 
								 | 
							
								        if (strncmp('HTMLPurifier_Language_', $class, 22) === 0) {
							 | 
						||
| 
								 | 
							
								            $code = str_replace('_', '-', substr($class, 22));
							 | 
						||
| 
								 | 
							
								            $file = 'HTMLPurifier/Language/classes/' . $code . '.php';
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								            $file = str_replace('_', '/', $class) . '.php';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        if (!file_exists(HTMLPURIFIER_PREFIX . '/' . $file)) {
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        return $file;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * "Pre-registers" our autoloader on the SPL stack.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function registerAutoload()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $autoload = array('HTMLPurifier_Bootstrap', 'autoload');
							 | 
						||
| 
								 | 
							
								        if (($funcs = spl_autoload_functions()) === false) {
							 | 
						||
| 
								 | 
							
								            spl_autoload_register($autoload);
							 | 
						||
| 
								 | 
							
								        } elseif (function_exists('spl_autoload_unregister')) {
							 | 
						||
| 
								 | 
							
								            if (version_compare(PHP_VERSION, '5.3.0', '>=')) {
							 | 
						||
| 
								 | 
							
								                // prepend flag exists, no need for shenanigans
							 | 
						||
| 
								 | 
							
								                spl_autoload_register($autoload, true, true);
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								                $buggy  = version_compare(PHP_VERSION, '5.2.11', '<');
							 | 
						||
| 
								 | 
							
								                $compat = version_compare(PHP_VERSION, '5.1.2', '<=') &&
							 | 
						||
| 
								 | 
							
								                          version_compare(PHP_VERSION, '5.1.0', '>=');
							 | 
						||
| 
								 | 
							
								                foreach ($funcs as $func) {
							 | 
						||
| 
								 | 
							
								                    if ($buggy && is_array($func)) {
							 | 
						||
| 
								 | 
							
								                        // :TRICKY: There are some compatibility issues and some
							 | 
						||
| 
								 | 
							
								                        // places where we need to error out
							 | 
						||
| 
								 | 
							
								                        $reflector = new ReflectionMethod($func[0], $func[1]);
							 | 
						||
| 
								 | 
							
								                        if (!$reflector->isStatic()) {
							 | 
						||
| 
								 | 
							
								                            throw new Exception(
							 | 
						||
| 
								 | 
							
								                                'HTML Purifier autoloader registrar is not compatible
							 | 
						||
| 
								 | 
							
								                                with non-static object methods due to PHP Bug #44144;
							 | 
						||
| 
								 | 
							
								                                Please do not use HTMLPurifier.autoload.php (or any
							 | 
						||
| 
								 | 
							
								                                file that includes this file); instead, place the code:
							 | 
						||
| 
								 | 
							
								                                spl_autoload_register(array(\'HTMLPurifier_Bootstrap\', \'autoload\'))
							 | 
						||
| 
								 | 
							
								                                after your own autoloaders.'
							 | 
						||
| 
								 | 
							
								                            );
							 | 
						||
| 
								 | 
							
								                        }
							 | 
						||
| 
								 | 
							
								                        // Suprisingly, spl_autoload_register supports the
							 | 
						||
| 
								 | 
							
								                        // Class::staticMethod callback format, although call_user_func doesn't
							 | 
						||
| 
								 | 
							
								                        if ($compat) {
							 | 
						||
| 
								 | 
							
								                            $func = implode('::', $func);
							 | 
						||
| 
								 | 
							
								                        }
							 | 
						||
| 
								 | 
							
								                    }
							 | 
						||
| 
								 | 
							
								                    spl_autoload_unregister($func);
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								                spl_autoload_register($autoload);
							 | 
						||
| 
								 | 
							
								                foreach ($funcs as $func) {
							 | 
						||
| 
								 | 
							
								                    spl_autoload_register($func);
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// vim: et sw=4 sts=4
							 |