. */ namespace Doctrine\Common; /** * A class loader used to load class files on demand. * * Usage recommendation: * 1) Use only 1 class loader instance. * 2) Set the base paths to your class libraries (including Doctrine's) through * $classLoader->setBasePath($prefix, $basePath); * Example: * $classLoader->setBasePath('Doctrine', '/usr/local/phplibs/doctrine/lib'); * Then, when trying to load the class Doctrine\ORM\EntityManager, for example * the classloader will look for /usr/local/phplibs/doctrine/lib/Doctrine/ORM/EntityManager.php * * 3) DO NOT setCheckFileExists(true). Doing so is expensive in terms of performance. * 4) Use an opcode-cache (i.e. APC) (STRONGLY RECOMMENDED). * * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link www.doctrine-project.org * @since 2.0 * @version $Revision: 3938 $ * @author Guilherme Blanco * @author Jonathan Wage * @author Roman Borschel */ class ClassLoader { /** * @var string Namespace separator */ private $_namespaceSeparator = '\\'; /** * @var string File extension used for classes */ private $_fileExtension = '.php'; /** * @var boolean Flag to inspect if file exists in codebase before include it */ private $_checkFileExists = false; /** * @var array Hashmap of base paths that Autoloader will look into */ private $_basePaths = array(); /** * Constructor registers the autoloader automatically * */ public function __construct() { spl_autoload_register(array($this, 'loadClass')); } /** * Set check file exists * * @param boolean $bool * @return void */ public function setCheckFileExists($bool) { $this->_checkFileExists = $bool; } /** * Set class file extension * * @param string $extension * @return void */ public function setClassFileExtension($extension) { $this->_fileExtension = $extension; } /** * Sets the namespace separator to use. * * @param string $separator * @return void */ public function setNamespaceSeparator($separator) { $this->_namespaceSeparator = $separator; } /** * Sets a static base path for classes with a certain prefix that is prepended * to the path derived from the class itself. * * @param string $classPrefix * @param string $basePath */ public function setBasePath($classPrefix, $basePath) { $this->_basePaths[$classPrefix] = $basePath; } /** * Loads the given class or interface. * * @param string $classname The name of the class to load. * @return boolean TRUE if the class has been successfully loaded, FALSE otherwise. */ public function loadClass($className) { if (class_exists($className, false) || interface_exists($className, false)) { return false; } $prefix = ''; $separator = $this->_namespaceSeparator; if (($pos = strpos($className, $this->_namespaceSeparator)) !== false) { $prefix = substr($className, 0, strpos($className, $this->_namespaceSeparator)); } else if (($pos = strpos($className, '_')) !== false) { // Support for '_' namespace separator for compatibility with Zend/PEAR/... $prefix = substr($className, 0, strpos($className, '_')); $separator = '_'; } // If we have a custom path for namespace, use it $class = ((isset($this->_basePaths[$prefix])) ? $this->_basePaths[$prefix] . DIRECTORY_SEPARATOR : '') . str_replace($separator, DIRECTORY_SEPARATOR, $className) . $this->_fileExtension; // Assure file exists in codebase before require if flag is active if ($this->_checkFileExists) { if (($fh = @fopen($class, 'r', true)) === false) { return false; } @fclose($fh); } require $class; return true; } }