| 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;	}}
 |