Browse Source

tweaks to package handling.

Taylor Otwell 13 years ago
parent
commit
188b0c4f29
4 changed files with 12 additions and 18 deletions
  1. 1 0
      application/config/aliases.php
  2. 1 1
      public/index.php
  3. 1 1
      system/loader.php
  4. 9 16
      system/package.php

+ 1 - 0
application/config/aliases.php

@@ -35,6 +35,7 @@ return array(
 	'Inflector' => 'System\\Inflector',
 	'Input' => 'System\\Input',
 	'Lang' => 'System\\Lang',
+	'Loader' => 'System\\Loader',
 	'Package' => 'System\\Package',
 	'URL' => 'System\\URL',
 	'Redirect' => 'System\\Redirect',

+ 1 - 1
public/index.php

@@ -145,7 +145,7 @@ require SYS_PATH.'routing/filter'.EXT;
 // --------------------------------------------------------------
 require SYS_PATH.'package'.EXT;
 
-System\Package::load(System\Config::get('packages.autoload'));
+System\Package::load(System\Config::get('package.autoload'));
 
 // --------------------------------------------------------------
 // Register the route filters.

+ 1 - 1
system/loader.php

@@ -65,7 +65,7 @@ class Loader {
 	 */
 	public static function register($path)
 	{
-		static::$paths[] = $path;
+		static::$paths[] = rtrim($path, '/').'/';
 	}
 
 }

+ 9 - 16
system/package.php

@@ -12,30 +12,23 @@ class Package {
 	/**
 	 * Load a package or set of packages.
 	 *
-	 * @param  string|array  $package
+	 * @param  string|array  $packages
 	 * @return void
 	 */
-	public static function load($package)
+	public static function load($packages)
 	{
-		if (is_array($package))
+		foreach ((array) $packages as $package)
 		{
-			foreach ($package as $value)
+			// Packages may have a bootstrap file, which commonly is used to register auto-loaders
+			// and perform other initialization needed to use the package. If the package has a
+			// bootstrapper, we will require it here.
+			if ( ! array_key_exists($package, static::$loaded) and file_exists($path = PACKAGE_PATH.$package.'/bootstrap'.EXT))
 			{
-				static::load($value);			
+				require $path;
 			}
 
-			return;
+			static::$loaded[] = $package;			
 		}
-
-		// Packages may have a bootstrap file, which commonly is used to register auto-loaders
-		// and perform other initialization needed to use the package. If the package has a
-		// bootstrapper, we will require it here.
-		if ( ! array_key_exists($package, static::$loaded) and file_exists($path = PACKAGE_PATH.$package.'/bootstrap'.EXT))
-		{
-			require $path;
-		}
-
-		static::$loaded[] = $package;
 	}
 
 }