Skip to content
Snippets Groups Projects
NestedOutput.php 1.4 KiB
Newer Older
Eric Rasmussen's avatar
Eric Rasmussen committed
<?php

/**
* This class extends UNL_Cache_Lite and uses output buffering to get the data to cache.
* It supports nesting of caches
*
* @package UNL_Cache_Lite
* @version $Id: NestedOutput.php 279664 2009-05-01 13:19:25Z tacker $
* @author Markus Tacker <tacker@php.net>
*/

class UNL_Cache_Lite_NestedOutput extends UNL_Cache_Lite_Output
{
	private $nestedIds = array();
	private $nestedGroups = array();

    /**
    * Start the cache
    *
    * @param string $id cache id
    * @param string $group name of the cache group
    * @param boolean $doNotTestCacheValidity if set to true, the cache validity won't be tested
    * @return boolean|string false if the cache is not hit else the data
    * @access public
    */
    function start($id, $group = 'default', $doNotTestCacheValidity = false)
    {
    	$this->nestedIds[] = $id;
    	$this->nestedGroups[] = $group;
    	$data = $this->get($id, $group, $doNotTestCacheValidity);
        if ($data !== false) {
            return $data;
        }
        ob_start();
        ob_implicit_flush(false);
        return false;
    }

    /**
    * Stop the cache
    *
    * @param boolen
    * @return string return contents of cache
    */
    function end()
    {
        $data = ob_get_contents();
        ob_end_clean();
        $id = array_pop($this->nestedIds);
        $group = array_pop($this->nestedGroups);
        $this->save($data, $id, $group);
		return $data;
    }

}