123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- <?php namespace System;
- class Cache {
- /**
- * The active cache drivers.
- *
- * @var Cache\Driver
- */
- private static $drivers = array();
- /**
- * Get a cache driver instance. If no driver name is specified, the default
- * cache driver will be returned as defined in the cache configuration file.
- *
- * Note: Cache drivers are managed as singleton instances.
- *
- * @param string $driver
- * @return Cache\Driver
- */
- public static function driver($driver = null)
- {
- if (is_null($driver))
- {
- $driver = Config::get('cache.driver');
- }
- if ( ! array_key_exists($driver, static::$drivers))
- {
- switch ($driver)
- {
- case 'file':
- static::$drivers[$driver] = new Cache\Driver\File;
- break;
- case 'memcached':
- static::$drivers[$driver] = new Cache\Driver\Memcached;
- break;
- case 'apc':
- static::$drivers[$driver] = new Cache\Driver\APC;
- break;
- default:
- throw new \Exception("Cache driver [$driver] is not supported.");
- }
- }
- return static::$drivers[$driver];
- }
- /**
- * Get an item from the cache.
- *
- * @param string $key
- * @param mixed $default
- * @param string $driver
- * @return mixed
- */
- public static function get($key, $default = null, $driver = null)
- {
- if (array_key_exists($key, static::driver($driver)->items))
- {
- return static::driver($driver)->items[$key];
- }
- if (is_null($item = static::driver($driver)->get($key)))
- {
- return is_callable($default) ? call_user_func($default) : $default;
- }
- return $item;
- }
- /**
- * Get an item from the cache. If the item doesn't exist in the cache, store
- * the default value in the cache and return it.
- *
- * @param string $key
- * @param mixed $default
- * @param int $minutes
- * @param string $driver
- * @return mixed
- */
- public static function remember($key, $default, $minutes, $driver = null)
- {
- if ( ! is_null($item = static::get($key)))
- {
- return $item;
- }
- $default = is_callable($default) ? call_user_func($default) : $default;
- static::driver($driver)->put($key, $default, $minutes);
- return $default;
- }
- /**
- * Pass all other methods to the default driver.
- *
- * Passing method calls to the driver instance provides a better API for the
- * developer. For instance, instead of saying Cache::driver()->foo(), we can
- * now just say Cache::foo().
- */
- public static function __callStatic($method, $parameters)
- {
- return call_user_func_array(array(static::driver(), $method), $parameters);
- }
- }
|