| 123456789101112131415161718192021222324252627282930313233343536373839404142 | 
							- <?php namespace System;
 
- class Arr {
 
- 	/**
 
- 	 * Get an item from an array.
 
- 	 *
 
- 	 * If the specified key is null, the entire array will be returned. The array may
 
- 	 * also be accessed using JavaScript "dot" style notation. Retrieving items nested
 
- 	 * in multiple arrays is also supported.
 
- 	 *
 
- 	 * <code>
 
- 	 * // Returns "taylor"
 
- 	 * $item = Arr::get(array('name' => 'taylor'), 'name', $default);
 
- 	 *
 
- 	 * // Returns "taylor"
 
- 	 * $item = Arr::get(array('name' => array('is' => 'taylor')), 'name.is');
 
- 	 * </code>
 
- 	 *
 
- 	 * @param  array   $array
 
- 	 * @param  string  $key
 
- 	 * @param  mixed   $default
 
- 	 * @return mixed
 
- 	 */
 
- 	public static function get($array, $key, $default = null)
 
- 	{
 
- 		if (is_null($key)) return $array;
 
- 		foreach (explode('.', $key) as $segment)
 
- 		{
 
- 			if ( ! array_key_exists($segment, $array))
 
- 			{
 
- 				return is_callable($default) ? call_user_func($default) : $default;
 
- 			}
 
- 			$array = $array[$segment];
 
- 		}
 
- 		return $array;
 
- 	}
 
- }
 
 
  |