Browse Source

fix glob error in bundle class.

Taylor Otwell 13 years ago
parent
commit
f53ebbf672
2 changed files with 16 additions and 12 deletions
  1. 10 6
      laravel/bundle.php
  2. 6 6
      laravel/cli/command.php

+ 10 - 6
laravel/bundle.php

@@ -271,10 +271,6 @@ class Bundle {
 	/**
 	 * Detect all of the existing bundles in the application.
 	 *
-	 * The names of the bundles are cached so this operation will be only be
-	 * performed once and then the same array will be returned on each later
-	 * request for the bundle names.
-	 *
 	 * @return array
 	 */
 	public static function all()
@@ -283,9 +279,17 @@ class Bundle {
 
 		$bundles = array();
 
-		foreach (array_filter(glob(BUNDLE_PATH.'*'), 'is_dir') as $bundle)
+		$files = glob(BUNDLE_PATH.'*');
+
+		// When open_basedir is enabled the glob function returns false on
+		// an empty array. We'll check for this and return an empty array
+		// if the bundle directory doesn't have any bundles.
+		if ($files !== false)
 		{
-			$bundles[] = basename($bundle);
+			foreach (array_filter($files, 'is_dir') as $bundle)
+			{
+				$bundles[] = basename($bundle);
+			}			
 		}
 
 		return static::$bundles = $bundles;

+ 6 - 6
laravel/cli/command.php

@@ -71,17 +71,17 @@ class Command {
 	{
 		$identifier = Bundle::identifier($bundle, $task);
 
-		// First we'll check to see if the task has been registered in
-		// the application IoC container. This allows dependencies to
-		// be injected into tasks for more testability.
+		// First we'll check to see if the task has been registered in the
+		// application IoC container. This allows all dependencies to be
+		// injected into tasks for more testability.
 		if (IoC::registered("task: {$identifier}"))
 		{
 			return IoC::resolve("task: {$identifier}");
 		}
 
-		// If the task file exists, we'll format the bundle and task
-		// name into a task class name and resolve an instance of
-		// the so that the requested method may be executed.
+		// If the task file exists, we'll format the bundle and task name
+		// into a task class name and resolve an instance of the so that
+		// the requested method may be executed.
 		if (file_exists($path = Bundle::path($bundle).'tasks/'.$task.EXT))
 		{
 			require $path;