| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | <?php defined('SYSPATH') OR die('No direct script access.');/** * View fragment caching. This is primarily used to cache small parts of a view * that rarely change. For instance, you may want to cache the footer of your * template because it has very little dynamic content. Or you could cache a * user profile page and delete the fragment when the user updates. * * For obvious reasons, fragment caching should not be applied to any * content that contains forms. * * [!!] Multiple language (I18n) support was added in v3.0.4. * * @package    Kohana * @category   Helpers * @author     Kohana Team * @copyright  (c) 2009-2012 Kohana Team * @license    http://kohanaframework.org/license * @uses       Kohana::cache */class Kohana_Fragment {	/**	 * @var  integer  default number of seconds to cache for	 */	public static $lifetime = 30;	/**	 * @var  boolean  use multilingual fragment support?	 */	public static $i18n = FALSE;	/**	 * @var  array  list of buffer => cache key	 */	protected static $_caches = array();	/**	 * Generate the cache key name for a fragment.	 *	 *     $key = Fragment::_cache_key('footer', TRUE);	 *	 * @param   string  $name   fragment name	 * @param   boolean $i18n   multilingual fragment support	 * @return  string	 * @uses    I18n::lang	 * @since   3.0.4	 */	protected static function _cache_key($name, $i18n = NULL)	{		if ($i18n === NULL)		{			// Use the default setting			$i18n = Fragment::$i18n;		}		// Language prefix for cache key		$i18n = ($i18n === TRUE) ? I18n::lang() : '';		// Note: $i18n and $name need to be delimited to prevent naming collisions		return 'Fragment::cache('.$i18n.'+'.$name.')';	}	/**	 * Load a fragment from cache and display it. Multiple fragments can	 * be nested with different life times.	 *	 *     if ( ! Fragment::load('footer')) {	 *         // Anything that is echo'ed here will be saved	 *         Fragment::save();	 *     }	 *	 * @param   string  $name       fragment name	 * @param   integer $lifetime   fragment cache lifetime	 * @param   boolean $i18n       multilingual fragment support	 * @return  boolean	 */	public static function load($name, $lifetime = NULL, $i18n = NULL)	{		// Set the cache lifetime		$lifetime = ($lifetime === NULL) ? Fragment::$lifetime : (int) $lifetime;		// Get the cache key name		$cache_key = Fragment::_cache_key($name, $i18n);		if ($fragment = Kohana::cache($cache_key, NULL, $lifetime))		{			// Display the cached fragment now			echo $fragment;			return TRUE;		}		else		{			// Start the output buffer			ob_start();			// Store the cache key by the buffer level			Fragment::$_caches[ob_get_level()] = $cache_key;			return FALSE;		}	}	/**	 * Saves the currently open fragment in the cache.	 *	 *     Fragment::save();	 *	 * @return  void	 */	public static function save()	{		// Get the buffer level		$level = ob_get_level();		if (isset(Fragment::$_caches[$level]))		{			// Get the cache key based on the level			$cache_key = Fragment::$_caches[$level];			// Delete the cache key, we don't need it anymore			unset(Fragment::$_caches[$level]);			// Get the output buffer and display it at the same time			$fragment = ob_get_flush();			// Cache the fragment			Kohana::cache($cache_key, $fragment);		}	}	/**	 * Delete a cached fragment.	 *	 *     Fragment::delete($key);	 *	 * @param   string  $name   fragment name	 * @param   boolean $i18n   multilingual fragment support	 * @return  void	 */	public static function delete($name, $i18n = NULL)	{		// Invalid the cache		Kohana::cache(Fragment::_cache_key($name, $i18n), NULL, -3600);	}} // End Fragment
 |