Browse Source

added function to recursively copy a directory.

Taylor Otwell 13 years ago
parent
commit
f7e6b957de
2 changed files with 50 additions and 36 deletions
  1. 2 35
      laravel/cli/tasks/bundle/publisher.php
  2. 48 1
      laravel/file.php

+ 2 - 35
laravel/cli/tasks/bundle/publisher.php

@@ -1,5 +1,6 @@
 <?php namespace Laravel\CLI\Tasks\Bundle;
 
+use Laravel\File;
 use Laravel\Bundle;
 use FilesystemIterator;
 
@@ -28,41 +29,7 @@ class Publisher {
 	 */
 	protected function move($bundle, $source, $destination)
 	{
-		if ( ! is_dir($source)) return;
-
-		// First we need to create the destination directory if it doesn't
-		// already exists. This directory hosts all of the assets we copy
-		// from the installed bundle's source directory.
-		if ( ! is_dir($destination))
-		{
-			mkdir($destination);
-		}
-
-		$items = new FilesystemIterator($source, FilesystemIterator::SKIP_DOTS);
-
-		foreach ($items as $item)
-		{
-			// If the file system item is a directory, we will recurse the
-			// function, passing in the item directory. To get the proper
-			// destination path, we'll replace the root bundle asset
-			// directory with the root public asset directory.
-			if ($item->isDir())
-			{
-				$path = $item->getRealPath();
-
-				$recurse = str_replace($this->from($bundle), $this->to($bundle), $path);
-
-				$this->move($bundle, $path, $recurse);
-			}
-			// If the file system item is an actual file, we can copy the
-			// file from the bundle asset directory to the public asset
-			// directory. The "copy" method will overwrite any existing
-			// files with the same name.
-			else
-			{
-				copy($item->getRealPath(), $destination.DS.$item->getBasename());
-			}
-		}		
+		File::copy_dir($source, $destination);	
 	}
 
 	/**

+ 48 - 1
laravel/file.php

@@ -1,4 +1,4 @@
-<?php namespace Laravel; use Closure;
+<?php namespace Laravel; use Closure, FilesystemIterator;
 
 class File {
 
@@ -170,4 +170,51 @@ class File {
 		return false;
 	}
 
+	/**
+	 * Recursively copy directory contents to another directory.
+	 *
+	 * @param  string  $source
+	 * @param  string  $destination
+	 * @return void
+	 */
+	public static function copy_dir($source, $destination)
+	{
+		if ( ! is_dir($source)) return;
+
+		// First we need to create the destination directory if it doesn't
+		// already exists. This directory hosts all of the assets we copy
+		// from the installed bundle's source directory.
+		if ( ! is_dir($destination))
+		{
+			mkdir($destination);
+		}
+
+		$items = new FilesystemIterator($source, FilesystemIterator::SKIP_DOTS);
+
+		foreach ($items as $item)
+		{
+			$location = $destination.DS.$item->getBasename();
+
+			// If the file system item is a directory, we will recurse the
+			// function, passing in the item directory. To get the proper
+			// destination path, we'll add the basename of the source to
+			// to the destination directory.
+			if ($item->isDir())
+			{
+				$path = $item->getRealPath();
+
+				static::copy_dir($path, $location);
+			}
+			// If the file system item is an actual file, we can copy the
+			// file from the bundle asset directory to the public asset
+			// directory. The "copy" method will overwrite any existing
+			// files with the same name.
+			else
+			{
+				copy($item->getRealPath(), $location);
+			}
+		}
+	}
+
+
 }