Browse Source

fix bundle dependency error possibility. fix WSOD in view rendering.

Taylor Otwell 13 years ago
parent
commit
27502918fb
2 changed files with 12 additions and 5 deletions
  1. 2 4
      laravel/bundle.php
  2. 10 1
      laravel/response.php

+ 2 - 4
laravel/bundle.php

@@ -46,7 +46,7 @@ class Bundle {
 		// dependent bundles so that they are available.
 		if (file_exists($path = static::path($bundle).'bundle'.EXT))
 		{
-			require $path;
+			require_once $path;
 		}
 
 		// Each bundle may also have a "routes" file which is responsible for
@@ -65,11 +65,9 @@ class Bundle {
 	 */
 	public static function routes($bundle)
 	{
-		if (static::started($bundle)) return;
-
 		if (file_exists($path = static::path($bundle).'routes'.EXT))
 		{
-			require $path;
+			require_once $path;
 		}
 	}
 

+ 10 - 1
laravel/response.php

@@ -214,7 +214,16 @@ class Response {
 		// Since this method is used by both the Route and Controller classes, it is
 		// a convenient spot to cast the application response to a string before it
 		// is returned to the main request handler.
-		$response->content = (string) $response->content;
+		$content =& $response->content;
+
+		if (is_object($content) and method_exists($content, '__toString'))
+		{
+			$content = $content->__toString();
+		}
+		else
+		{
+			$content = (string) $content;
+		}
 
 		return $response;
 	}