123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- <?php namespace Laravel;
- class Autoloader {
- /**
- * The PSR-0 compliant libraries registered with the auto-loader.
- *
- * @var array
- */
- protected static $libraries = array();
- /**
- * The paths to be searched by the auto-loader.
- *
- * @var array
- */
- protected static $paths = array(BASE_PATH, MODEL_PATH, LIBRARY_PATH);
- /**
- * Load the file corresponding to a given class.
- *
- * Laravel loads classes out of three directories: the core "laravel" directory,
- * and the application "models" and "libraries" directories. All of the file
- * names are lower cased and the directory structure corresponds with the
- * class namespaces.
- *
- * The application "libraries" directory also supports the inclusion of PSR-0
- * compliant libraries. These libraries will be detected automatically and
- * will be loaded according to the PSR-0 naming conventions.
- *
- * @param string $class
- * @return void
- */
- public static function load($class)
- {
- if (array_key_exists($class, Config::$items['application']['aliases']))
- {
- return class_alias(Config::$items['application']['aliases'][$class], $class);
- }
- if ( ! is_null($path = static::find($class)))
- {
- require $path;
- }
- }
- /**
- * Determine the file path associated with a given class name.
- *
- * @param string $class
- * @return string
- */
- protected static function find($class)
- {
- // After PHP namespaces were introduced, most libaries ditched underscores for
- // for namespaces to indicate the class directory hierarchy. We will check for
- // the presence of namespace slashes to determine the directory separator.
- $separator = (strpos($class, '\\') !== false) ? '\\' : '_';
- $library = substr($class, 0, strpos($class, $separator));
- $file = str_replace('\\', '/', $class);
- // If the namespace has been registered as a PSR-0 compliant library, we will
- // load the library according to the PSR-0 naming standards, which state that
- // namespaces and underscores indicate the directory hierarchy of the class.
- if (isset(static::$libraries[$library]))
- {
- return LIBRARY_PATH.str_replace('_', '/', $file).EXT;
- }
- // Next we will search through the common Laravel paths for the class file.
- // The Laravel framework path, along with the libraries and models paths
- // will be searched according to the Laravel class naming standard.
- $lower = strtolower($file);
- foreach (static::$paths as $path)
- {
- if (file_exists($path = $path.$lower.EXT))
- {
- return $path;
- }
- }
- // If we could not find the class file in any of the auto-loaded locations
- // according to the Laravel naming standard, we will search the libraries
- // directory for the class according to the PSR-0 naming standard.
- if (file_exists($path = LIBRARY_PATH.str_replace('_', '/', $file).EXT))
- {
- static::$libraries[] = $library;
- return $path;
- }
- // Since not all controllers will be resolved by the controller resolver,
- // we will do a quick check in the controller directory for the class.
- // For instance, since base controllers would not be resolved by the
- // controller class, we will need to resolve them here.
- if (strpos($class, '_Controller') !== false)
- {
- $controller = str_replace(array('_Controller', '_'), array('', '/'), $class);
- if (file_exists($path = strtolower(CONTROLLER_PATH.$controller.EXT)))
- {
- return $path;
- }
- }
- }
- }
|