Commit e467c831 authored by Taylor Otwell's avatar Taylor Otwell

improve cache class documentation.

parent 72e7275f
...@@ -16,20 +16,20 @@ class Cache { ...@@ -16,20 +16,20 @@ class Cache {
* @return Cache\Driver * @return Cache\Driver
*/ */
public static function driver($driver = null) public static function driver($driver = null)
{
if ( ! array_key_exists($driver, static::$drivers))
{ {
// -------------------------------------------------- // --------------------------------------------------
// If no driver was specified, use the default. // If the cache driver has already been instantiated,
// we'll just return that existing instance.
//
// Otherwise, we'll instantiate a new one.
// -------------------------------------------------- // --------------------------------------------------
if ( ! array_key_exists($driver, static::$drivers))
{
if (is_null($driver)) if (is_null($driver))
{ {
$driver = Config::get('cache.driver'); $driver = Config::get('cache.driver');
} }
// --------------------------------------------------
// Create the cache driver.
// --------------------------------------------------
static::$drivers[$driver] = Cache\Factory::make($driver); static::$drivers[$driver] = Cache\Factory::make($driver);
} }
...@@ -41,6 +41,13 @@ class Cache { ...@@ -41,6 +41,13 @@ class Cache {
*/ */
public static function __callStatic($method, $parameters) public static function __callStatic($method, $parameters)
{ {
// --------------------------------------------------
// Passing method calls to the driver instance allows
// a better API for the developer.
//
// For instance, instead of saying Cache::driver()->foo(),
// we can now just say Cache::foo().
// --------------------------------------------------
return call_user_func_array(array(static::driver(), $method), $parameters); return call_user_func_array(array(static::driver(), $method), $parameters);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment