autoload bundles based on namespace.

This commit is contained in:
Taylor Otwell 2012-02-19 21:59:57 -06:00
parent 106b5dc1e1
commit b262e743c0
2 changed files with 29 additions and 0 deletions

View File

@ -67,6 +67,21 @@ class_alias(static::$aliases[$class], $class);
return static::load_psr($class, $info['directory']);
}
// If the class is namespaced and a bundle exists that is assigned
// a name matching that namespace, we'll start the bundle and let
// the class fall through the method again.
if ( ! is_null($namespace = root_namespace($class)))
{
$namespace = strtolower($namespace);
if (Bundle::exists($namespace) and ! Bundle::started($namespace))
{
Bundle::start($namespace);
return static::load($class);
}
}
// If the class is not maped and is not part of a bundle or a mapped
// namespace, we'll make a last ditch effort to load the class via
// the PSR-0 from one of the registered directories.

View File

@ -361,6 +361,20 @@ function str_finish($value, $cap)
return rtrim($value, $cap).$cap;
}
/**
* Get the root namespace of a given class.
*
* @param string $class
* @return string
*/
function root_namespace($class)
{
if (str_contains($class, '\\'))
{
return head(explode('\\', $class));
}
}
/**
* Return the value of the given item.
*