Browse Source

continued adding comments to arr class.

Taylor Otwell 13 years ago
parent
commit
7f5d047e1f
1 changed files with 24 additions and 1 deletions
  1. 24 1
      laravel/arr.php

+ 24 - 1
laravel/arr.php

@@ -42,6 +42,13 @@ class Arr {
 	 *
 	 * The same "dot" syntax used by the "get" method may be used here.
 	 *
+	 * If no key is given to the method, the entire array will be replaced.
+	 *
+	 * <code>
+	 *		// Set the $array['user']['name'] value on the array
+	 *		Arr::set($array, 'user.name', 'Taylor');
+	 * </code>
+	 *
 	 * @param  array   $array
 	 * @param  string  $key
 	 * @param  mixed   $value
@@ -71,6 +78,14 @@ class Arr {
 	/**
 	 * Return the first element in an array which passes a given truth test.
 	 *
+	 * <code>
+	 *		// Return the first array element that equals "Taylor"
+	 *		$value = Arr::first($array, function($k, $v) {return $v === 'Taylor';});
+	 *
+	 *		// Return a default value if no matching element is found
+	 *		$value = Arr::first($array, function($k, $v) {return $v === 'Taylor'}, 'Default');
+	 * </code>
+	 *
 	 * @param  array    $array
 	 * @param  Closure  $callback
 	 * @return mixed
@@ -88,13 +103,21 @@ class Arr {
 	/**
 	 * Remove all array values that are contained within a given array of values.
 	 *
+	 * <code>
+	 *		// Remove all array values that are empty strings
+	 *		$array = Arr::without($array, '');
+	 *
+	 *		// Remove all array values that are "One", "Two", or "Three"
+	 *		$array = Arr::without($array, array('One', 'Two', 'Three'));
+	 * </code>
+	 *
 	 * @param  array  $array
 	 * @param  array  $without
 	 * @return array
 	 */
 	public static function without($array, $without = array())
 	{
-		foreach ($array as $key => $value)
+		foreach ((array) $array as $key => $value)
 		{
 			if (in_array($value, $without)) unset($array[$key]);
 		}