Initial commit
This commit is contained in:
		
							
								
								
									
										442
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_cacheresource.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										442
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_cacheresource.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,442 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Cache Handler API | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| abstract class Smarty_CacheResource | ||||
| { | ||||
|     /** | ||||
|      * cache for Smarty_CacheResource instances | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $resources = array(); | ||||
|  | ||||
|     /** | ||||
|      * resource types provided by the core | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected static $sysplugins = array( | ||||
|         'file' => true, | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Cached   $cached    cached object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     abstract public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template); | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     abstract public function populateTimestamp(Smarty_Template_Cached $cached); | ||||
|  | ||||
|     /** | ||||
|      * Read the cached template and process header | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param Smarty_Template_Cached   $cached    cached object | ||||
|      * | ||||
|      * @return boolean true or false if the cached content does not exist | ||||
|      */ | ||||
|     abstract public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null); | ||||
|  | ||||
|     /** | ||||
|      * Write the rendered template output to cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param string                   $content   content to cache | ||||
|      * | ||||
|      * @return boolean success | ||||
|      */ | ||||
|     abstract public function writeCachedContent(Smarty_Internal_Template $_template, $content); | ||||
|  | ||||
|     /** | ||||
|      * Return cached content | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return null|string | ||||
|      */ | ||||
|     public function getCachedContent(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         if ($_template->cached->handler->process($_template)) { | ||||
|             ob_start(); | ||||
|             $_template->properties['unifunc']($_template); | ||||
|  | ||||
|             return ob_get_clean(); | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache | ||||
|      * | ||||
|      * @param Smarty  $smarty   Smarty object | ||||
|      * @param integer $exp_time expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     abstract public function clearAll(Smarty $smarty, $exp_time = null); | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for a specific template | ||||
|      * | ||||
|      * @param Smarty  $smarty        Smarty object | ||||
|      * @param string  $resource_name template name | ||||
|      * @param string  $cache_id      cache id | ||||
|      * @param string  $compile_id    compile id | ||||
|      * @param integer $exp_time      expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     abstract public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time); | ||||
|  | ||||
|     /** | ||||
|      * @param Smarty                 $smarty | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return bool|null | ||||
|      */ | ||||
|     public function locked(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         // theoretically locking_timeout should be checked against time_limit (max_execution_time) | ||||
|         $start = microtime(true); | ||||
|         $hadLock = null; | ||||
|         while ($this->hasLock($smarty, $cached)) { | ||||
|             $hadLock = true; | ||||
|             if (microtime(true) - $start > $smarty->locking_timeout) { | ||||
|                 // abort waiting for lock release | ||||
|                 return false; | ||||
|             } | ||||
|             sleep(1); | ||||
|         } | ||||
|  | ||||
|         return $hadLock; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check is cache is locked for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         // check if lock exists | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Lock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         // create lock | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unlock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         // release lock | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load Cache Resource Handler | ||||
|      * | ||||
|      * @param Smarty $smarty Smarty object | ||||
|      * @param string $type   name of the cache resource | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return Smarty_CacheResource Cache Resource Handler | ||||
|      */ | ||||
|     public static function load(Smarty $smarty, $type = null) | ||||
|     { | ||||
|         if (!isset($type)) { | ||||
|             $type = $smarty->caching_type; | ||||
|         } | ||||
|  | ||||
|         // try smarty's cache | ||||
|         if (isset($smarty->_cacheresource_handlers[$type])) { | ||||
|             return $smarty->_cacheresource_handlers[$type]; | ||||
|         } | ||||
|  | ||||
|         // try registered resource | ||||
|         if (isset($smarty->registered_cache_resources[$type])) { | ||||
|             // do not cache these instances as they may vary from instance to instance | ||||
|             return $smarty->_cacheresource_handlers[$type] = $smarty->registered_cache_resources[$type]; | ||||
|         } | ||||
|         // try sysplugins dir | ||||
|         if (isset(self::$sysplugins[$type])) { | ||||
|             if (!isset(self::$resources[$type])) { | ||||
|                 $cache_resource_class = 'Smarty_Internal_CacheResource_' . ucfirst($type); | ||||
|                 self::$resources[$type] = new $cache_resource_class(); | ||||
|             } | ||||
|  | ||||
|             return $smarty->_cacheresource_handlers[$type] = self::$resources[$type]; | ||||
|         } | ||||
|         // try plugins dir | ||||
|         $cache_resource_class = 'Smarty_CacheResource_' . ucfirst($type); | ||||
|         if ($smarty->loadPlugin($cache_resource_class)) { | ||||
|             if (!isset(self::$resources[$type])) { | ||||
|                 self::$resources[$type] = new $cache_resource_class(); | ||||
|             } | ||||
|  | ||||
|             return $smarty->_cacheresource_handlers[$type] = self::$resources[$type]; | ||||
|         } | ||||
|         // give up | ||||
|         throw new SmartyException("Unable to load cache resource '{$type}'"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Invalid Loaded Cache Files | ||||
|      * | ||||
|      * @param Smarty $smarty Smarty object | ||||
|      */ | ||||
|     public static function invalidLoadedCache(Smarty $smarty) | ||||
|     { | ||||
|         foreach ($smarty->template_objects as $tpl) { | ||||
|             if (isset($tpl->cached)) { | ||||
|                 $tpl->cached->valid = false; | ||||
|                 $tpl->cached->processed = false; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Data Object | ||||
|  * Cache Data Container for Template Files | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| class Smarty_Template_Cached | ||||
| { | ||||
|     /** | ||||
|      * Source Filepath | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $filepath = false; | ||||
|  | ||||
|     /** | ||||
|      * Source Content | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $content = null; | ||||
|  | ||||
|     /** | ||||
|      * Source Timestamp | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $timestamp = false; | ||||
|  | ||||
|     /** | ||||
|      * Source Existence | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $exists = false; | ||||
|  | ||||
|     /** | ||||
|      * Cache Is Valid | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $valid = false; | ||||
|  | ||||
|     /** | ||||
|      * Cache was processed | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $processed = false; | ||||
|  | ||||
|     /** | ||||
|      * CacheResource Handler | ||||
|      * | ||||
|      * @var Smarty_CacheResource | ||||
|      */ | ||||
|     public $handler = null; | ||||
|  | ||||
|     /** | ||||
|      * Template Compile Id (Smarty_Internal_Template::$compile_id) | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compile_id = null; | ||||
|  | ||||
|     /** | ||||
|      * Template Cache Id (Smarty_Internal_Template::$cache_id) | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $cache_id = null; | ||||
|  | ||||
|     /** | ||||
|      * Id for cache locking | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $lock_id = null; | ||||
|  | ||||
|     /** | ||||
|      * flag that cache is locked by this instance | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $is_locked = false; | ||||
|  | ||||
|     /** | ||||
|      * Source Object | ||||
|      * | ||||
|      * @var Smarty_Template_Source | ||||
|      */ | ||||
|     public $source = null; | ||||
|  | ||||
|     /** | ||||
|      * create Cached Object container | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     public function __construct(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $this->compile_id = $_template->compile_id; | ||||
|         $this->cache_id = $_template->cache_id; | ||||
|         $this->source = $_template->source; | ||||
|         $_template->cached = $this; | ||||
|         $smarty = $_template->smarty; | ||||
|  | ||||
|         // | ||||
|         // load resource handler | ||||
|         // | ||||
|         $this->handler = $handler = Smarty_CacheResource::load($smarty); // Note: prone to circular references | ||||
|  | ||||
|         // | ||||
|         //    check if cache is valid | ||||
|         // | ||||
|         if (!($_template->caching == Smarty::CACHING_LIFETIME_CURRENT || $_template->caching == Smarty::CACHING_LIFETIME_SAVED) || $_template->source->recompiled) { | ||||
|             $handler->populate($this, $_template); | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         while (true) { | ||||
|             while (true) { | ||||
|                 $handler->populate($this, $_template); | ||||
|                 if ($this->timestamp === false || $smarty->force_compile || $smarty->force_cache) { | ||||
|                     $this->valid = false; | ||||
|                 } else { | ||||
|                     $this->valid = true; | ||||
|                 } | ||||
|                 if ($this->valid && $_template->caching == Smarty::CACHING_LIFETIME_CURRENT && $_template->cache_lifetime >= 0 && time() > ($this->timestamp + $_template->cache_lifetime)) { | ||||
|                     // lifetime expired | ||||
|                     $this->valid = false; | ||||
|                 } | ||||
|                 if ($this->valid || !$_template->smarty->cache_locking) { | ||||
|                     break; | ||||
|                 } | ||||
|                 if (!$this->handler->locked($_template->smarty, $this)) { | ||||
|                     $this->handler->acquireLock($_template->smarty, $this); | ||||
|                     break 2; | ||||
|                 } | ||||
|             } | ||||
|             if ($this->valid) { | ||||
|                 if (!$_template->smarty->cache_locking || $this->handler->locked($_template->smarty, $this) === null) { | ||||
|                     // load cache file for the following checks | ||||
|                     if ($smarty->debugging) { | ||||
|                         Smarty_Internal_Debug::start_cache($_template); | ||||
|                     } | ||||
|                     if ($handler->process($_template, $this) === false) { | ||||
|                         $this->valid = false; | ||||
|                     } else { | ||||
|                         $this->processed = true; | ||||
|                     } | ||||
|                     if ($smarty->debugging) { | ||||
|                         Smarty_Internal_Debug::end_cache($_template); | ||||
|                     } | ||||
|                 } else { | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 return; | ||||
|             } | ||||
|             if ($this->valid && $_template->caching === Smarty::CACHING_LIFETIME_SAVED && $_template->properties['cache_lifetime'] >= 0 && (time() > ($_template->cached->timestamp + $_template->properties['cache_lifetime']))) { | ||||
|                 $this->valid = false; | ||||
|             } | ||||
|             if (!$this->valid && $_template->smarty->cache_locking) { | ||||
|                 $this->handler->acquireLock($_template->smarty, $this); | ||||
|  | ||||
|                 return; | ||||
|             } else { | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Write this cache object to handler | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param string                   $content   content to cache | ||||
|      * | ||||
|      * @return boolean success | ||||
|      */ | ||||
|     public function write(Smarty_Internal_Template $_template, $content) | ||||
|     { | ||||
|         if (!$_template->source->recompiled) { | ||||
|             if ($this->handler->writeCachedContent($_template, $content)) { | ||||
|                 $this->content = null; | ||||
|                 $this->timestamp = time(); | ||||
|                 $this->exists = true; | ||||
|                 $this->valid = true; | ||||
|                 if ($_template->smarty->cache_locking) { | ||||
|                     $this->handler->releaseLock($_template->smarty, $this); | ||||
|                 } | ||||
|  | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										284
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_cacheresource_custom.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										284
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_cacheresource_custom.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,284 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Cache Handler API | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| abstract class Smarty_CacheResource_Custom extends Smarty_CacheResource | ||||
| { | ||||
|     /** | ||||
|      * fetch cached content and its modification time from data source | ||||
|      * | ||||
|      * @param  string  $id         unique cache content identifier | ||||
|      * @param  string  $name       template name | ||||
|      * @param  string  $cache_id   cache id | ||||
|      * @param  string  $compile_id compile id | ||||
|      * @param  string  $content    cached content | ||||
|      * @param  integer $mtime      cache modification timestamp (epoch) | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     abstract protected function fetch($id, $name, $cache_id, $compile_id, &$content, &$mtime); | ||||
|  | ||||
|     /** | ||||
|      * Fetch cached content's modification timestamp from data source | ||||
|      * {@internal implementing this method is optional. | ||||
|      *  Only implement it if modification times can be accessed faster than loading the complete cached content.}} | ||||
|      * | ||||
|      * @param  string $id         unique cache content identifier | ||||
|      * @param  string $name       template name | ||||
|      * @param  string $cache_id   cache id | ||||
|      * @param  string $compile_id compile id | ||||
|      * | ||||
|      * @return integer|boolean timestamp (epoch) the template was modified, or false if not found | ||||
|      */ | ||||
|     protected function fetchTimestamp($id, $name, $cache_id, $compile_id) | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Save content to cache | ||||
|      * | ||||
|      * @param  string       $id         unique cache content identifier | ||||
|      * @param  string       $name       template name | ||||
|      * @param  string       $cache_id   cache id | ||||
|      * @param  string       $compile_id compile id | ||||
|      * @param  integer|null $exp_time   seconds till expiration or null | ||||
|      * @param  string       $content    content to cache | ||||
|      * | ||||
|      * @return boolean      success | ||||
|      */ | ||||
|     abstract protected function save($id, $name, $cache_id, $compile_id, $exp_time, $content); | ||||
|  | ||||
|     /** | ||||
|      * Delete content from cache | ||||
|      * | ||||
|      * @param  string       $name       template name | ||||
|      * @param  string       $cache_id   cache id | ||||
|      * @param  string       $compile_id compile id | ||||
|      * @param  integer|null $exp_time   seconds till expiration time in seconds or null | ||||
|      * | ||||
|      * @return integer      number of deleted caches | ||||
|      */ | ||||
|     abstract protected function delete($name, $cache_id, $compile_id, $exp_time); | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Cached   $cached    cached object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $_cache_id = isset($cached->cache_id) ? preg_replace('![^\w\|]+!', '_', $cached->cache_id) : null; | ||||
|         $_compile_id = isset($cached->compile_id) ? preg_replace('![^\w\|]+!', '_', $cached->compile_id) : null; | ||||
|  | ||||
|         $cached->filepath = sha1($cached->source->filepath . $_cache_id . $_compile_id); | ||||
|         $this->populateTimestamp($cached); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Cached $cached | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $mtime = $this->fetchTimestamp($cached->filepath, $cached->source->name, $cached->cache_id, $cached->compile_id); | ||||
|         if ($mtime !== null) { | ||||
|             $cached->timestamp = $mtime; | ||||
|             $cached->exists = !!$cached->timestamp; | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         $timestamp = null; | ||||
|         $this->fetch($cached->filepath, $cached->source->name, $cached->cache_id, $cached->compile_id, $cached->content, $timestamp); | ||||
|         $cached->timestamp = isset($timestamp) ? $timestamp : false; | ||||
|         $cached->exists = !!$cached->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read the cached template and process the header | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * @param  Smarty_Template_Cached   $cached    cached object | ||||
|      * | ||||
|      * @return boolean                 true or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null) | ||||
|     { | ||||
|         if (!$cached) { | ||||
|             $cached = $_template->cached; | ||||
|         } | ||||
|         $content = $cached->content ? $cached->content : null; | ||||
|         $timestamp = $cached->timestamp ? $cached->timestamp : null; | ||||
|         if ($content === null || !$timestamp) { | ||||
|             $this->fetch( | ||||
|                 $_template->cached->filepath, | ||||
|                 $_template->source->name, | ||||
|                 $_template->cache_id, | ||||
|                 $_template->compile_id, | ||||
|                 $content, | ||||
|                 $timestamp | ||||
|             ); | ||||
|         } | ||||
|         if (isset($content)) { | ||||
|             /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|              * used in evaluated code | ||||
|              */ | ||||
|             $_smarty_tpl = $_template; | ||||
|             eval("?>" . $content); | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Write the rendered template output to cache | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * @param  string                   $content   content to cache | ||||
|      * | ||||
|      * @return boolean                  success | ||||
|      */ | ||||
|     public function writeCachedContent(Smarty_Internal_Template $_template, $content) | ||||
|     { | ||||
|         return $this->save( | ||||
|             $_template->cached->filepath, | ||||
|             $_template->source->name, | ||||
|             $_template->cache_id, | ||||
|             $_template->compile_id, | ||||
|             $_template->properties['cache_lifetime'], | ||||
|             $content | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache | ||||
|      * | ||||
|      * @param  Smarty  $smarty   Smarty object | ||||
|      * @param  integer $exp_time expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     public function clearAll(Smarty $smarty, $exp_time = null) | ||||
|     { | ||||
|         $this->cache = array(); | ||||
|  | ||||
|         return $this->delete(null, null, null, $exp_time); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for a specific template | ||||
|      * | ||||
|      * @param  Smarty  $smarty        Smarty object | ||||
|      * @param  string  $resource_name template name | ||||
|      * @param  string  $cache_id      cache id | ||||
|      * @param  string  $compile_id    compile id | ||||
|      * @param  integer $exp_time      expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time) | ||||
|     { | ||||
|         $this->cache = array(); | ||||
|         $cache_name = null; | ||||
|  | ||||
|         if (isset($resource_name)) { | ||||
|             $_save_stat = $smarty->caching; | ||||
|             $smarty->caching = true; | ||||
|             $tpl = new $smarty->template_class($resource_name, $smarty); | ||||
|             $smarty->caching = $_save_stat; | ||||
|  | ||||
|             if ($tpl->source->exists) { | ||||
|                 $cache_name = $tpl->source->name; | ||||
|             } else { | ||||
|                 return 0; | ||||
|             } | ||||
|             // remove from template cache | ||||
|             if ($smarty->allow_ambiguous_resources) { | ||||
|                 $_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id; | ||||
|             } else { | ||||
|                 $_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id; | ||||
|             } | ||||
|             if (isset($_templateId[150])) { | ||||
|                 $_templateId = sha1($_templateId); | ||||
|             } | ||||
|             unset($smarty->template_objects[$_templateId]); | ||||
|             // template object no longer needed | ||||
|             unset($tpl); | ||||
|         } | ||||
|  | ||||
|         return $this->delete($cache_name, $cache_id, $compile_id, $exp_time); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check is cache is locked for this template | ||||
|      * | ||||
|      * @param  Smarty                 $smarty Smarty object | ||||
|      * @param  Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return boolean               true or false if cache is locked | ||||
|      */ | ||||
|     public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $id = $cached->filepath; | ||||
|         $name = $cached->source->name . '.lock'; | ||||
|  | ||||
|         $mtime = $this->fetchTimestamp($id, $name, null, null); | ||||
|         if ($mtime === null) { | ||||
|             $this->fetch($id, $name, null, null, $content, $mtime); | ||||
|         } | ||||
|  | ||||
|         return $mtime && time() - $mtime < $smarty->locking_timeout; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Lock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = true; | ||||
|  | ||||
|         $id = $cached->filepath; | ||||
|         $name = $cached->source->name . '.lock'; | ||||
|         $this->save($id, $name, null, null, $smarty->locking_timeout, ''); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unlock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = false; | ||||
|  | ||||
|         $name = $cached->source->name . '.lock'; | ||||
|         $this->delete($name, null, null, null); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,493 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Cache Handler Base for Key/Value Storage Implementations | ||||
|  * This class implements the functionality required to use simple key/value stores | ||||
|  * for hierarchical cache groups. key/value stores like memcache or APC do not support | ||||
|  * wildcards in keys, therefore a cache group cannot be cleared like "a|*" - which | ||||
|  * is no problem to filesystem and RDBMS implementations. | ||||
|  * This implementation is based on the concept of invalidation. While one specific cache | ||||
|  * can be identified and cleared, any range of caches cannot be identified. For this reason | ||||
|  * each level of the cache group hierarchy can have its own value in the store. These values | ||||
|  * are nothing but microtimes, telling us when a particular cache group was cleared for the | ||||
|  * last time. These keys are evaluated for every cache read to determine if the cache has | ||||
|  * been invalidated since it was created and should hence be treated as inexistent. | ||||
|  * Although deep hierarchies are possible, they are not recommended. Try to keep your | ||||
|  * cache groups as shallow as possible. Anything up 3-5 parents should be ok. So | ||||
|  * »a|b|c« is a good depth where »a|b|c|d|e|f|g|h|i|j|k« isn't. Try to join correlating | ||||
|  * cache groups: if your cache groups look somewhat like »a|b|$page|$items|$whatever« | ||||
|  * consider using »a|b|c|$page-$items-$whatever« instead. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| abstract class Smarty_CacheResource_KeyValueStore extends Smarty_CacheResource | ||||
| { | ||||
|     /** | ||||
|      * cache for contents | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $contents = array(); | ||||
|     /** | ||||
|      * cache for timestamps | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $timestamps = array(); | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Cached   $cached    cached object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $cached->filepath = $_template->source->uid | ||||
|             . '#' . $this->sanitize($cached->source->resource) | ||||
|             . '#' . $this->sanitize($cached->cache_id) | ||||
|             . '#' . $this->sanitize($cached->compile_id); | ||||
|  | ||||
|         $this->populateTimestamp($cached); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         if (!$this->fetch($cached->filepath, $cached->source->name, $cached->cache_id, $cached->compile_id, $content, $timestamp, $cached->source->uid)) { | ||||
|             return; | ||||
|         } | ||||
|         $cached->content = $content; | ||||
|         $cached->timestamp = (int) $timestamp; | ||||
|         $cached->exists = $cached->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read the cached template and process the header | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * @param  Smarty_Template_Cached   $cached    cached object | ||||
|      * | ||||
|      * @return boolean                 true or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null) | ||||
|     { | ||||
|         if (!$cached) { | ||||
|             $cached = $_template->cached; | ||||
|         } | ||||
|         $content = $cached->content ? $cached->content : null; | ||||
|         $timestamp = $cached->timestamp ? $cached->timestamp : null; | ||||
|         if ($content === null || !$timestamp) { | ||||
|             if (!$this->fetch($_template->cached->filepath, $_template->source->name, $_template->cache_id, $_template->compile_id, $content, $timestamp, $_template->source->uid)) { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         if (isset($content)) { | ||||
|             /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|              * used in evaluated code | ||||
|              */ | ||||
|             $_smarty_tpl = $_template; | ||||
|             eval("?>" . $content); | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Write the rendered template output to cache | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * @param  string                   $content   content to cache | ||||
|      * | ||||
|      * @return boolean                  success | ||||
|      */ | ||||
|     public function writeCachedContent(Smarty_Internal_Template $_template, $content) | ||||
|     { | ||||
|         $this->addMetaTimestamp($content); | ||||
|  | ||||
|         return $this->write(array($_template->cached->filepath => $content), $_template->properties['cache_lifetime']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache | ||||
|      * {@internal the $exp_time argument is ignored altogether }} | ||||
|      * | ||||
|      * @param  Smarty  $smarty   Smarty object | ||||
|      * @param  integer $exp_time expiration time [being ignored] | ||||
|      * | ||||
|      * @return integer number of cache files deleted [always -1] | ||||
|      * @uses purge() to clear the whole store | ||||
|      * @uses invalidate() to mark everything outdated if purge() is inapplicable | ||||
|      */ | ||||
|     public function clearAll(Smarty $smarty, $exp_time = null) | ||||
|     { | ||||
|         if (!$this->purge()) { | ||||
|             $this->invalidate(null); | ||||
|         } | ||||
|  | ||||
|         return - 1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for a specific template | ||||
|      * {@internal the $exp_time argument is ignored altogether}} | ||||
|      * | ||||
|      * @param  Smarty  $smarty        Smarty object | ||||
|      * @param  string  $resource_name template name | ||||
|      * @param  string  $cache_id      cache id | ||||
|      * @param  string  $compile_id    compile id | ||||
|      * @param  integer $exp_time      expiration time [being ignored] | ||||
|      * | ||||
|      * @return integer number of cache files deleted [always -1] | ||||
|      * @uses buildCachedFilepath() to generate the CacheID | ||||
|      * @uses invalidate() to mark CacheIDs parent chain as outdated | ||||
|      * @uses delete() to remove CacheID from cache | ||||
|      */ | ||||
|     public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time) | ||||
|     { | ||||
|         $uid = $this->getTemplateUid($smarty, $resource_name, $cache_id, $compile_id); | ||||
|         $cid = $uid . '#' . $this->sanitize($resource_name) . '#' . $this->sanitize($cache_id) . '#' . $this->sanitize($compile_id); | ||||
|         $this->delete(array($cid)); | ||||
|         $this->invalidate($cid, $resource_name, $cache_id, $compile_id, $uid); | ||||
|  | ||||
|         return - 1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get template's unique ID | ||||
|      * | ||||
|      * @param  Smarty $smarty        Smarty object | ||||
|      * @param  string $resource_name template name | ||||
|      * @param  string $cache_id      cache id | ||||
|      * @param  string $compile_id    compile id | ||||
|      * | ||||
|      * @return string filepath of cache file | ||||
|      */ | ||||
|     protected function getTemplateUid(Smarty $smarty, $resource_name, $cache_id, $compile_id) | ||||
|     { | ||||
|         $uid = ''; | ||||
|         if (isset($resource_name)) { | ||||
|             $tpl = new $smarty->template_class($resource_name, $smarty); | ||||
|             if ($tpl->source->exists) { | ||||
|                 $uid = $tpl->source->uid; | ||||
|             } | ||||
|  | ||||
|             // remove from template cache | ||||
|             if ($smarty->allow_ambiguous_resources) { | ||||
|                 $_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id; | ||||
|             } else { | ||||
|                 $_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id; | ||||
|             } | ||||
|             if (isset($_templateId[150])) { | ||||
|                 $_templateId = sha1($_templateId); | ||||
|             } | ||||
|             unset($smarty->template_objects[$_templateId]); | ||||
|         } | ||||
|  | ||||
|         return $uid; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sanitize CacheID components | ||||
|      * | ||||
|      * @param  string $string CacheID component to sanitize | ||||
|      * | ||||
|      * @return string sanitized CacheID component | ||||
|      */ | ||||
|     protected function sanitize($string) | ||||
|     { | ||||
|         // some poeple smoke bad weed | ||||
|         $string = trim($string, '|'); | ||||
|         if (!$string) { | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         return preg_replace('#[^\w\|]+#S', '_', $string); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Fetch and prepare a cache object. | ||||
|      * | ||||
|      * @param  string  $cid           CacheID to fetch | ||||
|      * @param  string  $resource_name template name | ||||
|      * @param  string  $cache_id      cache id | ||||
|      * @param  string  $compile_id    compile id | ||||
|      * @param  string  $content       cached content | ||||
|      * @param  integer &$timestamp    cached timestamp (epoch) | ||||
|      * @param  string  $resource_uid  resource's uid | ||||
|      * | ||||
|      * @return boolean success | ||||
|      */ | ||||
|     protected function fetch($cid, $resource_name = null, $cache_id = null, $compile_id = null, &$content = null, &$timestamp = null, $resource_uid = null) | ||||
|     { | ||||
|         $t = $this->read(array($cid)); | ||||
|         $content = !empty($t[$cid]) ? $t[$cid] : null; | ||||
|         $timestamp = null; | ||||
|  | ||||
|         if ($content && ($timestamp = $this->getMetaTimestamp($content))) { | ||||
|             $invalidated = $this->getLatestInvalidationTimestamp($cid, $resource_name, $cache_id, $compile_id, $resource_uid); | ||||
|             if ($invalidated > $timestamp) { | ||||
|                 $timestamp = null; | ||||
|                 $content = null; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return !!$content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add current microtime to the beginning of $cache_content | ||||
|      * {@internal the header uses 8 Bytes, the first 4 Bytes are the seconds, the second 4 Bytes are the microseconds}} | ||||
|      * | ||||
|      * @param string &$content the content to be cached | ||||
|      */ | ||||
|     protected function addMetaTimestamp(&$content) | ||||
|     { | ||||
|         $mt = explode(" ", microtime()); | ||||
|         $ts = pack("NN", $mt[1], (int) ($mt[0] * 100000000)); | ||||
|         $content = $ts . $content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Extract the timestamp the $content was cached | ||||
|      * | ||||
|      * @param  string &$content the cached content | ||||
|      * | ||||
|      * @return float  the microtime the content was cached | ||||
|      */ | ||||
|     protected function getMetaTimestamp(&$content) | ||||
|     { | ||||
|         $s = unpack("N", substr($content, 0, 4)); | ||||
|         $m = unpack("N", substr($content, 4, 4)); | ||||
|         $content = substr($content, 8); | ||||
|  | ||||
|         return $s[1] + ($m[1] / 100000000); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Invalidate CacheID | ||||
|      * | ||||
|      * @param  string $cid           CacheID | ||||
|      * @param  string $resource_name template name | ||||
|      * @param  string $cache_id      cache id | ||||
|      * @param  string $compile_id    compile id | ||||
|      * @param  string $resource_uid  source's uid | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     protected function invalidate($cid = null, $resource_name = null, $cache_id = null, $compile_id = null, $resource_uid = null) | ||||
|     { | ||||
|         $now = microtime(true); | ||||
|         $key = null; | ||||
|         // invalidate everything | ||||
|         if (!$resource_name && !$cache_id && !$compile_id) { | ||||
|             $key = 'IVK#ALL'; | ||||
|         } // invalidate all caches by template | ||||
|         else { | ||||
|             if ($resource_name && !$cache_id && !$compile_id) { | ||||
|                 $key = 'IVK#TEMPLATE#' . $resource_uid . '#' . $this->sanitize($resource_name); | ||||
|             } // invalidate all caches by cache group | ||||
|             else { | ||||
|                 if (!$resource_name && $cache_id && !$compile_id) { | ||||
|                     $key = 'IVK#CACHE#' . $this->sanitize($cache_id); | ||||
|                 } // invalidate all caches by compile id | ||||
|                 else { | ||||
|                     if (!$resource_name && !$cache_id && $compile_id) { | ||||
|                         $key = 'IVK#COMPILE#' . $this->sanitize($compile_id); | ||||
|                     } // invalidate by combination | ||||
|                     else { | ||||
|                         $key = 'IVK#CID#' . $cid; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $this->write(array($key => $now)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine the latest timestamp known to the invalidation chain | ||||
|      * | ||||
|      * @param  string $cid           CacheID to determine latest invalidation timestamp of | ||||
|      * @param  string $resource_name template name | ||||
|      * @param  string $cache_id      cache id | ||||
|      * @param  string $compile_id    compile id | ||||
|      * @param  string $resource_uid  source's filepath | ||||
|      * | ||||
|      * @return float  the microtime the CacheID was invalidated | ||||
|      */ | ||||
|     protected function getLatestInvalidationTimestamp($cid, $resource_name = null, $cache_id = null, $compile_id = null, $resource_uid = null) | ||||
|     { | ||||
|         // abort if there is no CacheID | ||||
|         if (false && !$cid) { | ||||
|             return 0; | ||||
|         } | ||||
|         // abort if there are no InvalidationKeys to check | ||||
|         if (!($_cid = $this->listInvalidationKeys($cid, $resource_name, $cache_id, $compile_id, $resource_uid))) { | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         // there are no InValidationKeys | ||||
|         if (!($values = $this->read($_cid))) { | ||||
|             return 0; | ||||
|         } | ||||
|         // make sure we're dealing with floats | ||||
|         $values = array_map('floatval', $values); | ||||
|  | ||||
|         return max($values); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Translate a CacheID into the list of applicable InvalidationKeys. | ||||
|      * Splits "some|chain|into|an|array" into array( '#clearAll#', 'some', 'some|chain', 'some|chain|into', ... ) | ||||
|      * | ||||
|      * @param  string $cid           CacheID to translate | ||||
|      * @param  string $resource_name template name | ||||
|      * @param  string $cache_id      cache id | ||||
|      * @param  string $compile_id    compile id | ||||
|      * @param  string $resource_uid  source's filepath | ||||
|      * | ||||
|      * @return array  list of InvalidationKeys | ||||
|      * @uses $invalidationKeyPrefix to prepend to each InvalidationKey | ||||
|      */ | ||||
|     protected function listInvalidationKeys($cid, $resource_name = null, $cache_id = null, $compile_id = null, $resource_uid = null) | ||||
|     { | ||||
|         $t = array('IVK#ALL'); | ||||
|         $_name = $_compile = '#'; | ||||
|         if ($resource_name) { | ||||
|             $_name .= $resource_uid . '#' . $this->sanitize($resource_name); | ||||
|             $t[] = 'IVK#TEMPLATE' . $_name; | ||||
|         } | ||||
|         if ($compile_id) { | ||||
|             $_compile .= $this->sanitize($compile_id); | ||||
|             $t[] = 'IVK#COMPILE' . $_compile; | ||||
|         } | ||||
|         $_name .= '#'; | ||||
|         // some poeple smoke bad weed | ||||
|         $cid = trim($cache_id, '|'); | ||||
|         if (!$cid) { | ||||
|             return $t; | ||||
|         } | ||||
|         $i = 0; | ||||
|         while (true) { | ||||
|             // determine next delimiter position | ||||
|             $i = strpos($cid, '|', $i); | ||||
|             // add complete CacheID if there are no more delimiters | ||||
|             if ($i === false) { | ||||
|                 $t[] = 'IVK#CACHE#' . $cid; | ||||
|                 $t[] = 'IVK#CID' . $_name . $cid . $_compile; | ||||
|                 $t[] = 'IVK#CID' . $_name . $_compile; | ||||
|                 break; | ||||
|             } | ||||
|             $part = substr($cid, 0, $i); | ||||
|             // add slice to list | ||||
|             $t[] = 'IVK#CACHE#' . $part; | ||||
|             $t[] = 'IVK#CID' . $_name . $part . $_compile; | ||||
|             // skip past delimiter position | ||||
|             $i ++; | ||||
|         } | ||||
|  | ||||
|         return $t; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check is cache is locked for this template | ||||
|      * | ||||
|      * @param  Smarty                 $smarty Smarty object | ||||
|      * @param  Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return boolean               true or false if cache is locked | ||||
|      */ | ||||
|     public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $key = 'LOCK#' . $cached->filepath; | ||||
|         $data = $this->read(array($key)); | ||||
|  | ||||
|         return $data && time() - $data[$key] < $smarty->locking_timeout; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Lock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = true; | ||||
|         $key = 'LOCK#' . $cached->filepath; | ||||
|         $this->write(array($key => time()), $smarty->locking_timeout); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unlock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = false; | ||||
|         $key = 'LOCK#' . $cached->filepath; | ||||
|         $this->delete(array($key)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read values for a set of keys from cache | ||||
|      * | ||||
|      * @param  array $keys list of keys to fetch | ||||
|      * | ||||
|      * @return array list of values with the given keys used as indexes | ||||
|      */ | ||||
|     abstract protected function read(array $keys); | ||||
|  | ||||
|     /** | ||||
|      * Save values for a set of keys to cache | ||||
|      * | ||||
|      * @param  array $keys   list of values to save | ||||
|      * @param  int   $expire expiration time | ||||
|      * | ||||
|      * @return boolean true on success, false on failure | ||||
|      */ | ||||
|     abstract protected function write(array $keys, $expire = null); | ||||
|  | ||||
|     /** | ||||
|      * Remove values from cache | ||||
|      * | ||||
|      * @param  array $keys list of keys to delete | ||||
|      * | ||||
|      * @return boolean true on success, false on failure | ||||
|      */ | ||||
|     abstract protected function delete(array $keys); | ||||
|  | ||||
|     /** | ||||
|      * Remove *all* values from cache | ||||
|      * | ||||
|      * @return boolean true on success, false on failure | ||||
|      */ | ||||
|     protected function purge() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										94
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_config_source.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_config_source.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Data Object | ||||
|  * Meta Data Container for Config Files | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  * @property string $content | ||||
|  * @property int    $timestamp | ||||
|  * @property bool   $exists | ||||
|  */ | ||||
| class Smarty_Config_Source extends Smarty_Template_Source | ||||
| { | ||||
|     /** | ||||
|      * create Config Object container | ||||
|      * | ||||
|      * @param Smarty_Resource $handler         Resource Handler this source object communicates with | ||||
|      * @param Smarty          $smarty          Smarty instance this source object belongs to | ||||
|      * @param string          $resource        full config_resource | ||||
|      * @param string          $type            type of resource | ||||
|      * @param string          $name            resource name | ||||
|      * @param string          $unique_resource unqiue resource name | ||||
|      */ | ||||
|     public function __construct(Smarty_Resource $handler, Smarty $smarty, $resource, $type, $name, $unique_resource) | ||||
|     { | ||||
|         $this->handler = $handler; // Note: prone to circular references | ||||
|  | ||||
|         // Note: these may be ->config_compiler_class etc in the future | ||||
|         //$this->config_compiler_class = $handler->config_compiler_class; | ||||
|         //$this->config_lexer_class = $handler->config_lexer_class; | ||||
|         //$this->config_parser_class = $handler->config_parser_class; | ||||
|  | ||||
|         $this->smarty = $smarty; | ||||
|         $this->resource = $resource; | ||||
|         $this->type = $type; | ||||
|         $this->name = $name; | ||||
|         $this->unique_resource = $unique_resource; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * <<magic>> Generic setter. | ||||
|      * | ||||
|      * @param  string $property_name valid: content, timestamp, exists | ||||
|      * @param  mixed  $value         newly assigned value (not check for correct type) | ||||
|      * | ||||
|      * @throws SmartyException when the given property name is not valid | ||||
|      */ | ||||
|     public function __set($property_name, $value) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'content': | ||||
|             case 'timestamp': | ||||
|             case 'exists': | ||||
|                 $this->$property_name = $value; | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 throw new SmartyException("invalid config property '$property_name'."); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * <<magic>> Generic getter. | ||||
|      * | ||||
|      * @param  string $property_name valid: content, timestamp, exists | ||||
|      * | ||||
|      * @return mixed|void | ||||
|      * @throws SmartyException when the given property name is not valid | ||||
|      */ | ||||
|     public function __get($property_name) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'timestamp': | ||||
|             case 'exists': | ||||
|                 $this->handler->populateTimestamp($this); | ||||
|  | ||||
|                 return $this->$property_name; | ||||
|  | ||||
|             case 'content': | ||||
|                 return $this->content = $this->handler->getContent($this); | ||||
|  | ||||
|             default: | ||||
|                 throw new SmartyException("config property '$property_name' does not exist."); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,294 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin CacheResource File | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * This class does contain all necessary methods for the HTML cache on file system | ||||
|  * Implements the file system as resource for the HTML cache Version ussing nocache inserts. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  */ | ||||
| class Smarty_Internal_CacheResource_File extends Smarty_CacheResource | ||||
| { | ||||
|     /** | ||||
|      * populate Cached Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Cached   $cached    cached object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $_source_file_path = str_replace(':', '.', $_template->source->filepath); | ||||
|         $_cache_id = isset($_template->cache_id) ? preg_replace('![^\w\|]+!', '_', $_template->cache_id) : null; | ||||
|         $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null; | ||||
|         $_filepath = $_template->source->uid; | ||||
|         // if use_sub_dirs, break file into directories | ||||
|         if ($_template->smarty->use_sub_dirs) { | ||||
|             $_filepath = substr($_filepath, 0, 2) . DS | ||||
|                 . substr($_filepath, 2, 2) . DS | ||||
|                 . substr($_filepath, 4, 2) . DS | ||||
|                 . $_filepath; | ||||
|         } | ||||
|         $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^'; | ||||
|         if (isset($_cache_id)) { | ||||
|             $_cache_id = str_replace('|', $_compile_dir_sep, $_cache_id) . $_compile_dir_sep; | ||||
|         } else { | ||||
|             $_cache_id = ''; | ||||
|         } | ||||
|         if (isset($_compile_id)) { | ||||
|             $_compile_id = $_compile_id . $_compile_dir_sep; | ||||
|         } else { | ||||
|             $_compile_id = ''; | ||||
|         } | ||||
|         $_cache_dir = $_template->smarty->getCacheDir(); | ||||
|         if ($_template->smarty->cache_locking) { | ||||
|             // create locking file name | ||||
|             // relative file name? | ||||
|             if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_cache_dir)) { | ||||
|                 $_lock_dir = rtrim(getcwd(), '/\\') . DS . $_cache_dir; | ||||
|             } else { | ||||
|                 $_lock_dir = $_cache_dir; | ||||
|             } | ||||
|             $cached->lock_id = $_lock_dir . sha1($_cache_id . $_compile_id . $_template->source->uid) . '.lock'; | ||||
|         } | ||||
|         $cached->filepath = $_cache_dir . $_cache_id . $_compile_id . $_filepath . '.' . basename($_source_file_path) . '.php'; | ||||
|         $cached->timestamp = @filemtime($cached->filepath); | ||||
|         $cached->exists = !!$cached->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Cached Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->timestamp = @filemtime($cached->filepath); | ||||
|         $cached->exists = !!$cached->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read the cached template and process its header | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param Smarty_Template_Cached   $cached    cached object | ||||
|      * | ||||
|      * @return booleantrue or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null) | ||||
|     { | ||||
|         /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|          * used in included file | ||||
|          */ | ||||
|         $_smarty_tpl = $_template; | ||||
|  | ||||
|         return @include $_template->cached->filepath; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Write the rendered template output to cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param string                   $content   content to cache | ||||
|      * | ||||
|      * @return boolean success | ||||
|      */ | ||||
|     public function writeCachedContent(Smarty_Internal_Template $_template, $content) | ||||
|     { | ||||
|         if (Smarty_Internal_Write_File::writeFile($_template->cached->filepath, $content, $_template->smarty) === true) { | ||||
|             $_template->cached->timestamp = @filemtime($_template->cached->filepath); | ||||
|             $_template->cached->exists = !!$_template->cached->timestamp; | ||||
|             if ($_template->cached->exists) { | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache | ||||
|      * | ||||
|      * @param Smarty  $smarty | ||||
|      * @param integer $exp_time expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     public function clearAll(Smarty $smarty, $exp_time = null) | ||||
|     { | ||||
|         return $this->clear($smarty, null, null, null, $exp_time); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for a specific template | ||||
|      * | ||||
|      * @param Smarty  $smarty | ||||
|      * @param string  $resource_name template name | ||||
|      * @param string  $cache_id      cache id | ||||
|      * @param string  $compile_id    compile id | ||||
|      * @param integer $exp_time      expiration time (number of seconds, not timestamp) | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time) | ||||
|     { | ||||
|         $_cache_id = isset($cache_id) ? preg_replace('![^\w\|]+!', '_', $cache_id) : null; | ||||
|         $_compile_id = isset($compile_id) ? preg_replace('![^\w\|]+!', '_', $compile_id) : null; | ||||
|         $_dir_sep = $smarty->use_sub_dirs ? '/' : '^'; | ||||
|         $_compile_id_offset = $smarty->use_sub_dirs ? 3 : 0; | ||||
|         $_dir = realpath($smarty->getCacheDir()) . '/'; | ||||
|         $_dir_length = strlen($_dir); | ||||
|         if (isset($_cache_id)) { | ||||
|             $_cache_id_parts = explode('|', $_cache_id); | ||||
|             $_cache_id_parts_count = count($_cache_id_parts); | ||||
|             if ($smarty->use_sub_dirs) { | ||||
|                 foreach ($_cache_id_parts as $id_part) { | ||||
|                     $_dir .= $id_part . DS; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (isset($resource_name)) { | ||||
|             $_save_stat = $smarty->caching; | ||||
|             $smarty->caching = true; | ||||
|             $tpl = new $smarty->template_class($resource_name, $smarty); | ||||
|             $smarty->caching = $_save_stat; | ||||
|  | ||||
|             // remove from template cache | ||||
|             $tpl->source; // have the template registered before unset() | ||||
|             if ($smarty->allow_ambiguous_resources) { | ||||
|                 $_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id; | ||||
|             } else { | ||||
|                 $_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id; | ||||
|             } | ||||
|             if (isset($_templateId[150])) { | ||||
|                 $_templateId = sha1($_templateId); | ||||
|             } | ||||
|             unset($smarty->template_objects[$_templateId]); | ||||
|  | ||||
|             if ($tpl->source->exists) { | ||||
|                 $_resourcename_parts = basename(str_replace('^', '/', $tpl->cached->filepath)); | ||||
|             } else { | ||||
|                 return 0; | ||||
|             } | ||||
|         } | ||||
|         $_count = 0; | ||||
|         $_time = time(); | ||||
|         if (file_exists($_dir)) { | ||||
|             $_cacheDirs = new RecursiveDirectoryIterator($_dir); | ||||
|             $_cache = new RecursiveIteratorIterator($_cacheDirs, RecursiveIteratorIterator::CHILD_FIRST); | ||||
|             foreach ($_cache as $_file) { | ||||
|                 if (substr(basename($_file->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 // directory ? | ||||
|                 if ($_file->isDir()) { | ||||
|                     if (!$_cache->isDot()) { | ||||
|                         // delete folder if empty | ||||
|                         @rmdir($_file->getPathname()); | ||||
|                     } | ||||
|                 } else { | ||||
|                     $_parts = explode($_dir_sep, str_replace('\\', '/', substr((string) $_file, $_dir_length))); | ||||
|                     $_parts_count = count($_parts); | ||||
|                     // check name | ||||
|                     if (isset($resource_name)) { | ||||
|                         if ($_parts[$_parts_count - 1] != $_resourcename_parts) { | ||||
|                             continue; | ||||
|                         } | ||||
|                     } | ||||
|                     // check compile id | ||||
|                     if (isset($_compile_id) && (!isset($_parts[$_parts_count - 2 - $_compile_id_offset]) || $_parts[$_parts_count - 2 - $_compile_id_offset] != $_compile_id)) { | ||||
|                         continue; | ||||
|                     } | ||||
|                     // check cache id | ||||
|                     if (isset($_cache_id)) { | ||||
|                         // count of cache id parts | ||||
|                         $_parts_count = (isset($_compile_id)) ? $_parts_count - 2 - $_compile_id_offset : $_parts_count - 1 - $_compile_id_offset; | ||||
|                         if ($_parts_count < $_cache_id_parts_count) { | ||||
|                             continue; | ||||
|                         } | ||||
|                         for ($i = 0; $i < $_cache_id_parts_count; $i ++) { | ||||
|                             if ($_parts[$i] != $_cache_id_parts[$i]) { | ||||
|                                 continue 2; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     // expired ? | ||||
|                     if (isset($exp_time)) { | ||||
|                         if ($exp_time < 0) { | ||||
|                             preg_match('#\'cache_lifetime\' =>\s*(\d*)#', file_get_contents($_file), $match); | ||||
|                             if ($_time < (@filemtime($_file) + $match[1])) { | ||||
|                                 continue; | ||||
|                             } | ||||
|                         } else { | ||||
|                             if ($_time - @filemtime($_file) < $exp_time) { | ||||
|                                 continue; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     $_count += @unlink((string) $_file) ? 1 : 0; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_count; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check is cache is locked for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return boolean true or false if cache is locked | ||||
|      */ | ||||
|     public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         if (version_compare(PHP_VERSION, '5.3.0', '>=')) { | ||||
|             clearstatcache(true, $cached->lock_id); | ||||
|         } else { | ||||
|             clearstatcache(); | ||||
|         } | ||||
|         $t = @filemtime($cached->lock_id); | ||||
|  | ||||
|         return $t && (time() - $t < $smarty->locking_timeout); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Lock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = true; | ||||
|         touch($cached->lock_id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unlock cache for this template | ||||
|      * | ||||
|      * @param Smarty                 $smarty Smarty object | ||||
|      * @param Smarty_Template_Cached $cached cached object | ||||
|      * | ||||
|      * @return bool|void | ||||
|      */ | ||||
|     public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached) | ||||
|     { | ||||
|         $cached->is_locked = false; | ||||
|         @unlink($cached->lock_id); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,50 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Append | ||||
|  * Compiles the {append} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Append Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Append extends Smarty_Internal_Compile_Assign | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {append} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // the following must be assigned at runtime because it will be overwritten in parent class | ||||
|         $this->required_attributes = array('var', 'value'); | ||||
|         $this->shorttag_order = array('var', 'value'); | ||||
|         $this->optional_attributes = array('scope', 'index'); | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // map to compile assign attributes | ||||
|         if (isset($_attr['index'])) { | ||||
|             $_params['smarty_internal_index'] = '[' . $_attr['index'] . ']'; | ||||
|             unset($_attr['index']); | ||||
|         } else { | ||||
|             $_params['smarty_internal_index'] = '[]'; | ||||
|         } | ||||
|         $_new_attr = array(); | ||||
|         foreach ($_attr as $key => $value) { | ||||
|             $_new_attr[] = array($key => $value); | ||||
|         } | ||||
|         // call compile assign | ||||
|         return parent::compile($_new_attr, $compiler, $_params); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,86 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Assign | ||||
|  * Compiles the {assign} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Assign Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Assign extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {assign} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // the following must be assigned at runtime because it will be overwritten in Smarty_Internal_Compile_Append | ||||
|         $this->required_attributes = array('var', 'value'); | ||||
|         $this->shorttag_order = array('var', 'value'); | ||||
|         $this->optional_attributes = array('scope'); | ||||
|         $_nocache = 'null'; | ||||
|         $_scope = Smarty::SCOPE_LOCAL; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // nocache ? | ||||
|         if ($compiler->tag_nocache || $compiler->nocache) { | ||||
|             $_nocache = 'true'; | ||||
|             // create nocache var to make it know for further compiling | ||||
|             if (isset($compiler->template->tpl_vars[trim($_attr['var'], "'")])) { | ||||
|                 $compiler->template->tpl_vars[trim($_attr['var'], "'")]->nocache = true; | ||||
|             } else { | ||||
|                 $compiler->template->tpl_vars[trim($_attr['var'], "'")] = new Smarty_variable(null, true); | ||||
|             } | ||||
|         } | ||||
|         // scope setup | ||||
|         if (isset($_attr['scope'])) { | ||||
|             $_attr['scope'] = trim($_attr['scope'], "'\""); | ||||
|             if ($_attr['scope'] == 'parent') { | ||||
|                 $_scope = Smarty::SCOPE_PARENT; | ||||
|             } elseif ($_attr['scope'] == 'root') { | ||||
|                 $_scope = Smarty::SCOPE_ROOT; | ||||
|             } elseif ($_attr['scope'] == 'global') { | ||||
|                 $_scope = Smarty::SCOPE_GLOBAL; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error('illegal value for "scope" attribute', $compiler->lex->taglineno); | ||||
|             } | ||||
|         } | ||||
|         // compiled output | ||||
|         if (isset($parameter['smarty_internal_index'])) { | ||||
|             $output = "<?php \$_smarty_tpl->createLocalArrayVariable($_attr[var], $_nocache, $_scope);\n\$_smarty_tpl->tpl_vars[$_attr[var]]->value$parameter[smarty_internal_index] = $_attr[value];"; | ||||
|         } else { | ||||
|             // implement Smarty2's behaviour of variables assigned by reference | ||||
|             if ($compiler->template->smarty instanceof SmartyBC) { | ||||
|                 $output = "<?php if (isset(\$_smarty_tpl->tpl_vars[$_attr[var]])) {\$_smarty_tpl->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];"; | ||||
|                 $output .= "\n\$_smarty_tpl->tpl_vars[$_attr[var]]->value = $_attr[value]; \$_smarty_tpl->tpl_vars[$_attr[var]]->nocache = $_nocache; \$_smarty_tpl->tpl_vars[$_attr[var]]->scope = $_scope;"; | ||||
|                 $output .= "\n} else \$_smarty_tpl->tpl_vars[$_attr[var]] = new Smarty_variable($_attr[value], $_nocache, $_scope);"; | ||||
|             } else { | ||||
|                 $output = "<?php \$_smarty_tpl->tpl_vars[$_attr[var]] = new Smarty_variable($_attr[value], $_nocache, $_scope);"; | ||||
|             } | ||||
|         } | ||||
|         if ($_scope == Smarty::SCOPE_PARENT) { | ||||
|             $output .= "\nif (\$_smarty_tpl->parent != null) \$_smarty_tpl->parent->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];"; | ||||
|         } elseif ($_scope == Smarty::SCOPE_ROOT || $_scope == Smarty::SCOPE_GLOBAL) { | ||||
|             $output .= "\n\$_ptr = \$_smarty_tpl->parent; while (\$_ptr != null) {\$_ptr->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]]; \$_ptr = \$_ptr->parent; }"; | ||||
|         } | ||||
|         if ($_scope == Smarty::SCOPE_GLOBAL) { | ||||
|             $output .= "\nSmarty::\$global_tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];"; | ||||
|         } | ||||
|         $output .= '?>'; | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,438 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block | ||||
|  * Compiles the {block}{/block} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Block extends Smarty_Internal_CompileBase | ||||
| { | ||||
|  | ||||
|     const parent = '____SMARTY_BLOCK_PARENT____'; | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array('hide', 'append', 'prepend', 'nocache'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('internal_file', 'internal_uid', 'internal_line'); | ||||
|     /** | ||||
|      * nested child block names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $nested_block_names = array(); | ||||
|  | ||||
|     /** | ||||
|      * child block source buffer | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $block_data = array(); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {block} tag | ||||
|      * | ||||
|      * @param array  $args     array with attributes from parser | ||||
|      * @param object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $_name = trim($_attr['name'], "\"'"); | ||||
|  | ||||
|         // check if we process an inheritance child template | ||||
|         if ($compiler->inheritance_child) { | ||||
|             array_unshift(self::$nested_block_names, $_name); | ||||
|             // build {block} for child block | ||||
|             self::$block_data[$_name]['source'] = | ||||
|                 "{$compiler->smarty->left_delimiter}private_child_block name={$_attr['name']} file='{$compiler->template->source->filepath}' type='{$compiler->template->source->type}' resource='{$compiler->template->template_resource}'" . | ||||
|                 " uid='{$compiler->template->source->uid}' line={$compiler->lex->line}"; | ||||
|             if ($_attr['nocache']) { | ||||
|                 self::$block_data[$_name]['source'] .= ' nocache'; | ||||
|             } | ||||
|             self::$block_data[$_name]['source'] .= $compiler->smarty->right_delimiter; | ||||
|  | ||||
|             $save = array($_attr, $compiler->inheritance); | ||||
|             $this->openTag($compiler, 'block', $save); | ||||
|             // set flag for {block} tag | ||||
|             $compiler->inheritance = true; | ||||
|             $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK); | ||||
|             $compiler->has_code = false; | ||||
|             return; | ||||
|         } | ||||
|         // must merge includes | ||||
|         if ($_attr['nocache'] == true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $save = array($_attr, $compiler->inheritance, $compiler->parser->current_buffer, $compiler->nocache); | ||||
|         $this->openTag($compiler, 'block', $save); | ||||
|         $compiler->inheritance = true; | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|  | ||||
|         $compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser); | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile saved child block source | ||||
|      * | ||||
|      * @param object $compiler compiler object | ||||
|      * @param string $_name    optional name of child block | ||||
|      * | ||||
|      * @return string   compiled code of child block | ||||
|      */ | ||||
|     static function compileChildBlock($compiler, $_name = null) | ||||
|     { | ||||
|         if ($compiler->inheritance_child) { | ||||
|             $name1 = Smarty_Internal_Compile_Block::$nested_block_names[0]; | ||||
|             if (isset($compiler->template->block_data[$name1])) { | ||||
|                 //  replace inner block name with generic | ||||
|                 Smarty_Internal_Compile_Block::$block_data[$name1]['source'] .= $compiler->template->block_data[$name1]['source']; | ||||
|                 Smarty_Internal_Compile_Block::$block_data[$name1]['child'] = true; | ||||
|             } | ||||
|             $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK); | ||||
|             $compiler->has_code = false; | ||||
|             return; | ||||
|         } | ||||
|         // if called by {$smarty.block.child} we must search the name of enclosing {block} | ||||
|         if ($_name == null) { | ||||
|             $stack_count = count($compiler->_tag_stack); | ||||
|             while (--$stack_count >= 0) { | ||||
|                 if ($compiler->_tag_stack[$stack_count][0] == 'block') { | ||||
|                     $_name = trim($compiler->_tag_stack[$stack_count][1][0]['name'], "\"'"); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($_name == null) { | ||||
|             $compiler->trigger_template_error(' tag {$smarty.block.child} used outside {block} tags ', $compiler->lex->taglineno); | ||||
|         } | ||||
|         // undefined child? | ||||
|         if (!isset($compiler->template->block_data[$_name]['source'])) { | ||||
|             $compiler->popTrace(); | ||||
|             return ''; | ||||
|         } | ||||
|         // flag that child is already compile by {$smarty.block.child} inclusion | ||||
|         $compiler->template->block_data[$_name]['compiled'] = true; | ||||
|         $_tpl = new Smarty_Internal_template('string:' . $compiler->template->block_data[$_name]['source'], $compiler->smarty, $compiler->template, $compiler->template->cache_id, | ||||
|                                              $compiler->template->compile_id, $compiler->template->caching, $compiler->template->cache_lifetime); | ||||
|         if ($compiler->smarty->debugging) { | ||||
|             Smarty_Internal_Debug::ignore($_tpl); | ||||
|         } | ||||
|         $_tpl->tpl_vars = $compiler->template->tpl_vars; | ||||
|         $_tpl->variable_filters = $compiler->template->variable_filters; | ||||
|         $_tpl->properties['nocache_hash'] = $compiler->template->properties['nocache_hash']; | ||||
|         $_tpl->allow_relative_path = true; | ||||
|         $_tpl->compiler->inheritance = true; | ||||
|         $_tpl->compiler->suppressHeader = true; | ||||
|         $_tpl->compiler->suppressFilter = true; | ||||
|         $_tpl->compiler->suppressTemplatePropertyHeader = true; | ||||
|         $_tpl->compiler->suppressMergedTemplates = true; | ||||
|         $nocache = $compiler->nocache || $compiler->tag_nocache; | ||||
|         if (strpos($compiler->template->block_data[$_name]['source'], self::parent) !== false) { | ||||
|             $_output = str_replace(self::parent, $compiler->parser->current_buffer->to_smarty_php(), $_tpl->compiler->compileTemplate($_tpl, $nocache)); | ||||
|         } elseif ($compiler->template->block_data[$_name]['mode'] == 'prepend') { | ||||
|             $_output = $_tpl->compiler->compileTemplate($_tpl, $nocache) . $compiler->parser->current_buffer->to_smarty_php(); | ||||
|         } elseif ($compiler->template->block_data[$_name]['mode'] == 'append') { | ||||
|             $_output = $compiler->parser->current_buffer->to_smarty_php() . $_tpl->compiler->compileTemplate($_tpl, $nocache); | ||||
|         } elseif (!empty($compiler->template->block_data[$_name])) { | ||||
|             $_output = $_tpl->compiler->compileTemplate($_tpl, $nocache); | ||||
|         } | ||||
|         $compiler->template->properties['file_dependency'] = array_merge($compiler->template->properties['file_dependency'], $_tpl->properties['file_dependency']); | ||||
|         $compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $_tpl->properties['function']); | ||||
|         $compiler->merged_templates = array_merge($compiler->merged_templates, $_tpl->compiler->merged_templates); | ||||
|         $compiler->template->variable_filters = $_tpl->variable_filters; | ||||
|         if ($_tpl->has_nocache_code) { | ||||
|             $compiler->template->has_nocache_code = true; | ||||
|         } | ||||
|         foreach ($_tpl->required_plugins as $key => $tmp1) { | ||||
|             if ($compiler->nocache && $compiler->template->caching) { | ||||
|                 $code = 'nocache'; | ||||
|             } else { | ||||
|                 $code = $key; | ||||
|             } | ||||
|             foreach ($tmp1 as $name => $tmp) { | ||||
|                 foreach ($tmp as $type => $data) { | ||||
|                     $compiler->template->required_plugins[$code][$name][$type] = $data; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         unset($_tpl); | ||||
|         $compiler->has_code = true; | ||||
|         return $_output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile $smarty.block.parent | ||||
|      * | ||||
|      * @param object $compiler compiler object | ||||
|      * @param string $_name    optional name of child block | ||||
|      * | ||||
|      * @return string   compiled code of child block | ||||
|      */ | ||||
|     static function compileParentBlock($compiler, $_name = null) | ||||
|     { | ||||
|         // if called by {$smarty.block.parent} we must search the name of enclosing {block} | ||||
|         if ($_name == null) { | ||||
|             $stack_count = count($compiler->_tag_stack); | ||||
|             while (--$stack_count >= 0) { | ||||
|                 if ($compiler->_tag_stack[$stack_count][0] == 'block') { | ||||
|                     $_name = trim($compiler->_tag_stack[$stack_count][1][0]['name'], "\"'"); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($_name == null) { | ||||
|             $compiler->trigger_template_error(' tag {$smarty.block.parent} used outside {block} tags ', $compiler->lex->taglineno); | ||||
|         } | ||||
|         if (empty(Smarty_Internal_Compile_Block::$nested_block_names)) { | ||||
|             $compiler->trigger_template_error(' illegal {$smarty.block.parent} in parent template ', $compiler->lex->taglineno); | ||||
|         } | ||||
|         Smarty_Internal_Compile_Block::$block_data[Smarty_Internal_Compile_Block::$nested_block_names[0]]['source'] .= Smarty_Internal_Compile_Block::parent; | ||||
|         $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK); | ||||
|         $compiler->has_code = false; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Process block source | ||||
|      * | ||||
|      * @param        $compiler | ||||
|      * @param string $source source text | ||||
|      * | ||||
|      */ | ||||
|     static function blockSource($compiler, $source) | ||||
|     { | ||||
|         Smarty_Internal_Compile_Block::$block_data[Smarty_Internal_Compile_Block::$nested_block_names[0]]['source'] .= $source; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile BlockClose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Blockclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/block} tag | ||||
|      * | ||||
|      * @param array  $args     array with attributes from parser | ||||
|      * @param object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $compiler->has_code = true; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $saved_data = $this->closeTag($compiler, array('block')); | ||||
|         $_name = trim($saved_data[0]['name'], "\"'"); | ||||
|         // reset flag for {block} tag | ||||
|         $compiler->inheritance = $saved_data[1]; | ||||
|         // check if we process an inheritance child template | ||||
|         if ($compiler->inheritance_child) { | ||||
|             $name1 = Smarty_Internal_Compile_Block::$nested_block_names[0]; | ||||
|             Smarty_Internal_Compile_Block::$block_data[$name1]['source'] .= "{$compiler->smarty->left_delimiter}/private_child_block{$compiler->smarty->right_delimiter}"; | ||||
|             array_shift(Smarty_Internal_Compile_Block::$nested_block_names); | ||||
|             if (!empty(Smarty_Internal_Compile_Block::$nested_block_names)) { | ||||
|                 $name2 = Smarty_Internal_Compile_Block::$nested_block_names[0]; | ||||
|                 if (isset($compiler->template->block_data[$name1]) || !$saved_data[0]['hide']) { | ||||
|                     if (isset(Smarty_Internal_Compile_Block::$block_data[$name1]['child']) || !isset($compiler->template->block_data[$name1])) { | ||||
|                         Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source']; | ||||
|                     } else { | ||||
|                         if ($compiler->template->block_data[$name1]['mode'] == 'append') { | ||||
|                             Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source'] . $compiler->template->block_data[$name1]['source']; | ||||
|                         } elseif ($compiler->template->block_data[$name1]['mode'] == 'prepend') { | ||||
|                             Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= $compiler->template->block_data[$name1]['source'] . Smarty_Internal_Compile_Block::$block_data[$name1]['source']; | ||||
|                         } else { | ||||
|                             Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= $compiler->template->block_data[$name1]['source']; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 unset(Smarty_Internal_Compile_Block::$block_data[$name1]); | ||||
|                 $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK); | ||||
|             } else { | ||||
|                 if (isset($compiler->template->block_data[$name1]) || !$saved_data[0]['hide']) { | ||||
|                     if (isset($compiler->template->block_data[$name1]) && !isset(Smarty_Internal_Compile_Block::$block_data[$name1]['child'])) { | ||||
|                         if (strpos($compiler->template->block_data[$name1]['source'], Smarty_Internal_Compile_Block::parent) !== false) { | ||||
|                             $compiler->template->block_data[$name1]['source'] = | ||||
|                                 str_replace(Smarty_Internal_Compile_Block::parent, Smarty_Internal_Compile_Block::$block_data[$name1]['source'], $compiler->template->block_data[$name1]['source']); | ||||
|                         } elseif ($compiler->template->block_data[$name1]['mode'] == 'prepend') { | ||||
|                             $compiler->template->block_data[$name1]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source']; | ||||
|                         } elseif ($compiler->template->block_data[$name1]['mode'] == 'append') { | ||||
|                             $compiler->template->block_data[$name1]['source'] = Smarty_Internal_Compile_Block::$block_data[$name1]['source'] . $compiler->template->block_data[$name1]['source']; | ||||
|                         } | ||||
|                     } else { | ||||
|                         $compiler->template->block_data[$name1]['source'] = Smarty_Internal_Compile_Block::$block_data[$name1]['source']; | ||||
|                     } | ||||
|                     $compiler->template->block_data[$name1]['mode'] = 'replace'; | ||||
|                     if ($saved_data[0]['append']) { | ||||
|                         $compiler->template->block_data[$name1]['mode'] = 'append'; | ||||
|                     } | ||||
|                     if ($saved_data[0]['prepend']) { | ||||
|                         $compiler->template->block_data[$name1]['mode'] = 'prepend'; | ||||
|                     } | ||||
|                 } | ||||
|                 unset(Smarty_Internal_Compile_Block::$block_data[$name1]); | ||||
|                 $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY); | ||||
|             } | ||||
|             $compiler->has_code = false; | ||||
|             return; | ||||
|         } | ||||
|         if (isset($compiler->template->block_data[$_name]) && !isset($compiler->template->block_data[$_name]['compiled'])) { | ||||
|             $_output = Smarty_Internal_Compile_Block::compileChildBlock($compiler, $_name); | ||||
|         } else { | ||||
|             if ($saved_data[0]['hide'] && !isset($compiler->template->block_data[$_name]['source'])) { | ||||
|                 $_output = ''; | ||||
|             } else { | ||||
|                 $_output = $compiler->parser->current_buffer->to_smarty_php(); | ||||
|             } | ||||
|         } | ||||
|         unset($compiler->template->block_data[$_name]['compiled']); | ||||
|         // reset flags | ||||
|         $compiler->parser->current_buffer = $saved_data[2]; | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $compiler->nocache = $saved_data[3]; | ||||
|         // $_output content has already nocache code processed | ||||
|         $compiler->suppressNocacheProcessing = true; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Child Block Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Child_Block extends Smarty_Internal_CompileBase | ||||
| { | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name', 'file', 'uid', 'line', 'type', 'resource'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {private_child_block} tag | ||||
|      * | ||||
|      * @param array  $args     array with attributes from parser | ||||
|      * @param object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         // update template with original template resource of {block} | ||||
|         if (trim($_attr['type'], "'") == 'file') { | ||||
|             $compiler->template->template_resource = realpath(trim($_attr['file'], "'")); | ||||
|         } else { | ||||
|             $compiler->template->template_resource = trim($_attr['resource'], "'"); | ||||
|         } | ||||
|         // source object | ||||
|         unset ($compiler->template->source); | ||||
|         $exists = $compiler->template->source->exists; | ||||
|  | ||||
|         // must merge includes | ||||
|         if ($_attr['nocache'] == true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $save = array($_attr, $compiler->nocache); | ||||
|  | ||||
|         // set trace back to child block | ||||
|         $compiler->pushTrace(trim($_attr['file'], "\"'"), trim($_attr['uid'], "\"'"), $_attr['line'] - $compiler->lex->line); | ||||
|  | ||||
|         $this->openTag($compiler, 'private_child_block', $save); | ||||
|  | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Child Block Close Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Child_Blockclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {/private_child_block} tag | ||||
|      * | ||||
|      * @param array  $args     array with attributes from parser | ||||
|      * @param object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         $saved_data = $this->closeTag($compiler, array('private_child_block')); | ||||
|  | ||||
|         // end of child block | ||||
|         $compiler->popTrace(); | ||||
|  | ||||
|         $compiler->nocache = $saved_data[1]; | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,127 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function_Call | ||||
|  * Compiles the calls of user defined tags defined by {function} | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function_Call Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Call extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles the calls of user defined tags defined by {function} | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // save possible attributes | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             $_assign = $_attr['assign']; | ||||
|         } | ||||
|         $_name = $_attr['name']; | ||||
|         if ($compiler->compiles_template_function) { | ||||
|             $compiler->called_functions[] = trim($_name, "'\""); | ||||
|         } | ||||
|         unset($_attr['name'], $_attr['assign'], $_attr['nocache']); | ||||
|         // set flag (compiled code of {function} must be included in cache file | ||||
|         if ($compiler->nocache || $compiler->tag_nocache) { | ||||
|             $_nocache = 'true'; | ||||
|         } else { | ||||
|             $_nocache = 'false'; | ||||
|         } | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         if (isset($compiler->template->properties['function'][$_name]['parameter'])) { | ||||
|             foreach ($compiler->template->properties['function'][$_name]['parameter'] as $_key => $_value) { | ||||
|                 if (!isset($_attr[$_key])) { | ||||
|                     if (is_int($_key)) { | ||||
|                         $_paramsArray[] = "$_key=>$_value"; | ||||
|                     } else { | ||||
|                         $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } elseif (isset($compiler->smarty->template_functions[$_name]['parameter'])) { | ||||
|             foreach ($compiler->smarty->template_functions[$_name]['parameter'] as $_key => $_value) { | ||||
|                 if (!isset($_attr[$_key])) { | ||||
|                     if (is_int($_key)) { | ||||
|                         $_paramsArray[] = "$_key=>$_value"; | ||||
|                     } else { | ||||
|                         $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         //variable name? | ||||
|         if (!(strpos($_name, '$') === false)) { | ||||
|             $call_cache = $_name; | ||||
|             $call_function = '$tmp = "smarty_template_function_".' . $_name . '; $tmp'; | ||||
|         } else { | ||||
|             $_name = trim($_name, "'\""); | ||||
|             $call_cache = "'{$_name}'"; | ||||
|             $call_function = 'smarty_template_function_' . $_name; | ||||
|         } | ||||
|  | ||||
|         $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|         $_hash = str_replace('-', '_', $compiler->template->properties['nocache_hash']); | ||||
|         // was there an assign attribute | ||||
|         if (isset($_assign)) { | ||||
|             if ($compiler->template->caching) { | ||||
|                 $_output = "<?php ob_start(); Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n"; | ||||
|             } else { | ||||
|                 $_output = "<?php ob_start(); {$call_function}(\$_smarty_tpl,{$_params}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n"; | ||||
|             } | ||||
|         } else { | ||||
|             if ($compiler->template->caching) { | ||||
|                 $_output = "<?php Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache});?>\n"; | ||||
|             } else { | ||||
|                 $_output = "<?php {$call_function}(\$_smarty_tpl,{$_params});?>\n"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,96 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Capture | ||||
|  * Compiles the {capture} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Capture Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Capture extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('name', 'assign', 'append'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {capture} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         $buffer = isset($_attr['name']) ? $_attr['name'] : "'default'"; | ||||
|         $assign = isset($_attr['assign']) ? $_attr['assign'] : 'null'; | ||||
|         $append = isset($_attr['append']) ? $_attr['append'] : 'null'; | ||||
|  | ||||
|         $compiler->_capture_stack[0][] = array($buffer, $assign, $append, $compiler->nocache); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         $_output = "<?php \$_smarty_tpl->_capture_stack[0][] = array($buffer, $assign, $append); ob_start(); ?>"; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Captureclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_CaptureClose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/capture} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|  | ||||
|         list($buffer, $assign, $append, $compiler->nocache) = array_pop($compiler->_capture_stack[0]); | ||||
|  | ||||
|         $_output = "<?php list(\$_capture_buffer, \$_capture_assign, \$_capture_append) = array_pop(\$_smarty_tpl->_capture_stack[0]);\n"; | ||||
|         $_output .= "if (!empty(\$_capture_buffer)) {\n"; | ||||
|         $_output .= " if (isset(\$_capture_assign)) \$_smarty_tpl->assign(\$_capture_assign, ob_get_contents());\n"; | ||||
|         $_output .= " if (isset( \$_capture_append)) \$_smarty_tpl->append( \$_capture_append, ob_get_contents());\n"; | ||||
|         $_output .= " Smarty::\$_smarty_vars['capture'][\$_capture_buffer]=ob_get_clean();\n"; | ||||
|         $_output .= "} else \$_smarty_tpl->capture_error();?>"; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,82 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Config Load | ||||
|  * Compiles the {config load} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Config Load Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Config_Load extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('file', 'section'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('section', 'scope'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {config_load} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         static $_is_legal_scope = array('local' => true, 'parent' => true, 'root' => true, 'global' => true); | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         // save possible attributes | ||||
|         $conf_file = $_attr['file']; | ||||
|         if (isset($_attr['section'])) { | ||||
|             $section = $_attr['section']; | ||||
|         } else { | ||||
|             $section = 'null'; | ||||
|         } | ||||
|         $scope = 'local'; | ||||
|         // scope setup | ||||
|         if (isset($_attr['scope'])) { | ||||
|             $_attr['scope'] = trim($_attr['scope'], "'\""); | ||||
|             if (isset($_is_legal_scope[$_attr['scope']])) { | ||||
|                 $scope = $_attr['scope']; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error('illegal value for "scope" attribute', $compiler->lex->taglineno); | ||||
|             } | ||||
|         } | ||||
|         // create config object | ||||
|         $_output = "<?php  \$_config = new Smarty_Internal_Config($conf_file, \$_smarty_tpl->smarty, \$_smarty_tpl);"; | ||||
|         $_output .= "\$_config->loadConfigVars($section, '$scope'); ?>"; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,75 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Continue | ||||
|  * Compiles the {continue} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Continue Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Continue extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('levels'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('levels'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {continue} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         static $_is_loopy = array('for' => true, 'foreach' => true, 'while' => true, 'section' => true); | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         if (isset($_attr['levels'])) { | ||||
|             if (!is_numeric($_attr['levels'])) { | ||||
|                 $compiler->trigger_template_error('level attribute must be a numeric constant', $compiler->lex->taglineno); | ||||
|             } | ||||
|             $_levels = $_attr['levels']; | ||||
|         } else { | ||||
|             $_levels = 1; | ||||
|         } | ||||
|         $level_count = $_levels; | ||||
|         $stack_count = count($compiler->_tag_stack) - 1; | ||||
|         while ($level_count > 0 && $stack_count >= 0) { | ||||
|             if (isset($_is_loopy[$compiler->_tag_stack[$stack_count][0]])) { | ||||
|                 $level_count --; | ||||
|             } | ||||
|             $stack_count --; | ||||
|         } | ||||
|         if ($level_count != 0) { | ||||
|             $compiler->trigger_template_error("cannot continue {$_levels} level(s)", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         return "<?php continue {$_levels}?>"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Debug | ||||
|  * Compiles the {debug} tag. | ||||
|  * It opens a window the the Smarty Debugging Console. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Debug Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Debug extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {debug} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         // compile always as nocache | ||||
|         $compiler->tag_nocache = true; | ||||
|  | ||||
|         // display debug template | ||||
|         $_output = "<?php \$_smarty_tpl->smarty->loadPlugin('Smarty_Internal_Debug'); Smarty_Internal_Debug::display_debug(\$_smarty_tpl); ?>"; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,71 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Eval | ||||
|  * Compiles the {eval} tag. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Eval Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Eval extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('var'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('assign'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('var', 'assign'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {eval} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $this->required_attributes = array('var'); | ||||
|         $this->optional_attributes = array('assign'); | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             $_assign = $_attr['assign']; | ||||
|         } | ||||
|  | ||||
|         // create template object | ||||
|         $_output = "\$_template = new {$compiler->smarty->template_class}('eval:'." . $_attr['var'] . ", \$_smarty_tpl->smarty, \$_smarty_tpl);"; | ||||
|         //was there an assign attribute? | ||||
|         if (isset($_assign)) { | ||||
|             $_output .= "\$_smarty_tpl->assign($_assign,\$_template->fetch());"; | ||||
|         } else { | ||||
|             $_output .= "echo \$_template->fetch();"; | ||||
|         } | ||||
|  | ||||
|         return "<?php $_output ?>"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,85 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile extend | ||||
|  * Compiles the {extends} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile extend Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Extends extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('file'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {extends} tag | ||||
|      * | ||||
|      * @param array  $args     array with attributes from parser | ||||
|      * @param object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|         if (strpos($_attr['file'], '$_tmp') !== false) { | ||||
|             $compiler->trigger_template_error('illegal value for file attribute', $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         $name = $_attr['file']; | ||||
|         /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|          * used in evaluated code | ||||
|          */ | ||||
|         $_smarty_tpl = $compiler->template; | ||||
|         eval("\$tpl_name = $name;"); | ||||
|         // create template object | ||||
|         $_template = new $compiler->smarty->template_class($tpl_name, $compiler->smarty, $compiler->template); | ||||
|         // check for recursion | ||||
|         $uid = $_template->source->uid; | ||||
|         if (isset($compiler->extends_uid[$uid])) { | ||||
|             $compiler->trigger_template_error("illegal recursive call of \"$include_file\"", $compiler->lex->line - 1); | ||||
|         } | ||||
|         $compiler->extends_uid[$uid] = true; | ||||
|         if (empty($_template->source->components)) { | ||||
|             array_unshift($compiler->sources, $_template->source); | ||||
|         } else { | ||||
|             foreach ($_template->source->components as $source) { | ||||
|                 array_unshift($compiler->sources, $source); | ||||
|                 $uid = $source->uid; | ||||
|                 if (isset($compiler->extends_uid[$uid])) { | ||||
|                     $compiler->trigger_template_error("illegal recursive call of \"{$source->filepath}\"", $compiler->lex->line - 1); | ||||
|                 } | ||||
|                 $compiler->extends_uid[$uid] = true; | ||||
|             } | ||||
|         } | ||||
|         unset ($_template); | ||||
|         $compiler->inheritance_child = true; | ||||
|         $compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY); | ||||
|         return ''; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										145
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										145
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,145 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile For | ||||
|  * Compiles the {for} {forelse} {/for} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile For Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_For extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {for} tag | ||||
|      * Smarty 3 does implement two different syntax's: | ||||
|      * - {for $var in $array} | ||||
|      * For looping over arrays or iterators | ||||
|      * - {for $x=0; $x<$y; $x++} | ||||
|      * For general loops | ||||
|      * The parser is generating different sets of attribute by which this compiler can | ||||
|      * determine which syntax is used. | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         if ($parameter == 0) { | ||||
|             $this->required_attributes = array('start', 'to'); | ||||
|             $this->optional_attributes = array('max', 'step'); | ||||
|         } else { | ||||
|             $this->required_attributes = array('start', 'ifexp', 'var', 'step'); | ||||
|             $this->optional_attributes = array(); | ||||
|         } | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         $output = "<?php "; | ||||
|         if ($parameter == 1) { | ||||
|             foreach ($_attr['start'] as $_statement) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars[$_statement[var]] = new Smarty_Variable;"; | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars[$_statement[var]]->value = $_statement[value];\n"; | ||||
|             } | ||||
|             $output .= "  if ($_attr[ifexp]) { for (\$_foo=true;$_attr[ifexp]; \$_smarty_tpl->tpl_vars[$_attr[var]]->value$_attr[step]) {\n"; | ||||
|         } else { | ||||
|             $_statement = $_attr['start']; | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]] = new Smarty_Variable;"; | ||||
|             if (isset($_attr['step'])) { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->step = $_attr[step];"; | ||||
|             } else { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->step = 1;"; | ||||
|             } | ||||
|             if (isset($_attr['max'])) { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->total = (int) min(ceil((\$_smarty_tpl->tpl_vars[$_statement[var]]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$_statement[var]]->step)),$_attr[max]);\n"; | ||||
|             } else { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->total = (int) ceil((\$_smarty_tpl->tpl_vars[$_statement[var]]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$_statement[var]]->step));\n"; | ||||
|             } | ||||
|             $output .= "if (\$_smarty_tpl->tpl_vars[$_statement[var]]->total > 0) {\n"; | ||||
|             $output .= "for (\$_smarty_tpl->tpl_vars[$_statement[var]]->value = $_statement[value], \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration = 1;\$_smarty_tpl->tpl_vars[$_statement[var]]->iteration <= \$_smarty_tpl->tpl_vars[$_statement[var]]->total;\$_smarty_tpl->tpl_vars[$_statement[var]]->value += \$_smarty_tpl->tpl_vars[$_statement[var]]->step, \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration++) {\n"; | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->first = \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration == 1;"; | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->last = \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration == \$_smarty_tpl->tpl_vars[$_statement[var]]->total;"; | ||||
|         } | ||||
|         $output .= "?>"; | ||||
|  | ||||
|         $this->openTag($compiler, 'for', array('for', $compiler->nocache)); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         // return compiled code | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Forelse Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Forelse extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {forelse} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         list($openTag, $nocache) = $this->closeTag($compiler, array('for')); | ||||
|         $this->openTag($compiler, 'forelse', array('forelse', $nocache)); | ||||
|  | ||||
|         return "<?php }} else { ?>"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Forclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Forclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/for} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|  | ||||
|         list($openTag, $compiler->nocache) = $this->closeTag($compiler, array('for', 'forelse')); | ||||
|  | ||||
|         if ($openTag == 'forelse') { | ||||
|             return "<?php }  ?>"; | ||||
|         } else { | ||||
|             return "<?php }} ?>"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,229 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Foreach | ||||
|  * Compiles the {foreach} {foreachelse} {/foreach} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Foreach Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Foreach extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('from', 'item'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('name', 'key'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('from', 'item', 'key', 'name'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {foreach} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         $from = $_attr['from']; | ||||
|         $item = $_attr['item']; | ||||
|         if (!strncmp("\$_smarty_tpl->tpl_vars[$item]", $from, strlen($item) + 24)) { | ||||
|             $compiler->trigger_template_error("item variable {$item} may not be the same variable as at 'from'", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         if (isset($_attr['key'])) { | ||||
|             $key = $_attr['key']; | ||||
|         } else { | ||||
|             $key = null; | ||||
|         } | ||||
|  | ||||
|         $this->openTag($compiler, 'foreach', array('foreach', $compiler->nocache, $item, $key)); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|  | ||||
|         if (isset($_attr['name'])) { | ||||
|             $name = $_attr['name']; | ||||
|             $has_name = true; | ||||
|             $SmartyVarName = '$smarty.foreach.' . trim($name, '\'"') . '.'; | ||||
|         } else { | ||||
|             $name = null; | ||||
|             $has_name = false; | ||||
|         } | ||||
|         $ItemVarName = '$' . trim($item, '\'"') . '@'; | ||||
|         // evaluates which Smarty variables and properties have to be computed | ||||
|         if ($has_name) { | ||||
|             $usesSmartyFirst = strpos($compiler->lex->data, $SmartyVarName . 'first') !== false; | ||||
|             $usesSmartyLast = strpos($compiler->lex->data, $SmartyVarName . 'last') !== false; | ||||
|             $usesSmartyIndex = strpos($compiler->lex->data, $SmartyVarName . 'index') !== false; | ||||
|             $usesSmartyIteration = strpos($compiler->lex->data, $SmartyVarName . 'iteration') !== false; | ||||
|             $usesSmartyShow = strpos($compiler->lex->data, $SmartyVarName . 'show') !== false; | ||||
|             $usesSmartyTotal = strpos($compiler->lex->data, $SmartyVarName . 'total') !== false; | ||||
|         } else { | ||||
|             $usesSmartyFirst = false; | ||||
|             $usesSmartyLast = false; | ||||
|             $usesSmartyTotal = false; | ||||
|             $usesSmartyShow = false; | ||||
|         } | ||||
|  | ||||
|         $usesPropFirst = $usesSmartyFirst || strpos($compiler->lex->data, $ItemVarName . 'first') !== false; | ||||
|         $usesPropLast = $usesSmartyLast || strpos($compiler->lex->data, $ItemVarName . 'last') !== false; | ||||
|         $usesPropIndex = $usesPropFirst || strpos($compiler->lex->data, $ItemVarName . 'index') !== false; | ||||
|         $usesPropIteration = $usesPropLast || strpos($compiler->lex->data, $ItemVarName . 'iteration') !== false; | ||||
|         $usesPropShow = strpos($compiler->lex->data, $ItemVarName . 'show') !== false; | ||||
|         $usesPropTotal = $usesSmartyTotal || $usesSmartyShow || $usesPropShow || $usesPropLast || strpos($compiler->lex->data, $ItemVarName . 'total') !== false; | ||||
|         // generate output code | ||||
|         $output = "<?php "; | ||||
|         $output .= " \$_smarty_tpl->tpl_vars[$item] = new Smarty_Variable; \$_smarty_tpl->tpl_vars[$item]->_loop = false;\n"; | ||||
|         if ($key != null) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$key] = new Smarty_Variable;\n"; | ||||
|         } | ||||
|         $output .= " \$_from = $from; if (!is_array(\$_from) && !is_object(\$_from)) { settype(\$_from, 'array');}\n"; | ||||
|         if ($usesPropTotal) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->total= \$_smarty_tpl->_count(\$_from);\n"; | ||||
|         } | ||||
|         if ($usesPropIteration) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->iteration=0;\n"; | ||||
|         } | ||||
|         if ($usesPropIndex) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->index=-1;\n"; | ||||
|         } | ||||
|         if ($usesPropShow) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->show = (\$_smarty_tpl->tpl_vars[$item]->total > 0);\n"; | ||||
|         } | ||||
|         if ($has_name) { | ||||
|             if ($usesSmartyTotal) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['total'] = \$_smarty_tpl->tpl_vars[$item]->total;\n"; | ||||
|             } | ||||
|             if ($usesSmartyIteration) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']=0;\n"; | ||||
|             } | ||||
|             if ($usesSmartyIndex) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']=-1;\n"; | ||||
|             } | ||||
|             if ($usesSmartyShow) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['show']=(\$_smarty_tpl->tpl_vars[$item]->total > 0);\n"; | ||||
|             } | ||||
|         } | ||||
|         $output .= "foreach (\$_from as \$_smarty_tpl->tpl_vars[$item]->key => \$_smarty_tpl->tpl_vars[$item]->value) {\n\$_smarty_tpl->tpl_vars[$item]->_loop = true;\n"; | ||||
|         if ($key != null) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$key]->value = \$_smarty_tpl->tpl_vars[$item]->key;\n"; | ||||
|         } | ||||
|         if ($usesPropIteration) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->iteration++;\n"; | ||||
|         } | ||||
|         if ($usesPropIndex) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->index++;\n"; | ||||
|         } | ||||
|         if ($usesPropFirst) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->first = \$_smarty_tpl->tpl_vars[$item]->index === 0;\n"; | ||||
|         } | ||||
|         if ($usesPropLast) { | ||||
|             $output .= " \$_smarty_tpl->tpl_vars[$item]->last = \$_smarty_tpl->tpl_vars[$item]->iteration === \$_smarty_tpl->tpl_vars[$item]->total;\n"; | ||||
|         } | ||||
|         if ($has_name) { | ||||
|             if ($usesSmartyFirst) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['first'] = \$_smarty_tpl->tpl_vars[$item]->first;\n"; | ||||
|             } | ||||
|             if ($usesSmartyIteration) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']++;\n"; | ||||
|             } | ||||
|             if ($usesSmartyIndex) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']++;\n"; | ||||
|             } | ||||
|             if ($usesSmartyLast) { | ||||
|                 $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['last'] = \$_smarty_tpl->tpl_vars[$item]->last;\n"; | ||||
|             } | ||||
|         } | ||||
|         $output .= "?>"; | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Foreachelse Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Foreachelse extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {foreachelse} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         list($openTag, $nocache, $item, $key) = $this->closeTag($compiler, array('foreach')); | ||||
|         $this->openTag($compiler, 'foreachelse', array('foreachelse', $nocache, $item, $key)); | ||||
|  | ||||
|         return "<?php }\nif (!\$_smarty_tpl->tpl_vars[$item]->_loop) {\n?>"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Foreachclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Foreachclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/foreach} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|  | ||||
|         list($openTag, $compiler->nocache, $item, $key) = $this->closeTag($compiler, array('foreach', 'foreachelse')); | ||||
|  | ||||
|         return "<?php } ?>"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,167 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function | ||||
|  * Compiles the {function} {/function} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Function extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {function} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|         unset($_attr['nocache']); | ||||
|         $save = array($_attr, $compiler->parser->current_buffer, | ||||
|                       $compiler->template->has_nocache_code, $compiler->template->required_plugins); | ||||
|         $this->openTag($compiler, 'function', $save); | ||||
|         $_name = trim($_attr['name'], "'\""); | ||||
|         unset($_attr['name']); | ||||
|         // set flag that we are compiling a template function | ||||
|         $compiler->compiles_template_function = true; | ||||
|         $compiler->template->properties['function'][$_name]['parameter'] = array(); | ||||
|         /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|          * used in evaluated code | ||||
|          */ | ||||
|         $_smarty_tpl = $compiler->template; | ||||
|         foreach ($_attr as $_key => $_data) { | ||||
|             eval ('$tmp=' . $_data . ';'); | ||||
|             $compiler->template->properties['function'][$_name]['parameter'][$_key] = $tmp; | ||||
|         } | ||||
|         $compiler->smarty->template_functions[$_name]['parameter'] = $compiler->template->properties['function'][$_name]['parameter']; | ||||
|         if ($compiler->template->caching) { | ||||
|             $output = ''; | ||||
|         } else { | ||||
|             $output = "<?php if (!function_exists('smarty_template_function_{$_name}')) { | ||||
|     function smarty_template_function_{$_name}(\$_smarty_tpl,\$params) { | ||||
|     \$saved_tpl_vars = \$_smarty_tpl->tpl_vars; | ||||
|     foreach (\$_smarty_tpl->smarty->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}; | ||||
|     foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>"; | ||||
|         } | ||||
|         // Init temporary context | ||||
|         $compiler->template->required_plugins = array('compiled' => array(), 'nocache' => array()); | ||||
|         $compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser); | ||||
|         $compiler->parser->current_buffer->append_subtree(new _smarty_tag($compiler->parser, $output)); | ||||
|         $compiler->template->has_nocache_code = false; | ||||
|         $compiler->has_code = false; | ||||
|         $compiler->template->properties['function'][$_name]['compiled'] = ''; | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Functionclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Functionclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/function} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $saved_data = $this->closeTag($compiler, array('function')); | ||||
|         $_name = trim($saved_data[0]['name'], "'\""); | ||||
|         // build plugin include code | ||||
|         $plugins_string = ''; | ||||
|         if (!empty($compiler->template->required_plugins['compiled'])) { | ||||
|             $plugins_string = '<?php '; | ||||
|             foreach ($compiler->template->required_plugins['compiled'] as $tmp) { | ||||
|                 foreach ($tmp as $data) { | ||||
|                     $plugins_string .= "if (!is_callable('{$data['function']}')) include '{$data['file']}';\n"; | ||||
|                 } | ||||
|             } | ||||
|             $plugins_string .= '?>'; | ||||
|         } | ||||
|         if (!empty($compiler->template->required_plugins['nocache'])) { | ||||
|             $plugins_string .= "<?php echo '/*%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/<?php "; | ||||
|             foreach ($compiler->template->required_plugins['nocache'] as $tmp) { | ||||
|                 foreach ($tmp as $data) { | ||||
|                     $plugins_string .= "if (!is_callable(\'{$data['function']}\')) include \'{$data['file']}\';\n"; | ||||
|                 } | ||||
|             } | ||||
|             $plugins_string .= "?>/*/%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/';?>\n"; | ||||
|         } | ||||
|         // remove last line break from function definition | ||||
|         $last = count($compiler->parser->current_buffer->subtrees) - 1; | ||||
|         if ($compiler->parser->current_buffer->subtrees[$last] instanceof _smarty_linebreak) { | ||||
|             unset($compiler->parser->current_buffer->subtrees[$last]); | ||||
|         } | ||||
|         // if caching save template function for possible nocache call | ||||
|         if ($compiler->template->caching) { | ||||
|             $compiler->template->properties['function'][$_name]['compiled'] .= $plugins_string | ||||
|                 . $compiler->parser->current_buffer->to_smarty_php(); | ||||
|             $compiler->template->properties['function'][$_name]['nocache_hash'] = $compiler->template->properties['nocache_hash']; | ||||
|             $compiler->template->properties['function'][$_name]['has_nocache_code'] = $compiler->template->has_nocache_code; | ||||
|             $compiler->template->properties['function'][$_name]['called_functions'] = $compiler->called_functions; | ||||
|             $compiler->called_functions = array(); | ||||
|             $compiler->smarty->template_functions[$_name] = $compiler->template->properties['function'][$_name]; | ||||
|             $compiler->has_code = false; | ||||
|             $output = true; | ||||
|         } else { | ||||
|             $output = $plugins_string . $compiler->parser->current_buffer->to_smarty_php() . "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars; | ||||
| foreach (Smarty::\$global_tpl_vars as \$key => \$value) if(!isset(\$_smarty_tpl->tpl_vars[\$key])) \$_smarty_tpl->tpl_vars[\$key] = \$value;}}?>\n"; | ||||
|         } | ||||
|         // reset flag that we are compiling a template function | ||||
|         $compiler->compiles_template_function = false; | ||||
|         // restore old compiler status | ||||
|         $compiler->parser->current_buffer = $saved_data[1]; | ||||
|         $compiler->template->has_nocache_code = $compiler->template->has_nocache_code | $saved_data[2]; | ||||
|         $compiler->template->required_plugins = $saved_data[3]; | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										210
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,210 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile If | ||||
|  * Compiles the {if} {else} {elseif} {/if} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile If Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_If extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {if} tag | ||||
|      * | ||||
|      * @param array  $args      array with attributes from parser | ||||
|      * @param object $compiler  compiler object | ||||
|      * @param array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $this->openTag($compiler, 'if', array(1, $compiler->nocache)); | ||||
|         // must whole block be nocache ? | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|  | ||||
|         if (!array_key_exists("if condition", $parameter)) { | ||||
|             $compiler->trigger_template_error("missing if condition", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         if (is_array($parameter['if condition'])) { | ||||
|             if ($compiler->nocache) { | ||||
|                 $_nocache = ',true'; | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 if (is_array($parameter['if condition']['var'])) { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } else { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } | ||||
|             } else { | ||||
|                 $_nocache = ''; | ||||
|             } | ||||
|             if (is_array($parameter['if condition']['var'])) { | ||||
|                 $_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n"; | ||||
|                 $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|             } else { | ||||
|                 $_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});"; | ||||
|                 $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|             } | ||||
|  | ||||
|             return $_output; | ||||
|         } else { | ||||
|             return "<?php if ({$parameter['if condition']}) {?>"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Else Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Else extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {else} tag | ||||
|      * | ||||
|      * @param array  $args      array with attributes from parser | ||||
|      * @param object $compiler  compiler object | ||||
|      * @param array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         list($nesting, $compiler->tag_nocache) = $this->closeTag($compiler, array('if', 'elseif')); | ||||
|         $this->openTag($compiler, 'else', array($nesting, $compiler->tag_nocache)); | ||||
|  | ||||
|         return "<?php } else { ?>"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile ElseIf Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Elseif extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {elseif} tag | ||||
|      * | ||||
|      * @param array  $args      array with attributes from parser | ||||
|      * @param object $compiler  compiler object | ||||
|      * @param array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         list($nesting, $compiler->tag_nocache) = $this->closeTag($compiler, array('if', 'elseif')); | ||||
|  | ||||
|         if (!array_key_exists("if condition", $parameter)) { | ||||
|             $compiler->trigger_template_error("missing elseif condition", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         if (is_array($parameter['if condition'])) { | ||||
|             $condition_by_assign = true; | ||||
|             if ($compiler->nocache) { | ||||
|                 $_nocache = ',true'; | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 if (is_array($parameter['if condition']['var'])) { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } else { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } | ||||
|             } else { | ||||
|                 $_nocache = ''; | ||||
|             } | ||||
|         } else { | ||||
|             $condition_by_assign = false; | ||||
|         } | ||||
|  | ||||
|         if (empty($compiler->prefix_code)) { | ||||
|             if ($condition_by_assign) { | ||||
|                 $this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache)); | ||||
|                 if (is_array($parameter['if condition']['var'])) { | ||||
|                     $_output = "<?php } else { if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n"; | ||||
|                     $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|                 } else { | ||||
|                     $_output = "<?php  } else { if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});"; | ||||
|                     $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|                 } | ||||
|  | ||||
|                 return $_output; | ||||
|             } else { | ||||
|                 $this->openTag($compiler, 'elseif', array($nesting, $compiler->tag_nocache)); | ||||
|  | ||||
|                 return "<?php } elseif ({$parameter['if condition']}) {?>"; | ||||
|             } | ||||
|         } else { | ||||
|             $tmp = ''; | ||||
|             foreach ($compiler->prefix_code as $code) { | ||||
|                 $tmp .= $code; | ||||
|             } | ||||
|             $compiler->prefix_code = array(); | ||||
|             $this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache)); | ||||
|             if ($condition_by_assign) { | ||||
|                 if (is_array($parameter['if condition']['var'])) { | ||||
|                     $_output = "<?php } else {?>{$tmp}<?php  if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n"; | ||||
|                     $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|                 } else { | ||||
|                     $_output = "<?php } else {?>{$tmp}<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});"; | ||||
|                     $_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|                 } | ||||
|  | ||||
|                 return $_output; | ||||
|             } else { | ||||
|                 return "<?php } else {?>{$tmp}<?php if ({$parameter['if condition']}) {?>"; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Ifclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Ifclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/if} tag | ||||
|      * | ||||
|      * @param array  $args      array with attributes from parser | ||||
|      * @param object $compiler  compiler object | ||||
|      * @param array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         list($nesting, $compiler->nocache) = $this->closeTag($compiler, array('if', 'else', 'elseif')); | ||||
|         $tmp = ''; | ||||
|         for ($i = 0; $i < $nesting; $i ++) { | ||||
|             $tmp .= '}'; | ||||
|         } | ||||
|  | ||||
|         return "<?php {$tmp}?>"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,265 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Include | ||||
|  * Compiles the {include} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Include Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Include extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * caching mode to create nocache code but no cache file | ||||
|      */ | ||||
|     const CACHING_NOCACHE_CODE = 9999; | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array('nocache', 'inline', 'caching'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {include} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // save possible attributes | ||||
|         $include_file = $_attr['file']; | ||||
|  | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             $_assign = $_attr['assign']; | ||||
|         } | ||||
|  | ||||
|         $_parent_scope = Smarty::SCOPE_LOCAL; | ||||
|         if (isset($_attr['scope'])) { | ||||
|             $_attr['scope'] = trim($_attr['scope'], "'\""); | ||||
|             if ($_attr['scope'] == 'parent') { | ||||
|                 $_parent_scope = Smarty::SCOPE_PARENT; | ||||
|             } elseif ($_attr['scope'] == 'root') { | ||||
|                 $_parent_scope = Smarty::SCOPE_ROOT; | ||||
|             } elseif ($_attr['scope'] == 'global') { | ||||
|                 $_parent_scope = Smarty::SCOPE_GLOBAL; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $_caching = Smarty::CACHING_OFF; | ||||
|  | ||||
|         // flag if included template code should be merged into caller | ||||
|         $merge_compiled_includes = ($compiler->smarty->merge_compiled_includes || ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) || $_attr['inline'] === true) && !$compiler->template->source->recompiled; | ||||
|  | ||||
|         // set default when in nocache mode | ||||
|         //       if ($compiler->template->caching && ($compiler->nocache || $compiler->tag_nocache || $compiler->forceNocache == 2)) { | ||||
|         if ($compiler->template->caching && ((!$compiler->inheritance && !$compiler->nocache && !$compiler->tag_nocache) || ($compiler->inheritance && ($compiler->nocache || $compiler->tag_nocache)))) { | ||||
|             $_caching = self::CACHING_NOCACHE_CODE; | ||||
|         } | ||||
|         /* | ||||
|         * if the {include} tag provides individual parameter for caching | ||||
|         * it will not be included into the common cache file and treated like | ||||
|         * a nocache section | ||||
|         */ | ||||
|         if (isset($_attr['cache_lifetime'])) { | ||||
|             $_cache_lifetime = $_attr['cache_lifetime']; | ||||
|             $compiler->tag_nocache = true; | ||||
|             $_caching = Smarty::CACHING_LIFETIME_CURRENT; | ||||
|         } else { | ||||
|             $_cache_lifetime = 'null'; | ||||
|         } | ||||
|         if (isset($_attr['cache_id'])) { | ||||
|             $_cache_id = $_attr['cache_id']; | ||||
|             $compiler->tag_nocache = true; | ||||
|             $_caching = Smarty::CACHING_LIFETIME_CURRENT; | ||||
|         } else { | ||||
|             $_cache_id = '$_smarty_tpl->cache_id'; | ||||
|         } | ||||
|         if (isset($_attr['compile_id'])) { | ||||
|             $_compile_id = $_attr['compile_id']; | ||||
|         } else { | ||||
|             $_compile_id = '$_smarty_tpl->compile_id'; | ||||
|         } | ||||
|         if ($_attr['caching'] === true) { | ||||
|             $_caching = Smarty::CACHING_LIFETIME_CURRENT; | ||||
|         } | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|             if ($merge_compiled_includes) { | ||||
|                 $_caching = self::CACHING_NOCACHE_CODE; | ||||
|             } else { | ||||
|                 $_caching = Smarty::CACHING_OFF; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $has_compiled_template = false; | ||||
|         if ($merge_compiled_includes && $_attr['inline'] !== true) { | ||||
|             // variable template name ? | ||||
|             if ($compiler->has_variable_string || !((substr_count($include_file, '"') == 2 || substr_count($include_file, "'") == 2)) | ||||
|                 || substr_count($include_file, '(') != 0 || substr_count($include_file, '$_smarty_tpl->') != 0 | ||||
|             ) { | ||||
|                 $merge_compiled_includes = false; | ||||
|                 if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) { | ||||
|                     $compiler->trigger_template_error(' variable template file names not allow within {block} tags'); | ||||
|                 } | ||||
|             } | ||||
|             // variable compile_id? | ||||
|             if (isset($_attr['compile_id'])) { | ||||
|                 if (!((substr_count($_attr['compile_id'], '"') == 2 || substr_count($_attr['compile_id'], "'") == 2)) | ||||
|                     || substr_count($_attr['compile_id'], '(') != 0 || substr_count($_attr['compile_id'], '$_smarty_tpl->') != 0 | ||||
|                 ) { | ||||
|                     $merge_compiled_includes = false; | ||||
|                     if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) { | ||||
|                         $compiler->trigger_template_error(' variable compile_id not allow within {block} tags'); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($merge_compiled_includes) { | ||||
|             if ($compiler->template->caching && ($compiler->tag_nocache || $compiler->nocache) && $_caching != self::CACHING_NOCACHE_CODE) { | ||||
|                 $merge_compiled_includes = false; | ||||
|                 if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) { | ||||
|                     $compiler->trigger_template_error(' invalid caching mode of subtemplate within {block} tags'); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($merge_compiled_includes) { | ||||
|             // we must observe different compile_id | ||||
|             $uid = sha1($_compile_id); | ||||
|             $tpl_name = null; | ||||
|             $nocache = false; | ||||
|             /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|              * used in evaluated code | ||||
|              */ | ||||
|             $_smarty_tpl = $compiler->template; | ||||
|             eval("\$tpl_name = $include_file;"); | ||||
|             if (!isset($compiler->smarty->merged_templates_func[$tpl_name][$uid])) { | ||||
|                 $tpl = new $compiler->smarty->template_class ($tpl_name, $compiler->smarty, $compiler->template, $compiler->template->cache_id, $compiler->template->compile_id); | ||||
|                 // save unique function name | ||||
|                 $compiler->smarty->merged_templates_func[$tpl_name][$uid]['func'] = $tpl->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true)); | ||||
|                 // use current nocache hash for inlined code | ||||
|                 $compiler->smarty->merged_templates_func[$tpl_name][$uid]['nocache_hash'] = $tpl->properties['nocache_hash'] = $compiler->template->properties['nocache_hash']; | ||||
|                 if ($compiler->template->caching && $_caching == self::CACHING_NOCACHE_CODE) { | ||||
|                     // all code must be nocache | ||||
|                     $nocache = true; | ||||
|                 } | ||||
|                 if ($compiler->inheritance) { | ||||
|                     $tpl->compiler->inheritance = true; | ||||
|                 } | ||||
|                 // make sure whole chain gets compiled | ||||
|                 $tpl->mustCompile = true; | ||||
|                 if (!($tpl->source->uncompiled) && $tpl->source->exists) { | ||||
|  | ||||
|                     // get compiled code | ||||
|                     $compiled_code = $tpl->compiler->compileTemplate($tpl, $nocache); | ||||
|                     // release compiler object to free memory | ||||
|                     unset($tpl->compiler); | ||||
|                     // merge compiled code for {function} tags | ||||
|                     $compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $tpl->properties['function']); | ||||
|                     // merge filedependency | ||||
|                     $tpl->properties['file_dependency'][$tpl->source->uid] = array($tpl->source->filepath, $tpl->source->timestamp, $tpl->source->type); | ||||
|                     $compiler->template->properties['file_dependency'] = array_merge($compiler->template->properties['file_dependency'], $tpl->properties['file_dependency']); | ||||
|                     // remove header code | ||||
|                     $compiled_code = preg_replace("/(<\?php \/\*%%SmartyHeaderCode:{$tpl->properties['nocache_hash']}%%\*\/(.+?)\/\*\/%%SmartyHeaderCode%%\*\/\?>\n)/s", '', $compiled_code); | ||||
|                     if ($tpl->has_nocache_code) { | ||||
|                         // replace nocache_hash | ||||
|                         $compiled_code = str_replace("{$tpl->properties['nocache_hash']}", $compiler->template->properties['nocache_hash'], $compiled_code); | ||||
|                         $compiler->template->has_nocache_code = true; | ||||
|                     } | ||||
|                     $compiler->merged_templates[$tpl->properties['unifunc']] = $compiled_code; | ||||
|                     $has_compiled_template = true; | ||||
|                     unset ($tpl); | ||||
|                 } | ||||
|             } else { | ||||
|                 $has_compiled_template = true; | ||||
|             } | ||||
|         } | ||||
|         // delete {include} standard attributes | ||||
|         unset($_attr['file'], $_attr['assign'], $_attr['cache_id'], $_attr['compile_id'], $_attr['cache_lifetime'], $_attr['nocache'], $_attr['caching'], $_attr['scope'], $_attr['inline']); | ||||
|         // remaining attributes must be assigned as smarty variable | ||||
|         if (!empty($_attr)) { | ||||
|             if ($_parent_scope == Smarty::SCOPE_LOCAL) { | ||||
|                 // create variables | ||||
|                 $nccode = ''; | ||||
|                 foreach ($_attr as $key => $value) { | ||||
|                     $_pairs[] = "'$key'=>$value"; | ||||
|                     $nccode .= "\$_smarty_tpl->tpl_vars['$key'] =  new Smarty_variable($value);\n"; | ||||
|                 } | ||||
|                 $_vars = 'array(' . join(',', $_pairs) . ')'; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error('variable passing not allowed in parent/global scope', $compiler->lex->taglineno); | ||||
|             } | ||||
|         } else { | ||||
|             $_vars = 'array()'; | ||||
|         } | ||||
|         if ($has_compiled_template) { | ||||
|             // never call inline templates in nocache mode | ||||
|             $compiler->suppressNocacheProcessing = true; | ||||
|             $_hash = $compiler->smarty->merged_templates_func[$tpl_name][$uid]['nocache_hash']; | ||||
|             $_output = "<?php /*  Call merged included template \"" . $tpl_name . "\" */\n"; | ||||
|             $_output .= "\$_tpl_stack[] = \$_smarty_tpl;\n"; | ||||
|             if (!empty($nccode) && $_caching == 9999 && $_smarty_tpl->caching) { | ||||
|                 $compiler->suppressNocacheProcessing = false; | ||||
|                 $_output .=  substr($compiler->processNocacheCode('<?php ' .$nccode . "?>\n", true), 6, -3); | ||||
|                 $compiler->suppressNocacheProcessing = true; | ||||
|             } | ||||
|             $_output .= " \$_smarty_tpl = \$_smarty_tpl->setupInlineSubTemplate($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope, '$_hash');\n"; | ||||
|             if (isset($_assign)) { | ||||
|                 $_output .= 'ob_start(); '; | ||||
|             } | ||||
|             $_output .= $compiler->smarty->merged_templates_func[$tpl_name][$uid]['func'] . "(\$_smarty_tpl);\n"; | ||||
|             $_output .= "\$_smarty_tpl = array_pop(\$_tpl_stack); "; | ||||
|             if (isset($_assign)) { | ||||
|                 $_output .= " \$_smarty_tpl->tpl_vars[$_assign] = new Smarty_variable(ob_get_clean());"; | ||||
|             } | ||||
|             $_output .= "\n/*  End of included template \"" . $tpl_name . "\" */?>"; | ||||
|  | ||||
|             return $_output; | ||||
|         } | ||||
|  | ||||
|         // was there an assign attribute | ||||
|         if (isset($_assign)) { | ||||
|             $_output = "<?php \$_smarty_tpl->tpl_vars[$_assign] = new Smarty_variable(\$_smarty_tpl->getSubTemplate ($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope));?>\n";; | ||||
|         } else { | ||||
|             $_output = "<?php echo \$_smarty_tpl->getSubTemplate ($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope);?>\n"; | ||||
|         } | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,107 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Include PHP | ||||
|  * Compiles the {include_php} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Insert Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Include_Php extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('file'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('once', 'assign'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {include_php} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         if (!($compiler->smarty instanceof SmartyBC)) { | ||||
|             throw new SmartyException("{include_php} is deprecated, use SmartyBC class to enable"); | ||||
|         } | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|          * used in evaluated code | ||||
|          */ | ||||
|         $_smarty_tpl = $compiler->template; | ||||
|         $_filepath = false; | ||||
|         eval('$_file = ' . $_attr['file'] . ';'); | ||||
|         if (!isset($compiler->smarty->security_policy) && file_exists($_file)) { | ||||
|             $_filepath = $_file; | ||||
|         } else { | ||||
|             if (isset($compiler->smarty->security_policy)) { | ||||
|                 $_dir = $compiler->smarty->security_policy->trusted_dir; | ||||
|             } else { | ||||
|                 $_dir = $compiler->smarty->trusted_dir; | ||||
|             } | ||||
|             if (!empty($_dir)) { | ||||
|                 foreach ((array) $_dir as $_script_dir) { | ||||
|                     $_script_dir = rtrim($_script_dir, '/\\') . DS; | ||||
|                     if (file_exists($_script_dir . $_file)) { | ||||
|                         $_filepath = $_script_dir . $_file; | ||||
|                         break; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($_filepath == false) { | ||||
|             $compiler->trigger_template_error("{include_php} file '{$_file}' is not readable", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         if (isset($compiler->smarty->security_policy)) { | ||||
|             $compiler->smarty->security_policy->isTrustedPHPDir($_filepath); | ||||
|         } | ||||
|  | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             $_assign = $_attr['assign']; | ||||
|         } | ||||
|         $_once = '_once'; | ||||
|         if (isset($_attr['once'])) { | ||||
|             if ($_attr['once'] == 'false') { | ||||
|                 $_once = ''; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (isset($_assign)) { | ||||
|             return "<?php ob_start(); include{$_once} ('{$_filepath}'); \$_smarty_tpl->assign({$_assign},ob_get_contents()); ob_end_clean();?>"; | ||||
|         } else { | ||||
|             return "<?php include{$_once} ('{$_filepath}');?>\n"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,140 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Insert | ||||
|  * Compiles the {insert} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Insert Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Insert extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {insert} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // never compile as nocache code | ||||
|         $compiler->suppressNocacheProcessing = true; | ||||
|         $compiler->tag_nocache = true; | ||||
|         $_smarty_tpl = $compiler->template; | ||||
|         $_name = null; | ||||
|         $_script = null; | ||||
|  | ||||
|         $_output = '<?php '; | ||||
|         // save possible attributes | ||||
|         eval('$_name = ' . $_attr['name'] . ';'); | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             $_assign = $_attr['assign']; | ||||
|             // create variable to make sure that the compiler knows about its nocache status | ||||
|             $compiler->template->tpl_vars[trim($_attr['assign'], "'")] = new Smarty_Variable(null, true); | ||||
|         } | ||||
|         if (isset($_attr['script'])) { | ||||
|             // script which must be included | ||||
|             $_function = "smarty_insert_{$_name}"; | ||||
|             $_smarty_tpl = $compiler->template; | ||||
|             $_filepath = false; | ||||
|             eval('$_script = ' . $_attr['script'] . ';'); | ||||
|             if (!isset($compiler->smarty->security_policy) && file_exists($_script)) { | ||||
|                 $_filepath = $_script; | ||||
|             } else { | ||||
|                 if (isset($compiler->smarty->security_policy)) { | ||||
|                     $_dir = $compiler->smarty->security_policy->trusted_dir; | ||||
|                 } else { | ||||
|                     $_dir = $compiler->smarty->trusted_dir; | ||||
|                 } | ||||
|                 if (!empty($_dir)) { | ||||
|                     foreach ((array) $_dir as $_script_dir) { | ||||
|                         $_script_dir = rtrim($_script_dir, '/\\') . DS; | ||||
|                         if (file_exists($_script_dir . $_script)) { | ||||
|                             $_filepath = $_script_dir . $_script; | ||||
|                             break; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($_filepath == false) { | ||||
|                 $compiler->trigger_template_error("{insert} missing script file '{$_script}'", $compiler->lex->taglineno); | ||||
|             } | ||||
|             // code for script file loading | ||||
|             $_output .= "require_once '{$_filepath}' ;"; | ||||
|             require_once $_filepath; | ||||
|             if (!is_callable($_function)) { | ||||
|                 $compiler->trigger_template_error(" {insert} function '{$_function}' is not callable in script file '{$_script}'", $compiler->lex->taglineno); | ||||
|             } | ||||
|         } else { | ||||
|             $_filepath = 'null'; | ||||
|             $_function = "insert_{$_name}"; | ||||
|             // function in PHP script ? | ||||
|             if (!is_callable($_function)) { | ||||
|                 // try plugin | ||||
|                 if (!$_function = $compiler->getPlugin($_name, 'insert')) { | ||||
|                     $compiler->trigger_template_error("{insert} no function or plugin found for '{$_name}'", $compiler->lex->taglineno); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // delete {insert} standard attributes | ||||
|         unset($_attr['name'], $_attr['assign'], $_attr['script'], $_attr['nocache']); | ||||
|         // convert attributes into parameter array string | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             $_paramsArray[] = "'$_key' => $_value"; | ||||
|         } | ||||
|         $_params = 'array(' . implode(", ", $_paramsArray) . ')'; | ||||
|         // call insert | ||||
|         if (isset($_assign)) { | ||||
|             if ($_smarty_tpl->caching) { | ||||
|                 $_output .= "echo Smarty_Internal_Nocache_Insert::compile ('{$_function}',{$_params}, \$_smarty_tpl, '{$_filepath}',{$_assign});?>"; | ||||
|             } else { | ||||
|                 $_output .= "\$_smarty_tpl->assign({$_assign} , {$_function} ({$_params},\$_smarty_tpl), true);?>"; | ||||
|             } | ||||
|         } else { | ||||
|             $compiler->has_output = true; | ||||
|             if ($_smarty_tpl->caching) { | ||||
|                 $_output .= "echo Smarty_Internal_Nocache_Insert::compile ('{$_function}',{$_params}, \$_smarty_tpl, '{$_filepath}');?>"; | ||||
|             } else { | ||||
|                 $_output .= "echo {$_function}({$_params},\$_smarty_tpl);?>"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,39 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Ldelim | ||||
|  * Compiles the {ldelim} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Ldelim Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Ldelim extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {ldelim} tag | ||||
|      * This tag does output the left delimiter | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = true; | ||||
|  | ||||
|         return $compiler->smarty->left_delimiter; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,70 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Nocache | ||||
|  * Compiles the {nocache} {/nocache} tags. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Nocache Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Nocache extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {nocache} tag | ||||
|      * This tag does not generate compiled output. It only sets a compiler flag. | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|         // enter nocache mode | ||||
|         $compiler->nocache = true; | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Nocacheclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Nocacheclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/nocache} tag | ||||
|      * This tag does not generate compiled output. It only sets a compiler flag. | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // leave nocache mode | ||||
|         $compiler->nocache = false; | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,85 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Plugin | ||||
|  * Compiles code for the execution of block plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Plugin Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Block_Plugin extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of block plugin | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of block plugin | ||||
|      * @param  string $function  PHP function name | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag, $function) | ||||
|     { | ||||
|         if (!isset($tag[5]) || substr($tag, - 5) != 'close') { | ||||
|             // opening tag of block plugin | ||||
|             // check and get attributes | ||||
|             $_attr = $this->getAttributes($compiler, $args); | ||||
|             if ($_attr['nocache'] === true) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             unset($_attr['nocache']); | ||||
|             // convert attributes into parameter array string | ||||
|             $_paramsArray = array(); | ||||
|             foreach ($_attr as $_key => $_value) { | ||||
|                 if (is_int($_key)) { | ||||
|                     $_paramsArray[] = "$_key=>$_value"; | ||||
|                 } else { | ||||
|                     $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                 } | ||||
|             } | ||||
|             $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|  | ||||
|             $this->openTag($compiler, $tag, array($_params, $compiler->nocache)); | ||||
|             // maybe nocache because of nocache variables or nocache plugin | ||||
|             $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|             // compile code | ||||
|             $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>"; | ||||
|         } else { | ||||
|             // must endblock be nocache? | ||||
|             if ($compiler->nocache) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             // closing tag of block plugin, restore nocache | ||||
|             list($_params, $compiler->nocache) = $this->closeTag($compiler, substr($tag, 0, - 5)); | ||||
|             // This tag does create output | ||||
|             $compiler->has_output = true; | ||||
|             // compile code | ||||
|             if (!isset($parameter['modifier_list'])) { | ||||
|                 $mod_pre = $mod_post = ''; | ||||
|             } else { | ||||
|                 $mod_pre = ' ob_start(); '; | ||||
|                 $mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';'; | ||||
|             } | ||||
|             $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . " } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>"; | ||||
|         } | ||||
|  | ||||
|         return $output . "\n"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,71 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function Plugin | ||||
|  * Compiles code for the execution of function plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Function Plugin Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Function_Plugin extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array(); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of function plugin | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of function plugin | ||||
|      * @param  string $function  PHP function name | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag, $function) | ||||
|     { | ||||
|         // This tag does create output | ||||
|         $compiler->has_output = true; | ||||
|  | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         unset($_attr['nocache']); | ||||
|         // convert attributes into parameter array string | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|         // compile code | ||||
|         $output = "<?php echo {$function}({$_params},\$_smarty_tpl);?>\n"; | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,139 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Modifier | ||||
|  * Compiles code for modifier execution | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Modifier Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Modifier extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for modifier execution | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $output = $parameter['value']; | ||||
|         // loop over list of modifiers | ||||
|         foreach ($parameter['modifierlist'] as $single_modifier) { | ||||
|             $modifier = $single_modifier[0]; | ||||
|             $single_modifier[0] = $output; | ||||
|             $params = implode(',', $single_modifier); | ||||
|             // check if we know already the type of modifier | ||||
|             if (isset($compiler->known_modifier_type[$modifier])) { | ||||
|                 $modifier_types = array($compiler->known_modifier_type[$modifier]); | ||||
|             } else { | ||||
|                 $modifier_types = array(1, 2, 3, 4, 5, 6); | ||||
|             } | ||||
|             foreach ($modifier_types as $type) { | ||||
|                 switch ($type) { | ||||
|                     case 1: | ||||
|                         // registered modifier | ||||
|                         if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][$modifier])) { | ||||
|                             $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][$modifier][0]; | ||||
|                             if (!is_array($function)) { | ||||
|                                 $output = "{$function}({$params})"; | ||||
|                             } else { | ||||
|                                 if (is_object($function[0])) { | ||||
|                                     $output = '$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][\'' . $modifier . '\'][0][0]->' . $function[1] . '(' . $params . ')'; | ||||
|                                 } else { | ||||
|                                     $output = $function[0] . '::' . $function[1] . '(' . $params . ')'; | ||||
|                                 } | ||||
|                             } | ||||
|                             $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             break 2; | ||||
|                         } | ||||
|                         break; | ||||
|                     case 2: | ||||
|                         // registered modifier compiler | ||||
|                         if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIERCOMPILER][$modifier][0])) { | ||||
|                             $output = call_user_func($compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIERCOMPILER][$modifier][0], $single_modifier, $compiler->smarty); | ||||
|                             $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             break 2; | ||||
|                         } | ||||
|                         break; | ||||
|                     case 3: | ||||
|                         // modifiercompiler plugin | ||||
|                         if ($compiler->smarty->loadPlugin('smarty_modifiercompiler_' . $modifier)) { | ||||
|                             // check if modifier allowed | ||||
|                             if (!is_object($compiler->smarty->security_policy) || $compiler->smarty->security_policy->isTrustedModifier($modifier, $compiler)) { | ||||
|                                 $plugin = 'smarty_modifiercompiler_' . $modifier; | ||||
|                                 $output = $plugin($single_modifier, $compiler); | ||||
|                             } | ||||
|                             $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             break 2; | ||||
|                         } | ||||
|                         break; | ||||
|                     case 4: | ||||
|                         // modifier plugin | ||||
|                         if ($function = $compiler->getPlugin($modifier, Smarty::PLUGIN_MODIFIER)) { | ||||
|                             // check if modifier allowed | ||||
|                             if (!is_object($compiler->smarty->security_policy) || $compiler->smarty->security_policy->isTrustedModifier($modifier, $compiler)) { | ||||
|                                 $output = "{$function}({$params})"; | ||||
|                             } | ||||
|                             $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             break 2; | ||||
|                         } | ||||
|                         break; | ||||
|                     case 5: | ||||
|                         // PHP function | ||||
|                         if (is_callable($modifier)) { | ||||
|                             // check if modifier allowed | ||||
|                             if (!is_object($compiler->smarty->security_policy) || $compiler->smarty->security_policy->isTrustedPhpModifier($modifier, $compiler)) { | ||||
|                                 $output = "{$modifier}({$params})"; | ||||
|                             } | ||||
|                             $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             break 2; | ||||
|                         } | ||||
|                         break; | ||||
|                     case 6: | ||||
|                         // default plugin handler | ||||
|                         if (isset($compiler->default_handler_plugins[Smarty::PLUGIN_MODIFIER][$modifier]) || (is_callable($compiler->smarty->default_plugin_handler_func) && $compiler->getPluginFromDefaultHandler($modifier, Smarty::PLUGIN_MODIFIER))) { | ||||
|                             $function = $compiler->default_handler_plugins[Smarty::PLUGIN_MODIFIER][$modifier][0]; | ||||
|                             // check if modifier allowed | ||||
|                             if (!is_object($compiler->smarty->security_policy) || $compiler->smarty->security_policy->isTrustedModifier($modifier, $compiler)) { | ||||
|                                 if (!is_array($function)) { | ||||
|                                     $output = "{$function}({$params})"; | ||||
|                                 } else { | ||||
|                                     if (is_object($function[0])) { | ||||
|                                         $output = '$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][\'' . $modifier . '\'][0][0]->' . $function[1] . '(' . $params . ')'; | ||||
|                                     } else { | ||||
|                                         $output = $function[0] . '::' . $function[1] . '(' . $params . ')'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             } | ||||
|                             if (isset($compiler->template->required_plugins['nocache'][$modifier][Smarty::PLUGIN_MODIFIER]['file']) || isset($compiler->template->required_plugins['compiled'][$modifier][Smarty::PLUGIN_MODIFIER]['file'])) { | ||||
|                                 // was a plugin | ||||
|                                 $compiler->known_modifier_type[$modifier] = 4; | ||||
|                             } else { | ||||
|                                 $compiler->known_modifier_type[$modifier] = $type; | ||||
|                             } | ||||
|                             break 2; | ||||
|                         } | ||||
|                 } | ||||
|             } | ||||
|             if (!isset($compiler->known_modifier_type[$modifier])) { | ||||
|                 $compiler->trigger_template_error("unknown modifier \"" . $modifier . "\"", $compiler->lex->taglineno); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,86 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Object Block Function | ||||
|  * Compiles code for registered objects as block function | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Object Block Function Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Object_Block_Function extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of block plugin | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of block object | ||||
|      * @param  string $method    name of method to call | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag, $method) | ||||
|     { | ||||
|         if (!isset($tag[5]) || substr($tag, - 5) != 'close') { | ||||
|             // opening tag of block plugin | ||||
|             // check and get attributes | ||||
|             $_attr = $this->getAttributes($compiler, $args); | ||||
|             if ($_attr['nocache'] === true) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             unset($_attr['nocache']); | ||||
|             // convert attributes into parameter array string | ||||
|             $_paramsArray = array(); | ||||
|             foreach ($_attr as $_key => $_value) { | ||||
|                 if (is_int($_key)) { | ||||
|                     $_paramsArray[] = "$_key=>$_value"; | ||||
|                 } else { | ||||
|                     $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                 } | ||||
|             } | ||||
|             $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|  | ||||
|             $this->openTag($compiler, $tag . '->' . $method, array($_params, $compiler->nocache)); | ||||
|             // maybe nocache because of nocache variables or nocache plugin | ||||
|             $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|             // compile code | ||||
|             $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}->{$method}', {$_params}); \$_block_repeat=true; echo \$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>"; | ||||
|         } else { | ||||
|             $base_tag = substr($tag, 0, - 5); | ||||
|             // must endblock be nocache? | ||||
|             if ($compiler->nocache) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             // closing tag of block plugin, restore nocache | ||||
|             list($_params, $compiler->nocache) = $this->closeTag($compiler, $base_tag . '->' . $method); | ||||
|             // This tag does create output | ||||
|             $compiler->has_output = true; | ||||
|             // compile code | ||||
|             if (!isset($parameter['modifier_list'])) { | ||||
|                 $mod_pre = $mod_post = ''; | ||||
|             } else { | ||||
|                 $mod_pre = ' ob_start(); '; | ||||
|                 $mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';'; | ||||
|             } | ||||
|             $output = "<?php \$_block_content = ob_get_contents(); ob_end_clean(); \$_block_repeat=false;" . $mod_pre . " echo \$_smarty_tpl->smarty->registered_objects['{$base_tag}'][0]->{$method}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . "  } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>"; | ||||
|         } | ||||
|  | ||||
|         return $output . "\n"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,84 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Object Function | ||||
|  * Compiles code for registered objects as function | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Object Function Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Object_Function extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of function plugin | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of function | ||||
|      * @param  string $method    name of method to call | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag, $method) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         unset($_attr['nocache']); | ||||
|         $_assign = null; | ||||
|         if (isset($_attr['assign'])) { | ||||
|             $_assign = $_attr['assign']; | ||||
|             unset($_attr['assign']); | ||||
|         } | ||||
|         // method or property ? | ||||
|         if (method_exists($compiler->smarty->registered_objects[$tag][0], $method)) { | ||||
|             // convert attributes into parameter array string | ||||
|             if ($compiler->smarty->registered_objects[$tag][2]) { | ||||
|                 $_paramsArray = array(); | ||||
|                 foreach ($_attr as $_key => $_value) { | ||||
|                     if (is_int($_key)) { | ||||
|                         $_paramsArray[] = "$_key=>$_value"; | ||||
|                     } else { | ||||
|                         $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                     } | ||||
|                 } | ||||
|                 $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|                 $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params},\$_smarty_tpl)"; | ||||
|             } else { | ||||
|                 $_params = implode(",", $_attr); | ||||
|                 $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params})"; | ||||
|             } | ||||
|         } else { | ||||
|             // object property | ||||
|             $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}"; | ||||
|         } | ||||
|  | ||||
|         if (empty($_assign)) { | ||||
|             // This tag does create output | ||||
|             $compiler->has_output = true; | ||||
|             $output = "<?php echo {$return};?>\n"; | ||||
|         } else { | ||||
|             $output = "<?php \$_smarty_tpl->assign({$_assign},{$return});?>\n"; | ||||
|         } | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,151 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Print Expression | ||||
|  * Compiles any tag which will output an expression or variable | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Print Expression Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Print_Expression extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('assign'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array('nocache', 'nofilter'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for generating output from any expression | ||||
|      * | ||||
|      * @param array  $args      array with attributes from parser | ||||
|      * @param object $compiler  compiler object | ||||
|      * @param array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // nocache option | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         if (isset($_attr['assign'])) { | ||||
|             // assign output to variable | ||||
|             $output = "<?php \$_smarty_tpl->assign({$_attr['assign']},{$parameter['value']});?>"; | ||||
|         } else { | ||||
|             // display value | ||||
|             $output = $parameter['value']; | ||||
|             // tag modifier | ||||
|             if (!empty($parameter['modifierlist'])) { | ||||
|                 $output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifierlist'], 'value' => $output)); | ||||
|             } | ||||
|             if (!$_attr['nofilter']) { | ||||
|                 // default modifier | ||||
|                 if (!empty($compiler->smarty->default_modifiers)) { | ||||
|                     if (empty($compiler->default_modifier_list)) { | ||||
|                         $modifierlist = array(); | ||||
|                         foreach ($compiler->smarty->default_modifiers as $key => $single_default_modifier) { | ||||
|                             preg_match_all('/(\'[^\'\\\\]*(?:\\\\.[^\'\\\\]*)*\'|"[^"\\\\]*(?:\\\\.[^"\\\\]*)*"|:|[^:]+)/', $single_default_modifier, $mod_array); | ||||
|                             for ($i = 0, $count = count($mod_array[0]); $i < $count; $i ++) { | ||||
|                                 if ($mod_array[0][$i] != ':') { | ||||
|                                     $modifierlist[$key][] = $mod_array[0][$i]; | ||||
|                                 } | ||||
|                             } | ||||
|                         } | ||||
|                         $compiler->default_modifier_list = $modifierlist; | ||||
|                     } | ||||
|                     $output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => $compiler->default_modifier_list, 'value' => $output)); | ||||
|                 } | ||||
|                 // autoescape html | ||||
|                 if ($compiler->template->smarty->escape_html) { | ||||
|                     $output = "htmlspecialchars({$output}, ENT_QUOTES, '" . addslashes(Smarty::$_CHARSET) . "')"; | ||||
|                 } | ||||
|                 // loop over registered filters | ||||
|                 if (!empty($compiler->template->smarty->registered_filters[Smarty::FILTER_VARIABLE])) { | ||||
|                     foreach ($compiler->template->smarty->registered_filters[Smarty::FILTER_VARIABLE] as $key => $function) { | ||||
|                         if (!is_array($function)) { | ||||
|                             $output = "{$function}({$output},\$_smarty_tpl)"; | ||||
|                         } elseif (is_object($function[0])) { | ||||
|                             $output = "\$_smarty_tpl->smarty->registered_filters[Smarty::FILTER_VARIABLE]['{$key}'][0]->{$function[1]}({$output},\$_smarty_tpl)"; | ||||
|                         } else { | ||||
|                             $output = "{$function[0]}::{$function[1]}({$output},\$_smarty_tpl)"; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 // auto loaded filters | ||||
|                 if (isset($compiler->smarty->autoload_filters[Smarty::FILTER_VARIABLE])) { | ||||
|                     foreach ((array) $compiler->template->smarty->autoload_filters[Smarty::FILTER_VARIABLE] as $name) { | ||||
|                         $result = $this->compile_output_filter($compiler, $name, $output); | ||||
|                         if ($result !== false) { | ||||
|                             $output = $result; | ||||
|                         } else { | ||||
|                             // not found, throw exception | ||||
|                             throw new SmartyException("Unable to load filter '{$name}'"); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 if (isset($compiler->template->variable_filters)) { | ||||
|                     foreach ($compiler->template->variable_filters as $filter) { | ||||
|                         if (count($filter) == 1 && ($result = $this->compile_output_filter($compiler, $filter[0], $output)) !== false) { | ||||
|                             $output = $result; | ||||
|                         } else { | ||||
|                             $output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => array($filter), 'value' => $output)); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             $compiler->has_output = true; | ||||
|             $output = "<?php echo {$output};?>"; | ||||
|         } | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param object $compiler compiler object | ||||
|      * @param string $name     name of variable filter | ||||
|      * @param string   $output   embedded output | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function compile_output_filter($compiler, $name, $output) | ||||
|     { | ||||
|         $plugin_name = "smarty_variablefilter_{$name}"; | ||||
|         $path = $compiler->smarty->loadPlugin($plugin_name, false); | ||||
|         if ($path) { | ||||
|             if ($compiler->template->caching) { | ||||
|                 $compiler->template->required_plugins['nocache'][$name][Smarty::FILTER_VARIABLE]['file'] = $path; | ||||
|                 $compiler->template->required_plugins['nocache'][$name][Smarty::FILTER_VARIABLE]['function'] = $plugin_name; | ||||
|             } else { | ||||
|                 $compiler->template->required_plugins['compiled'][$name][Smarty::FILTER_VARIABLE]['file'] = $path; | ||||
|                 $compiler->template->required_plugins['compiled'][$name][Smarty::FILTER_VARIABLE]['function'] = $plugin_name; | ||||
|             } | ||||
|         } else { | ||||
|             // not found | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return "{$plugin_name}({$output},\$_smarty_tpl)"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,111 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Registered Block | ||||
|  * Compiles code for the execution of a registered block function | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Registered Block Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Registered_Block extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of a block function | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of block function | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag) | ||||
|     { | ||||
|         if (!isset($tag[5]) || substr($tag, - 5) != 'close') { | ||||
|             // opening tag of block plugin | ||||
|             // check and get attributes | ||||
|             $_attr = $this->getAttributes($compiler, $args); | ||||
|             if ($_attr['nocache']) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             unset($_attr['nocache']); | ||||
|             if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag])) { | ||||
|                 $tag_info = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag]; | ||||
|             } else { | ||||
|                 $tag_info = $compiler->default_handler_plugins[Smarty::PLUGIN_BLOCK][$tag]; | ||||
|             } | ||||
|             // convert attributes into parameter array string | ||||
|             $_paramsArray = array(); | ||||
|             foreach ($_attr as $_key => $_value) { | ||||
|                 if (is_int($_key)) { | ||||
|                     $_paramsArray[] = "$_key=>$_value"; | ||||
|                 } elseif ($compiler->template->caching && in_array($_key, $tag_info[2])) { | ||||
|                     $_value = str_replace("'", "^#^", $_value); | ||||
|                     $_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^"; | ||||
|                 } else { | ||||
|                     $_paramsArray[] = "'$_key'=>$_value"; | ||||
|                 } | ||||
|             } | ||||
|             $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|  | ||||
|             $this->openTag($compiler, $tag, array($_params, $compiler->nocache)); | ||||
|             // maybe nocache because of nocache variables or nocache plugin | ||||
|             $compiler->nocache = !$tag_info[1] | $compiler->nocache | $compiler->tag_nocache; | ||||
|             $function = $tag_info[0]; | ||||
|             // compile code | ||||
|             if (!is_array($function)) { | ||||
|                 $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>"; | ||||
|             } elseif (is_object($function[0])) { | ||||
|                 $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo \$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0][0]->{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>"; | ||||
|             } else { | ||||
|                 $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function[0]}::{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>"; | ||||
|             } | ||||
|         } else { | ||||
|             // must endblock be nocache? | ||||
|             if ($compiler->nocache) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             $base_tag = substr($tag, 0, - 5); | ||||
|             // closing tag of block plugin, restore nocache | ||||
|             list($_params, $compiler->nocache) = $this->closeTag($compiler, $base_tag); | ||||
|             // This tag does create output | ||||
|             $compiler->has_output = true; | ||||
|             if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag])) { | ||||
|                 $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag][0]; | ||||
|             } else { | ||||
|                 $function = $compiler->default_handler_plugins[Smarty::PLUGIN_BLOCK][$base_tag][0]; | ||||
|             } | ||||
|             // compile code | ||||
|             if (!isset($parameter['modifier_list'])) { | ||||
|                 $mod_pre = $mod_post = ''; | ||||
|             } else { | ||||
|                 $mod_pre = ' ob_start(); '; | ||||
|                 $mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';'; | ||||
|             } | ||||
|             if (!is_array($function)) { | ||||
|                 $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat);" . $mod_post . " } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>"; | ||||
|             } elseif (is_object($function[0])) { | ||||
|                 $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo \$_smarty_tpl->smarty->registered_plugins['block']['{$base_tag}'][0][0]->{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . "} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>"; | ||||
|             } else { | ||||
|                 $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function[0]}::{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . "} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $output . "\n"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,79 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Registered Function | ||||
|  * Compiles code for the execution of a registered function | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Registered Function Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Registered_Function extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('_any'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of a registered function | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * @param  string $tag       name of function | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter, $tag) | ||||
|     { | ||||
|         // This tag does create output | ||||
|         $compiler->has_output = true; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache']) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         unset($_attr['nocache']); | ||||
|         if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag])) { | ||||
|             $tag_info = $compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag]; | ||||
|         } else { | ||||
|             $tag_info = $compiler->default_handler_plugins[Smarty::PLUGIN_FUNCTION][$tag]; | ||||
|         } | ||||
|         // not cachable? | ||||
|         $compiler->tag_nocache = $compiler->tag_nocache || !$tag_info[1]; | ||||
|         // convert attributes into parameter array string | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } elseif ($compiler->template->caching && in_array($_key, $tag_info[2])) { | ||||
|                 $_value = str_replace("'", "^#^", $_value); | ||||
|                 $_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         $_params = 'array(' . implode(",", $_paramsArray) . ')'; | ||||
|         $function = $tag_info[0]; | ||||
|         // compile code | ||||
|         if (!is_array($function)) { | ||||
|             $output = "<?php echo {$function}({$_params},\$_smarty_tpl);?>\n"; | ||||
|         } elseif (is_object($function[0])) { | ||||
|             $output = "<?php echo \$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION]['{$tag}'][0][0]->{$function[1]}({$_params},\$_smarty_tpl);?>\n"; | ||||
|         } else { | ||||
|             $output = "<?php echo {$function[0]}::{$function[1]}({$_params},\$_smarty_tpl);?>\n"; | ||||
|         } | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,114 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Special Smarty Variable | ||||
|  * Compiles the special $smarty variables | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile special Smarty Variable Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Special_Variable extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the special $smarty variables | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * @param         $parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         $_index = preg_split("/\]\[/", substr($parameter, 1, strlen($parameter) - 2)); | ||||
|         $compiled_ref = ' '; | ||||
|         $variable = trim($_index[0], "'"); | ||||
|         switch ($variable) { | ||||
|             case 'foreach': | ||||
|                 return "\$_smarty_tpl->getVariable('smarty')->value$parameter"; | ||||
|             case 'section': | ||||
|                 return "\$_smarty_tpl->getVariable('smarty')->value$parameter"; | ||||
|             case 'capture': | ||||
|                 return "Smarty::\$_smarty_vars$parameter"; | ||||
|             case 'now': | ||||
|                 return 'time()'; | ||||
|             case 'cookies': | ||||
|                 if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) { | ||||
|                     $compiler->trigger_template_error("(secure mode) super globals not permitted"); | ||||
|                     break; | ||||
|                 } | ||||
|                 $compiled_ref = '$_COOKIE'; | ||||
|                 break; | ||||
|  | ||||
|             case 'get': | ||||
|             case 'post': | ||||
|             case 'env': | ||||
|             case 'server': | ||||
|             case 'session': | ||||
|             case 'request': | ||||
|                 if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) { | ||||
|                     $compiler->trigger_template_error("(secure mode) super globals not permitted"); | ||||
|                     break; | ||||
|                 } | ||||
|                 $compiled_ref = '$_' . strtoupper($variable); | ||||
|                 break; | ||||
|  | ||||
|             case 'template': | ||||
|                 return 'basename($_smarty_tpl->source->filepath)'; | ||||
|  | ||||
|             case 'template_object': | ||||
|                 return '$_smarty_tpl'; | ||||
|  | ||||
|             case 'current_dir': | ||||
|                 return 'dirname($_smarty_tpl->source->filepath)'; | ||||
|  | ||||
|             case 'version': | ||||
|                 $_version = Smarty::SMARTY_VERSION; | ||||
|  | ||||
|                 return "'$_version'"; | ||||
|  | ||||
|             case 'const': | ||||
|                 if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_constants) { | ||||
|                     $compiler->trigger_template_error("(secure mode) constants not permitted"); | ||||
|                     break; | ||||
|                 } | ||||
|  | ||||
|                 return "@constant({$_index[1]})"; | ||||
|  | ||||
|             case 'config': | ||||
|                 if (isset($_index[2])) { | ||||
|                     return "(is_array(\$tmp = \$_smarty_tpl->getConfigVariable($_index[1])) ? \$tmp[$_index[2]] : null)"; | ||||
|                 } else { | ||||
|                     return "\$_smarty_tpl->getConfigVariable($_index[1])"; | ||||
|                 } | ||||
|             case 'ldelim': | ||||
|                 $_ldelim = $compiler->smarty->left_delimiter; | ||||
|  | ||||
|                 return "'$_ldelim'"; | ||||
|  | ||||
|             case 'rdelim': | ||||
|                 $_rdelim = $compiler->smarty->right_delimiter; | ||||
|  | ||||
|                 return "'$_rdelim'"; | ||||
|  | ||||
|             default: | ||||
|                 $compiler->trigger_template_error('$smarty.' . trim($_index[0], "'") . ' is invalid'); | ||||
|                 break; | ||||
|         } | ||||
|         if (isset($_index[1])) { | ||||
|             array_shift($_index); | ||||
|             foreach ($_index as $_ind) { | ||||
|                 $compiled_ref = $compiled_ref . "[$_ind]"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $compiled_ref; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,39 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Rdelim | ||||
|  * Compiles the {rdelim} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Rdelim Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Rdelim extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {rdelim} tag | ||||
|      * This tag does output the right delimiter. | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr['nocache'] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno); | ||||
|         } | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = true; | ||||
|  | ||||
|         return $compiler->smarty->right_delimiter; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,206 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Section | ||||
|  * Compiles the {section} {sectionelse} {/section} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Section Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Section extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('name', 'loop'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('name', 'loop'); | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('start', 'step', 'max', 'show'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {section} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         $this->openTag($compiler, 'section', array('section', $compiler->nocache)); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|  | ||||
|         $output = "<?php "; | ||||
|  | ||||
|         $section_name = $_attr['name']; | ||||
|  | ||||
|         $output .= "if (isset(\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name])) unset(\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]);\n"; | ||||
|         $section_props = "\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]"; | ||||
|  | ||||
|         foreach ($_attr as $attr_name => $attr_value) { | ||||
|             switch ($attr_name) { | ||||
|                 case 'loop': | ||||
|                     $output .= "{$section_props}['loop'] = is_array(\$_loop=$attr_value) ? count(\$_loop) : max(0, (int) \$_loop); unset(\$_loop);\n"; | ||||
|                     break; | ||||
|  | ||||
|                 case 'show': | ||||
|                     if (is_bool($attr_value)) { | ||||
|                         $show_attr_value = $attr_value ? 'true' : 'false'; | ||||
|                     } else { | ||||
|                         $show_attr_value = "(bool) $attr_value"; | ||||
|                     } | ||||
|                     $output .= "{$section_props}['show'] = $show_attr_value;\n"; | ||||
|                     break; | ||||
|  | ||||
|                 case 'name': | ||||
|                     $output .= "{$section_props}['$attr_name'] = $attr_value;\n"; | ||||
|                     break; | ||||
|  | ||||
|                 case 'max': | ||||
|                 case 'start': | ||||
|                     $output .= "{$section_props}['$attr_name'] = (int) $attr_value;\n"; | ||||
|                     break; | ||||
|  | ||||
|                 case 'step': | ||||
|                     $output .= "{$section_props}['$attr_name'] = ((int) $attr_value) == 0 ? 1 : (int) $attr_value;\n"; | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (!isset($_attr['show'])) { | ||||
|             $output .= "{$section_props}['show'] = true;\n"; | ||||
|         } | ||||
|  | ||||
|         if (!isset($_attr['loop'])) { | ||||
|             $output .= "{$section_props}['loop'] = 1;\n"; | ||||
|         } | ||||
|  | ||||
|         if (!isset($_attr['max'])) { | ||||
|             $output .= "{$section_props}['max'] = {$section_props}['loop'];\n"; | ||||
|         } else { | ||||
|             $output .= "if ({$section_props}['max'] < 0)\n" . "    {$section_props}['max'] = {$section_props}['loop'];\n"; | ||||
|         } | ||||
|  | ||||
|         if (!isset($_attr['step'])) { | ||||
|             $output .= "{$section_props}['step'] = 1;\n"; | ||||
|         } | ||||
|  | ||||
|         if (!isset($_attr['start'])) { | ||||
|             $output .= "{$section_props}['start'] = {$section_props}['step'] > 0 ? 0 : {$section_props}['loop']-1;\n"; | ||||
|         } else { | ||||
|             $output .= "if ({$section_props}['start'] < 0)\n" . "    {$section_props}['start'] = max({$section_props}['step'] > 0 ? 0 : -1, {$section_props}['loop'] + {$section_props}['start']);\n" . "else\n" . "    {$section_props}['start'] = min({$section_props}['start'], {$section_props}['step'] > 0 ? {$section_props}['loop'] : {$section_props}['loop']-1);\n"; | ||||
|         } | ||||
|  | ||||
|         $output .= "if ({$section_props}['show']) {\n"; | ||||
|         if (!isset($_attr['start']) && !isset($_attr['step']) && !isset($_attr['max'])) { | ||||
|             $output .= "    {$section_props}['total'] = {$section_props}['loop'];\n"; | ||||
|         } else { | ||||
|             $output .= "    {$section_props}['total'] = min(ceil(({$section_props}['step'] > 0 ? {$section_props}['loop'] - {$section_props}['start'] : {$section_props}['start']+1)/abs({$section_props}['step'])), {$section_props}['max']);\n"; | ||||
|         } | ||||
|         $output .= "    if ({$section_props}['total'] == 0)\n" . "        {$section_props}['show'] = false;\n" . "} else\n" . "    {$section_props}['total'] = 0;\n"; | ||||
|  | ||||
|         $output .= "if ({$section_props}['show']):\n"; | ||||
|         $output .= " | ||||
|             for ({$section_props}['index'] = {$section_props}['start'], {$section_props}['iteration'] = 1; | ||||
|                  {$section_props}['iteration'] <= {$section_props}['total']; | ||||
|                  {$section_props}['index'] += {$section_props}['step'], {$section_props}['iteration']++):\n"; | ||||
|         $output .= "{$section_props}['rownum'] = {$section_props}['iteration'];\n"; | ||||
|         $output .= "{$section_props}['index_prev'] = {$section_props}['index'] - {$section_props}['step'];\n"; | ||||
|         $output .= "{$section_props}['index_next'] = {$section_props}['index'] + {$section_props}['step'];\n"; | ||||
|         $output .= "{$section_props}['first']      = ({$section_props}['iteration'] == 1);\n"; | ||||
|         $output .= "{$section_props}['last']       = ({$section_props}['iteration'] == {$section_props}['total']);\n"; | ||||
|  | ||||
|         $output .= "?>"; | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Sectionelse Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Sectionelse extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {sectionelse} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         list($openTag, $nocache) = $this->closeTag($compiler, array('section')); | ||||
|         $this->openTag($compiler, 'sectionelse', array('sectionelse', $nocache)); | ||||
|  | ||||
|         return "<?php endfor; else: ?>"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Sectionclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Sectionclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/section} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|  | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|  | ||||
|         list($openTag, $compiler->nocache) = $this->closeTag($compiler, array('section', 'sectionelse')); | ||||
|  | ||||
|         if ($openTag == 'sectionelse') { | ||||
|             return "<?php endif; ?>"; | ||||
|         } else { | ||||
|             return "<?php endfor; endif; ?>"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,70 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Setfilter | ||||
|  * Compiles code for setfilter tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Setfilter Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Setfilter extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for setfilter tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         $compiler->variable_filter_stack[] = $compiler->template->variable_filters; | ||||
|         $compiler->template->variable_filters = $parameter['modifier_list']; | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Setfilterclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Setfilterclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/setfilter} tag | ||||
|      * This tag does not generate compiled output. It resets variable filter. | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // reset variable filter to previous state | ||||
|         if (count($compiler->variable_filter_stack)) { | ||||
|             $compiler->template->variable_filters = array_pop($compiler->variable_filter_stack); | ||||
|         } else { | ||||
|             $compiler->template->variable_filters = array(); | ||||
|         } | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,93 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile While | ||||
|  * Compiles the {while} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile While Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_While extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {while} tag | ||||
|      * | ||||
|      * @param  array  $args      array with attributes from parser | ||||
|      * @param  object $compiler  compiler object | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $this->openTag($compiler, 'while', $compiler->nocache); | ||||
|  | ||||
|         if (!array_key_exists("if condition", $parameter)) { | ||||
|             $compiler->trigger_template_error("missing while condition", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         if (is_array($parameter['if condition'])) { | ||||
|             if ($compiler->nocache) { | ||||
|                 $_nocache = ',true'; | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 if (is_array($parameter['if condition']['var'])) { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } else { | ||||
|                     $compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true); | ||||
|                 } | ||||
|             } else { | ||||
|                 $_nocache = ''; | ||||
|             } | ||||
|             if (is_array($parameter['if condition']['var'])) { | ||||
|                 $_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n"; | ||||
|                 $_output .= "while (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|             } else { | ||||
|                 $_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});"; | ||||
|                 $_output .= "while (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>"; | ||||
|             } | ||||
|  | ||||
|             return $_output; | ||||
|         } else { | ||||
|             return "<?php while ({$parameter['if condition']}) {?>"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Whileclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Whileclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/while} tag | ||||
|      * | ||||
|      * @param  array  $args     array with attributes from parser | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, $compiler) | ||||
|     { | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $compiler->nocache = $this->closeTag($compiler, array('while')); | ||||
|  | ||||
|         return "<?php }?>"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										174
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,174 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin CompileBase | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * This class does extend all internal compile plugins | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| abstract class Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Array of names of required attribute required by tag | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $required_attributes = array(); | ||||
|     /** | ||||
|      * Array of names of optional attribute required by tag | ||||
|      * use array('_any') if there is no restriction of attributes names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $optional_attributes = array(); | ||||
|     /** | ||||
|      * Shorttag attribute order defined by its names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $shorttag_order = array(); | ||||
|     /** | ||||
|      * Array of names of valid option flags | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $option_flags = array('nocache'); | ||||
|  | ||||
|     /** | ||||
|      * This function checks if the attributes passed are valid | ||||
|      * The attributes passed for the tag to compile are checked against the list of required and | ||||
|      * optional attributes. Required attributes must be present. Optional attributes are check against | ||||
|      * the corresponding list. The keyword '_any' specifies that any attribute will be accepted | ||||
|      * as valid | ||||
|      * | ||||
|      * @param  object $compiler   compiler object | ||||
|      * @param  array  $attributes attributes applied to the tag | ||||
|      * | ||||
|      * @return array  of mapped attributes for further processing | ||||
|      */ | ||||
|     public function getAttributes($compiler, $attributes) | ||||
|     { | ||||
|         $_indexed_attr = array(); | ||||
|         // loop over attributes | ||||
|         foreach ($attributes as $key => $mixed) { | ||||
|             // shorthand ? | ||||
|             if (!is_array($mixed)) { | ||||
|                 // option flag ? | ||||
|                 if (in_array(trim($mixed, '\'"'), $this->option_flags)) { | ||||
|                     $_indexed_attr[trim($mixed, '\'"')] = true; | ||||
|                     // shorthand attribute ? | ||||
|                 } elseif (isset($this->shorttag_order[$key])) { | ||||
|                     $_indexed_attr[$this->shorttag_order[$key]] = $mixed; | ||||
|                 } else { | ||||
|                     // too many shorthands | ||||
|                     $compiler->trigger_template_error('too many shorthand attributes', $compiler->lex->taglineno); | ||||
|                 } | ||||
|                 // named attribute | ||||
|             } else { | ||||
|                 $kv = each($mixed); | ||||
|                 // option flag? | ||||
|                 if (in_array($kv['key'], $this->option_flags)) { | ||||
|                     if (is_bool($kv['value'])) { | ||||
|                         $_indexed_attr[$kv['key']] = $kv['value']; | ||||
|                     } elseif (is_string($kv['value']) && in_array(trim($kv['value'], '\'"'), array('true', 'false'))) { | ||||
|                         if (trim($kv['value']) == 'true') { | ||||
|                             $_indexed_attr[$kv['key']] = true; | ||||
|                         } else { | ||||
|                             $_indexed_attr[$kv['key']] = false; | ||||
|                         } | ||||
|                     } elseif (is_numeric($kv['value']) && in_array($kv['value'], array(0, 1))) { | ||||
|                         if ($kv['value'] == 1) { | ||||
|                             $_indexed_attr[$kv['key']] = true; | ||||
|                         } else { | ||||
|                             $_indexed_attr[$kv['key']] = false; | ||||
|                         } | ||||
|                     } else { | ||||
|                         $compiler->trigger_template_error("illegal value of option flag \"{$kv['key']}\"", $compiler->lex->taglineno); | ||||
|                     } | ||||
|                     // must be named attribute | ||||
|                 } else { | ||||
|                     reset($mixed); | ||||
|                     $_indexed_attr[key($mixed)] = $mixed[key($mixed)]; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // check if all required attributes present | ||||
|         foreach ($this->required_attributes as $attr) { | ||||
|             if (!array_key_exists($attr, $_indexed_attr)) { | ||||
|                 $compiler->trigger_template_error("missing \"" . $attr . "\" attribute", $compiler->lex->taglineno); | ||||
|             } | ||||
|         } | ||||
|         // check for not allowed attributes | ||||
|         if ($this->optional_attributes != array('_any')) { | ||||
|             $tmp_array = array_merge($this->required_attributes, $this->optional_attributes, $this->option_flags); | ||||
|             foreach ($_indexed_attr as $key => $dummy) { | ||||
|                 if (!in_array($key, $tmp_array) && $key !== 0) { | ||||
|                     $compiler->trigger_template_error("unexpected \"" . $key . "\" attribute", $compiler->lex->taglineno); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // default 'false' for all option flags not set | ||||
|         foreach ($this->option_flags as $flag) { | ||||
|             if (!isset($_indexed_attr[$flag])) { | ||||
|                 $_indexed_attr[$flag] = false; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_indexed_attr; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Push opening tag name on stack | ||||
|      * Optionally additional data can be saved on stack | ||||
|      * | ||||
|      * @param object $compiler compiler object | ||||
|      * @param string $openTag  the opening tag's name | ||||
|      * @param mixed  $data     optional data saved | ||||
|      */ | ||||
|     public function openTag($compiler, $openTag, $data = null) | ||||
|     { | ||||
|         array_push($compiler->_tag_stack, array($openTag, $data)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Pop closing tag | ||||
|      * Raise an error if this stack-top doesn't match with expected opening tags | ||||
|      * | ||||
|      * @param  object       $compiler    compiler object | ||||
|      * @param  array|string $expectedTag the expected opening tag names | ||||
|      * | ||||
|      * @return mixed        any type the opening tag's name or saved data | ||||
|      */ | ||||
|     public function closeTag($compiler, $expectedTag) | ||||
|     { | ||||
|         if (count($compiler->_tag_stack) > 0) { | ||||
|             // get stacked info | ||||
|             list($_openTag, $_data) = array_pop($compiler->_tag_stack); | ||||
|             // open tag must match with the expected ones | ||||
|             if (in_array($_openTag, (array) $expectedTag)) { | ||||
|                 if (is_null($_data)) { | ||||
|                     // return opening tag | ||||
|                     return $_openTag; | ||||
|                 } else { | ||||
|                     // return restored data | ||||
|                     return $_data; | ||||
|                 } | ||||
|             } | ||||
|             // wrong nesting of tags | ||||
|             $compiler->trigger_template_error("unclosed {$compiler->smarty->left_delimiter}" . $_openTag . "{$compiler->smarty->right_delimiter} tag"); | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         // wrong nesting of tags | ||||
|         $compiler->trigger_template_error("unexpected closing tag", $compiler->lex->taglineno); | ||||
|  | ||||
|         return; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										306
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_config.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										306
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_config.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,306 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Config | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Config | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Config | ||||
|  * Main class for config variables | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Config | ||||
|  * @ignore | ||||
|  */ | ||||
| class Smarty_Internal_Config | ||||
| { | ||||
|     /** | ||||
|      * Smarty instance | ||||
|      * | ||||
|      * @var Smarty object | ||||
|      */ | ||||
|     public $smarty = null; | ||||
|     /** | ||||
|      * Object of config var storage | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $data = null; | ||||
|     /** | ||||
|      * Config resource | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $config_resource = null; | ||||
|     /** | ||||
|      * Compiled config file | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compiled_config = null; | ||||
|     /** | ||||
|      * filepath of compiled config file | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compiled_filepath = null; | ||||
|     /** | ||||
|      * Filemtime of compiled config Filemtime | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $compiled_timestamp = null; | ||||
|     /** | ||||
|      * flag if compiled config file is invalid and must be (re)compiled | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $mustCompile = null; | ||||
|     /** | ||||
|      * Config file compiler object | ||||
|      * | ||||
|      * @var Smarty_Internal_Config_File_Compiler object | ||||
|      */ | ||||
|     public $compiler_object = null; | ||||
|  | ||||
|     /** | ||||
|      * Constructor of config file object | ||||
|      * | ||||
|      * @param string $config_resource config file resource name | ||||
|      * @param Smarty $smarty          Smarty instance | ||||
|      * @param object $data            object for config vars storage | ||||
|      */ | ||||
|     public function __construct($config_resource, $smarty, $data = null) | ||||
|     { | ||||
|         $this->data = $data; | ||||
|         $this->smarty = $smarty; | ||||
|         $this->config_resource = $config_resource; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the compiled  filepath | ||||
|      * | ||||
|      * @return string the compiled filepath | ||||
|      */ | ||||
|     public function getCompiledFilepath() | ||||
|     { | ||||
|         return $this->compiled_filepath === null ? | ||||
|             ($this->compiled_filepath = $this->buildCompiledFilepath()) : | ||||
|             $this->compiled_filepath; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get file path. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function buildCompiledFilepath() | ||||
|     { | ||||
|         $_compile_id = isset($this->smarty->compile_id) ? preg_replace('![^\w\|]+!', '_', $this->smarty->compile_id) : null; | ||||
|         $_flag = (int) $this->smarty->config_read_hidden + (int) $this->smarty->config_booleanize * 2 | ||||
|             + (int) $this->smarty->config_overwrite * 4; | ||||
|         $_filepath = sha1(realpath($this->source->filepath) . $_flag); | ||||
|         // if use_sub_dirs, break file into directories | ||||
|         if ($this->smarty->use_sub_dirs) { | ||||
|             $_filepath = substr($_filepath, 0, 2) . DS | ||||
|                 . substr($_filepath, 2, 2) . DS | ||||
|                 . substr($_filepath, 4, 2) . DS | ||||
|                 . $_filepath; | ||||
|         } | ||||
|         $_compile_dir_sep = $this->smarty->use_sub_dirs ? DS : '^'; | ||||
|         if (isset($_compile_id)) { | ||||
|             $_filepath = $_compile_id . $_compile_dir_sep . $_filepath; | ||||
|         } | ||||
|         $_compile_dir = $this->smarty->getCompileDir(); | ||||
|  | ||||
|         return $_compile_dir . $_filepath . '.' . basename($this->source->name) . '.config' . '.php'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the timestamp of the compiled file | ||||
|      * | ||||
|      * @return integer the file timestamp | ||||
|      */ | ||||
|     public function getCompiledTimestamp() | ||||
|     { | ||||
|         return $this->compiled_timestamp === null | ||||
|             ? ($this->compiled_timestamp = (file_exists($this->getCompiledFilepath())) ? filemtime($this->getCompiledFilepath()) : false) | ||||
|             : $this->compiled_timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns if the current config file must be compiled | ||||
|      * It does compare the timestamps of config source and the compiled config and checks the force compile configuration | ||||
|      * | ||||
|      * @return boolean true if the file must be compiled | ||||
|      */ | ||||
|     public function mustCompile() | ||||
|     { | ||||
|         return $this->mustCompile === null ? | ||||
|             $this->mustCompile = ($this->smarty->force_compile || $this->getCompiledTimestamp() === false || $this->smarty->compile_check && $this->getCompiledTimestamp() < $this->source->timestamp) : | ||||
|             $this->mustCompile; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the compiled config file | ||||
|      * It checks if the config file must be compiled or just read the compiled version | ||||
|      * | ||||
|      * @return string the compiled config file | ||||
|      */ | ||||
|     public function getCompiledConfig() | ||||
|     { | ||||
|         if ($this->compiled_config === null) { | ||||
|             // see if template needs compiling. | ||||
|             if ($this->mustCompile()) { | ||||
|                 $this->compileConfigSource(); | ||||
|             } else { | ||||
|                 $this->compiled_config = file_get_contents($this->getCompiledFilepath()); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this->compiled_config; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiles the config files | ||||
|      * | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function compileConfigSource() | ||||
|     { | ||||
|         // compile template | ||||
|         if (!is_object($this->compiler_object)) { | ||||
|             // load compiler | ||||
|             $this->compiler_object = new Smarty_Internal_Config_File_Compiler($this->smarty); | ||||
|         } | ||||
|         // compile locking | ||||
|         if ($this->smarty->compile_locking) { | ||||
|             if ($saved_timestamp = $this->getCompiledTimestamp()) { | ||||
|                 touch($this->getCompiledFilepath()); | ||||
|             } | ||||
|         } | ||||
|         // call compiler | ||||
|         try { | ||||
|             $this->compiler_object->compileSource($this); | ||||
|         } | ||||
|         catch (Exception $e) { | ||||
|             // restore old timestamp in case of error | ||||
|             if ($this->smarty->compile_locking && $saved_timestamp) { | ||||
|                 touch($this->getCompiledFilepath(), $saved_timestamp); | ||||
|             } | ||||
|             throw $e; | ||||
|         } | ||||
|         // compiling succeeded | ||||
|         // write compiled template | ||||
|         Smarty_Internal_Write_File::writeFile($this->getCompiledFilepath(), $this->getCompiledConfig(), $this->smarty); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * load config variables | ||||
|      * | ||||
|      * @param mixed         $sections array of section names, single section or null | ||||
|      * @param string $scope    global,parent or local | ||||
|      * | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function loadConfigVars($sections = null, $scope = 'local') | ||||
|     { | ||||
|         if ($this->data instanceof Smarty_Internal_Template) { | ||||
|             $this->data->properties['file_dependency'][sha1($this->source->filepath)] = array($this->source->filepath, $this->source->timestamp, 'file'); | ||||
|         } | ||||
|         if ($this->mustCompile()) { | ||||
|             $this->compileConfigSource(); | ||||
|         } | ||||
|         // pointer to scope | ||||
|         if ($scope == 'local') { | ||||
|             $scope_ptr = $this->data; | ||||
|         } elseif ($scope == 'parent') { | ||||
|             if (isset($this->data->parent)) { | ||||
|                 $scope_ptr = $this->data->parent; | ||||
|             } else { | ||||
|                 $scope_ptr = $this->data; | ||||
|             } | ||||
|         } elseif ($scope == 'root' || $scope == 'global') { | ||||
|             $scope_ptr = $this->data; | ||||
|             while (isset($scope_ptr->parent)) { | ||||
|                 $scope_ptr = $scope_ptr->parent; | ||||
|             } | ||||
|         } | ||||
|         $_config_vars = array(); | ||||
|         include($this->getCompiledFilepath()); | ||||
|         // copy global config vars | ||||
|         foreach ($_config_vars['vars'] as $variable => $value) { | ||||
|             if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) { | ||||
|                 $scope_ptr->config_vars[$variable] = $value; | ||||
|             } else { | ||||
|                 $scope_ptr->config_vars[$variable] = array_merge((array) $scope_ptr->config_vars[$variable], (array) $value); | ||||
|             } | ||||
|         } | ||||
|         // scan sections | ||||
|         if (!empty($sections)) { | ||||
|             foreach ((array) $sections as $this_section) { | ||||
|                 if (isset($_config_vars['sections'][$this_section])) { | ||||
|                     foreach ($_config_vars['sections'][$this_section]['vars'] as $variable => $value) { | ||||
|                         if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) { | ||||
|                             $scope_ptr->config_vars[$variable] = $value; | ||||
|                         } else { | ||||
|                             $scope_ptr->config_vars[$variable] = array_merge((array) $scope_ptr->config_vars[$variable], (array) $value); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * set Smarty property in template context | ||||
|      * | ||||
|      * @param  string $property_name property name | ||||
|      * @param  mixed  $value         value | ||||
|      * | ||||
|      * @throws SmartyException if $property_name is not valid | ||||
|      */ | ||||
|     public function __set($property_name, $value) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'source': | ||||
|             case 'compiled': | ||||
|                 $this->$property_name = $value; | ||||
|  | ||||
|                 return; | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("invalid config property '$property_name'."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * get Smarty property in template context | ||||
|      * | ||||
|      * @param  string $property_name property name | ||||
|      * | ||||
|      * @return \Smarty_Config_Source|\Smarty_Template_Compiled | ||||
|      * @throws SmartyException if $property_name is not valid | ||||
|      */ | ||||
|     public function __get($property_name) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'source': | ||||
|                 if (empty($this->config_resource)) { | ||||
|                     throw new SmartyException("Unable to parse resource name \"{$this->config_resource}\""); | ||||
|                 } | ||||
|                 $this->source = Smarty_Resource::config($this); | ||||
|  | ||||
|                 return $this->source; | ||||
|  | ||||
|             case 'compiled': | ||||
|                 $this->compiled = $this->source->getCompiled($this); | ||||
|  | ||||
|                 return $this->compiled; | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("config attribute '$property_name' does not exist."); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,159 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Config File Compiler | ||||
|  * This is the config file compiler class. It calls the lexer and parser to | ||||
|  * perform the compiling. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Config | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Main config file compiler class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Config | ||||
|  */ | ||||
| class Smarty_Internal_Config_File_Compiler | ||||
| { | ||||
|     /** | ||||
|      * Lexer object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $lex; | ||||
|  | ||||
|     /** | ||||
|      * Parser object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $parser; | ||||
|  | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var Smarty object | ||||
|      */ | ||||
|     public $smarty; | ||||
|  | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var Smarty_Internal_Config object | ||||
|      */ | ||||
|     public $config; | ||||
|  | ||||
|     /** | ||||
|      * Compiled config data sections and variables | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $config_data = array(); | ||||
|  | ||||
|     /** | ||||
|      * Initialize compiler | ||||
|      * | ||||
|      * @param Smarty $smarty base instance | ||||
|      */ | ||||
|     public function __construct($smarty) | ||||
|     { | ||||
|         $this->smarty = $smarty; | ||||
|         $this->config_data['sections'] = array(); | ||||
|         $this->config_data['vars'] = array(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Method to compile a Smarty template. | ||||
|      * | ||||
|      * @param  Smarty_Internal_Config $config config object | ||||
|      * | ||||
|      * @return bool                   true if compiling succeeded, false if it failed | ||||
|      */ | ||||
|     public function compileSource(Smarty_Internal_Config $config) | ||||
|     { | ||||
|         /* here is where the compiling takes place. Smarty | ||||
|           tags in the templates are replaces with PHP code, | ||||
|           then written to compiled files. */ | ||||
|         $this->config = $config; | ||||
|         // get config file source | ||||
|         $_content = $config->source->content . "\n"; | ||||
|         // on empty template just return | ||||
|         if ($_content == '') { | ||||
|             return true; | ||||
|         } | ||||
|         // init the lexer/parser to compile the config file | ||||
|         $lex = new Smarty_Internal_Configfilelexer($_content, $this); | ||||
|         $parser = new Smarty_Internal_Configfileparser($lex, $this); | ||||
|  | ||||
|         if (function_exists('mb_internal_encoding') && ((int) ini_get('mbstring.func_overload')) & 2) { | ||||
|             $mbEncoding = mb_internal_encoding(); | ||||
|             mb_internal_encoding('ASCII'); | ||||
|         } else { | ||||
|             $mbEncoding = null; | ||||
|         } | ||||
|  | ||||
|  | ||||
|         if ($this->smarty->_parserdebug) { | ||||
|             $parser->PrintTrace(); | ||||
|         } | ||||
|         // get tokens from lexer and parse them | ||||
|         while ($lex->yylex()) { | ||||
|             if ($this->smarty->_parserdebug) { | ||||
|                 echo "<br>Parsing  {$parser->yyTokenName[$lex->token]} Token {$lex->value} Line {$lex->line} \n"; | ||||
|             } | ||||
|             $parser->doParse($lex->token, $lex->value); | ||||
|         } | ||||
|         // finish parsing process | ||||
|         $parser->doParse(0, 0); | ||||
|  | ||||
|         if ($mbEncoding) { | ||||
|             mb_internal_encoding($mbEncoding); | ||||
|         } | ||||
|  | ||||
|         $config->compiled_config = '<?php $_config_vars = ' . var_export($this->config_data, true) . '; ?>'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * display compiler error messages without dying | ||||
|      * If parameter $args is empty it is a parser detected syntax error. | ||||
|      * In this case the parser is called to obtain information about expected tokens. | ||||
|      * If parameter $args contains a string this is used as error message | ||||
|      * | ||||
|      * @param string $args individual error message or null | ||||
|      * | ||||
|      * @throws SmartyCompilerException | ||||
|      */ | ||||
|     public function trigger_config_file_error($args = null) | ||||
|     { | ||||
|         $this->lex = Smarty_Internal_Configfilelexer::instance(); | ||||
|         $this->parser = Smarty_Internal_Configfileparser::instance(); | ||||
|         // get template source line which has error | ||||
|         $line = $this->lex->line; | ||||
|         if (isset($args)) { | ||||
|             // $line--; | ||||
|         } | ||||
|         $match = preg_split("/\n/", $this->lex->data); | ||||
|         $error_text = "Syntax error in config file '{$this->config->source->filepath}' on line {$line} '{$match[$line - 1]}' "; | ||||
|         if (isset($args)) { | ||||
|             // individual error message | ||||
|             $error_text .= $args; | ||||
|         } else { | ||||
|             // expected token from parser | ||||
|             foreach ($this->parser->yy_get_expected_tokens($this->parser->yymajor) as $token) { | ||||
|                 $exp_token = $this->parser->yyTokenName[$token]; | ||||
|                 if (isset($this->lex->smarty_token_names[$exp_token])) { | ||||
|                     // token type from lexer | ||||
|                     $expect[] = '"' . $this->lex->smarty_token_names[$exp_token] . '"'; | ||||
|                 } else { | ||||
|                     // otherwise internal token name | ||||
|                     $expect[] = $this->parser->yyTokenName[$token]; | ||||
|                 } | ||||
|             } | ||||
|             // output parser error message | ||||
|             $error_text .= ' - Unexpected "' . $this->lex->value . '", expected one of: ' . implode(' , ', $expect); | ||||
|         } | ||||
|         throw new SmartyCompilerException($error_text); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,643 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Configfilelexer | ||||
|  * This is the lexer to break the config file source into tokens | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Config | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Configfilelexer | ||||
|  */ | ||||
| class Smarty_Internal_Configfilelexer | ||||
| { | ||||
|  | ||||
|     public $data; | ||||
|     public $counter; | ||||
|     public $token; | ||||
|     public $value; | ||||
|     public $node; | ||||
|     public $line; | ||||
|     private $state = 1; | ||||
|     public $yyTraceFILE; | ||||
|     public $yyTracePrompt; | ||||
|     public $state_name = array(1 => 'START', 2 => 'VALUE', 3 => 'NAKED_STRING_VALUE', 4 => 'COMMENT', 5 => 'SECTION', 6 => 'TRIPPLE'); | ||||
|     public $smarty_token_names = array( // Text for parser error messages | ||||
|     ); | ||||
|  | ||||
|     function __construct($data, $compiler) | ||||
|     { | ||||
|         // set instance object | ||||
|         self::instance($this); | ||||
|         $this->data = $data . "\n"; //now all lines are \n-terminated | ||||
|         $this->counter = 0; | ||||
|         $this->line = 1; | ||||
|         $this->compiler = $compiler; | ||||
|         $this->smarty = $compiler->smarty; | ||||
|     } | ||||
|  | ||||
|     public static function &instance($new_instance = null) | ||||
|     { | ||||
|         static $instance = null; | ||||
|         if (isset($new_instance) && is_object($new_instance)) { | ||||
|             $instance = $new_instance; | ||||
|         } | ||||
|         return $instance; | ||||
|     } | ||||
|  | ||||
|     public function PrintTrace() | ||||
|     { | ||||
|         $this->yyTraceFILE = fopen('php://output', 'w'); | ||||
|         $this->yyTracePrompt = '<br>'; | ||||
|     } | ||||
|  | ||||
|     private $_yy_state = 1; | ||||
|     private $_yy_stack = array(); | ||||
|  | ||||
|     public function yylex() | ||||
|     { | ||||
|         return $this->{'yylex' . $this->_yy_state}(); | ||||
|     } | ||||
|  | ||||
|     public function yypushstate($state) | ||||
|     { | ||||
|         if ($this->yyTraceFILE) { | ||||
|             fprintf($this->yyTraceFILE, "%sState push %s\n", $this->yyTracePrompt, isset($this->state_name[$this->_yy_state]) ? $this->state_name[$this->_yy_state] : $this->_yy_state); | ||||
|         } | ||||
|         array_push($this->_yy_stack, $this->_yy_state); | ||||
|         $this->_yy_state = $state; | ||||
|         if ($this->yyTraceFILE) { | ||||
|             fprintf($this->yyTraceFILE, "%snew State %s\n", $this->yyTracePrompt, isset($this->state_name[$this->_yy_state]) ? $this->state_name[$this->_yy_state] : $this->_yy_state); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function yypopstate() | ||||
|     { | ||||
|         if ($this->yyTraceFILE) { | ||||
|             fprintf($this->yyTraceFILE, "%sState pop %s\n", $this->yyTracePrompt, isset($this->state_name[$this->_yy_state]) ? $this->state_name[$this->_yy_state] : $this->_yy_state); | ||||
|         } | ||||
|         $this->_yy_state = array_pop($this->_yy_stack); | ||||
|         if ($this->yyTraceFILE) { | ||||
|             fprintf($this->yyTraceFILE, "%snew State %s\n", $this->yyTracePrompt, isset($this->state_name[$this->_yy_state]) ? $this->state_name[$this->_yy_state] : $this->_yy_state); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function yybegin($state) | ||||
|     { | ||||
|         $this->_yy_state = $state; | ||||
|         if ($this->yyTraceFILE) { | ||||
|             fprintf($this->yyTraceFILE, "%sState set %s\n", $this->yyTracePrompt, isset($this->state_name[$this->_yy_state]) ? $this->state_name[$this->_yy_state] : $this->_yy_state); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function yylex1() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|             2 => 0, | ||||
|             3 => 0, | ||||
|             4 => 0, | ||||
|             5 => 0, | ||||
|             6 => 0, | ||||
|             7 => 0, | ||||
|             8 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G(#|;)|\G(\\[)|\G(\\])|\G(=)|\G([ \t\r]+)|\G(\n)|\G([0-9]*[a-zA-Z_]\\w*)|\G([\S\s])/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state START'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r1_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const START = 1; | ||||
|  | ||||
|     function yy_r1_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_COMMENTSTART; | ||||
|         $this->yypushstate(self::COMMENT); | ||||
|     } | ||||
|  | ||||
|     function yy_r1_2($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_OPENB; | ||||
|         $this->yypushstate(self::SECTION); | ||||
|     } | ||||
|  | ||||
|     function yy_r1_3($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_CLOSEB; | ||||
|     } | ||||
|  | ||||
|     function yy_r1_4($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_EQUAL; | ||||
|         $this->yypushstate(self::VALUE); | ||||
|     } | ||||
|  | ||||
|     function yy_r1_5($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     function yy_r1_6($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE; | ||||
|     } | ||||
|  | ||||
|     function yy_r1_7($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_ID; | ||||
|     } | ||||
|  | ||||
|     function yy_r1_8($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_OTHER; | ||||
|     } | ||||
|  | ||||
|     public function yylex2() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|             2 => 0, | ||||
|             3 => 0, | ||||
|             4 => 0, | ||||
|             5 => 0, | ||||
|             6 => 0, | ||||
|             7 => 0, | ||||
|             8 => 0, | ||||
|             9 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G([ \t\r]+)|\G(\\d+\\.\\d+(?=[ \t\r]*[\n#;]))|\G(\\d+(?=[ \t\r]*[\n#;]))|\G(\"\"\")|\G('[^'\\\\]*(?:\\\\.[^'\\\\]*)*'(?=[ \t\r]*[\n#;]))|\G(\"[^\"\\\\]*(?:\\\\.[^\"\\\\]*)*\"(?=[ \t\r]*[\n#;]))|\G([a-zA-Z]+(?=[ \t\r]*[\n#;]))|\G([^\n]+?(?=[ \t\r]*\n))|\G(\n)/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state VALUE'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r2_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const VALUE = 2; | ||||
|  | ||||
|     function yy_r2_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     function yy_r2_2($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_FLOAT; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_3($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_INT; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_4($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_QUOTES; | ||||
|         $this->yypushstate(self::TRIPPLE); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_5($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_SINGLE_QUOTED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_6($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_DOUBLE_QUOTED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_7($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         if (!$this->smarty->config_booleanize || !in_array(strtolower($this->value), Array("true", "false", "on", "off", "yes", "no"))) { | ||||
|             $this->yypopstate(); | ||||
|             $this->yypushstate(self::NAKED_STRING_VALUE); | ||||
|             return true; //reprocess in new state | ||||
|         } else { | ||||
|             $this->token = Smarty_Internal_Configfileparser::TPC_BOOL; | ||||
|             $this->yypopstate(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function yy_r2_8($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     function yy_r2_9($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->value = ""; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex3() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G([^\n]+?(?=[ \t\r]*\n))/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state NAKED_STRING_VALUE'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r3_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const NAKED_STRING_VALUE = 3; | ||||
|  | ||||
|     function yy_r3_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex4() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|             2 => 0, | ||||
|             3 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G([ \t\r]+)|\G([^\n]+?(?=[ \t\r]*\n))|\G(\n)/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state COMMENT'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r4_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const COMMENT = 4; | ||||
|  | ||||
|     function yy_r4_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     function yy_r4_2($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|     } | ||||
|  | ||||
|     function yy_r4_3($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex5() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|             2 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G(\\.)|\G(.*?(?=[\.=[\]\r\n]))/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state SECTION'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r5_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const SECTION = 5; | ||||
|  | ||||
|     function yy_r5_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_DOT; | ||||
|     } | ||||
|  | ||||
|     function yy_r5_2($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_SECTION; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex6() | ||||
|     { | ||||
|         $tokenMap = array( | ||||
|             1 => 0, | ||||
|             2 => 0, | ||||
|         ); | ||||
|         if ($this->counter >= strlen($this->data)) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         $yy_global_pattern = "/\G(\"\"\"(?=[ \t\r]*[\n#;]))|\G([\S\s])/iS"; | ||||
|  | ||||
|         do { | ||||
|             if (preg_match($yy_global_pattern, $this->data, $yymatches, null, $this->counter)) { | ||||
|                 $yysubmatches = $yymatches; | ||||
|                 $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns | ||||
|                 if (!count($yymatches)) { | ||||
|                     throw new Exception('Error: lexing failed because a rule matched' . | ||||
|                                         ' an empty string.  Input "' . substr($this->data, | ||||
|                                                                               $this->counter, 5) . '... state TRIPPLE'); | ||||
|                 } | ||||
|                 next($yymatches); // skip global match | ||||
|                 $this->token = key($yymatches); // token number | ||||
|                 if ($tokenMap[$this->token]) { | ||||
|                     // extract sub-patterns for passing to lex function | ||||
|                     $yysubmatches = array_slice($yysubmatches, $this->token + 1, | ||||
|                                                 $tokenMap[$this->token]); | ||||
|                 } else { | ||||
|                     $yysubmatches = array(); | ||||
|                 } | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r6_' . $this->token}($yysubmatches); | ||||
|                 if ($r === null) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     // accept this token | ||||
|                     return true; | ||||
|                 } elseif ($r === true) { | ||||
|                     // we have changed state | ||||
|                     // process this token in the new state | ||||
|                     return $this->yylex(); | ||||
|                 } elseif ($r === false) { | ||||
|                     $this->counter += strlen($this->value); | ||||
|                     $this->line += substr_count($this->value, "\n"); | ||||
|                     if ($this->counter >= strlen($this->data)) { | ||||
|                         return false; // end of input | ||||
|                     } | ||||
|                     // skip this token | ||||
|                     continue; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new Exception('Unexpected input at line' . $this->line . | ||||
|                                     ': ' . $this->data[$this->counter]); | ||||
|             } | ||||
|             break; | ||||
|         } while (true); | ||||
|     } // end function | ||||
|  | ||||
|     const TRIPPLE = 6; | ||||
|  | ||||
|     function yy_r6_1($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_QUOTES_END; | ||||
|         $this->yypopstate(); | ||||
|         $this->yypushstate(self::START); | ||||
|     } | ||||
|  | ||||
|     function yy_r6_2($yy_subpatterns) | ||||
|     { | ||||
|  | ||||
|         $to = strlen($this->data); | ||||
|         preg_match("/\"\"\"[ \t\r]*[\n#;]/", $this->data, $match, PREG_OFFSET_CAPTURE, $this->counter); | ||||
|         if (isset($match[0][1])) { | ||||
|             $to = $match[0][1]; | ||||
|         } else { | ||||
|             $this->compiler->trigger_template_error("missing or misspelled literal closing tag"); | ||||
|         } | ||||
|         $this->value = substr($this->data, $this->counter, $to - $this->counter); | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_TEXT; | ||||
|     } | ||||
| } | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										576
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										576
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,576 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Data | ||||
|  * This file contains the basic classes and methods for template and variable creation | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Base class with template and variable methods | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  */ | ||||
| class Smarty_Internal_Data | ||||
| { | ||||
|     /** | ||||
|      * name of class used for templates | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_class = 'Smarty_Internal_Template'; | ||||
|     /** | ||||
|      * template variables | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $tpl_vars = array(); | ||||
|     /** | ||||
|      * parent template (if any) | ||||
|      * | ||||
|      * @var Smarty_Internal_Template | ||||
|      */ | ||||
|     public $parent = null; | ||||
|     /** | ||||
|      * configuration settings | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $config_vars = array(); | ||||
|  | ||||
|     /** | ||||
|      * assigns a Smarty variable | ||||
|      * | ||||
|      * @param  array|string $tpl_var the template variable name(s) | ||||
|      * @param  mixed        $value   the value to assign | ||||
|      * @param  boolean      $nocache if true any output of this variable will be not cached | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function assign($tpl_var, $value = null, $nocache = false) | ||||
|     { | ||||
|         if (is_array($tpl_var)) { | ||||
|             foreach ($tpl_var as $_key => $_val) { | ||||
|                 if ($_key != '') { | ||||
|                     $this->tpl_vars[$_key] = new Smarty_variable($_val, $nocache); | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             if ($tpl_var != '') { | ||||
|                 $this->tpl_vars[$tpl_var] = new Smarty_variable($value, $nocache); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * assigns a global Smarty variable | ||||
|      * | ||||
|      * @param  string  $varname the global variable name | ||||
|      * @param  mixed   $value   the value to assign | ||||
|      * @param  boolean $nocache if true any output of this variable will be not cached | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function assignGlobal($varname, $value = null, $nocache = false) | ||||
|     { | ||||
|         if ($varname != '') { | ||||
|             Smarty::$global_tpl_vars[$varname] = new Smarty_variable($value, $nocache); | ||||
|             $ptr = $this; | ||||
|             while ($ptr instanceof Smarty_Internal_Template) { | ||||
|                 $ptr->tpl_vars[$varname] = clone Smarty::$global_tpl_vars[$varname]; | ||||
|                 $ptr = $ptr->parent; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * assigns values to template variables by reference | ||||
|      * | ||||
|      * @param string   $tpl_var the template variable name | ||||
|      * @param          $value | ||||
|      * @param  boolean $nocache if true any output of this variable will be not cached | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function assignByRef($tpl_var, &$value, $nocache = false) | ||||
|     { | ||||
|         if ($tpl_var != '') { | ||||
|             $this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache); | ||||
|             $this->tpl_vars[$tpl_var]->value = & $value; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * appends values to template variables | ||||
|      * | ||||
|      * @param  array|string $tpl_var the template variable name(s) | ||||
|      * @param  mixed        $value   the value to append | ||||
|      * @param  boolean      $merge   flag if array elements shall be merged | ||||
|      * @param  boolean      $nocache if true any output of this variable will be not cached | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function append($tpl_var, $value = null, $merge = false, $nocache = false) | ||||
|     { | ||||
|         if (is_array($tpl_var)) { | ||||
|             // $tpl_var is an array, ignore $value | ||||
|             foreach ($tpl_var as $_key => $_val) { | ||||
|                 if ($_key != '') { | ||||
|                     if (!isset($this->tpl_vars[$_key])) { | ||||
|                         $tpl_var_inst = $this->getVariable($_key, null, true, false); | ||||
|                         if ($tpl_var_inst instanceof Undefined_Smarty_Variable) { | ||||
|                             $this->tpl_vars[$_key] = new Smarty_variable(null, $nocache); | ||||
|                         } else { | ||||
|                             $this->tpl_vars[$_key] = clone $tpl_var_inst; | ||||
|                         } | ||||
|                     } | ||||
|                     if (!(is_array($this->tpl_vars[$_key]->value) || $this->tpl_vars[$_key]->value instanceof ArrayAccess)) { | ||||
|                         settype($this->tpl_vars[$_key]->value, 'array'); | ||||
|                     } | ||||
|                     if ($merge && is_array($_val)) { | ||||
|                         foreach ($_val as $_mkey => $_mval) { | ||||
|                             $this->tpl_vars[$_key]->value[$_mkey] = $_mval; | ||||
|                         } | ||||
|                     } else { | ||||
|                         $this->tpl_vars[$_key]->value[] = $_val; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             if ($tpl_var != '' && isset($value)) { | ||||
|                 if (!isset($this->tpl_vars[$tpl_var])) { | ||||
|                     $tpl_var_inst = $this->getVariable($tpl_var, null, true, false); | ||||
|                     if ($tpl_var_inst instanceof Undefined_Smarty_Variable) { | ||||
|                         $this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache); | ||||
|                     } else { | ||||
|                         $this->tpl_vars[$tpl_var] = clone $tpl_var_inst; | ||||
|                     } | ||||
|                 } | ||||
|                 if (!(is_array($this->tpl_vars[$tpl_var]->value) || $this->tpl_vars[$tpl_var]->value instanceof ArrayAccess)) { | ||||
|                     settype($this->tpl_vars[$tpl_var]->value, 'array'); | ||||
|                 } | ||||
|                 if ($merge && is_array($value)) { | ||||
|                     foreach ($value as $_mkey => $_mval) { | ||||
|                         $this->tpl_vars[$tpl_var]->value[$_mkey] = $_mval; | ||||
|                     } | ||||
|                 } else { | ||||
|                     $this->tpl_vars[$tpl_var]->value[] = $value; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * appends values to template variables by reference | ||||
|      * | ||||
|      * @param  string  $tpl_var the template variable name | ||||
|      * @param  mixed   &$value  the referenced value to append | ||||
|      * @param  boolean $merge   flag if array elements shall be merged | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function appendByRef($tpl_var, &$value, $merge = false) | ||||
|     { | ||||
|         if ($tpl_var != '' && isset($value)) { | ||||
|             if (!isset($this->tpl_vars[$tpl_var])) { | ||||
|                 $this->tpl_vars[$tpl_var] = new Smarty_variable(); | ||||
|             } | ||||
|             if (!is_array($this->tpl_vars[$tpl_var]->value)) { | ||||
|                 settype($this->tpl_vars[$tpl_var]->value, 'array'); | ||||
|             } | ||||
|             if ($merge && is_array($value)) { | ||||
|                 foreach ($value as $_key => $_val) { | ||||
|                     $this->tpl_vars[$tpl_var]->value[$_key] = & $value[$_key]; | ||||
|                 } | ||||
|             } else { | ||||
|                 $this->tpl_vars[$tpl_var]->value[] = & $value; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all template variables | ||||
|      * | ||||
|      * @param  string  $varname        variable name or null | ||||
|      * @param  object   $_ptr           optional pointer to data object | ||||
|      * @param  boolean $search_parents include parent templates? | ||||
|      * | ||||
|      * @return string  variable value or or array of variables | ||||
|      */ | ||||
|     public function getTemplateVars($varname = null, $_ptr = null, $search_parents = true) | ||||
|     { | ||||
|         if (isset($varname)) { | ||||
|             $_var = $this->getVariable($varname, $_ptr, $search_parents, false); | ||||
|             if (is_object($_var)) { | ||||
|                 return $_var->value; | ||||
|             } else { | ||||
|                 return null; | ||||
|             } | ||||
|         } else { | ||||
|             $_result = array(); | ||||
|             if ($_ptr === null) { | ||||
|                 $_ptr = $this; | ||||
|             } | ||||
|             while ($_ptr !== null) { | ||||
|                 foreach ($_ptr->tpl_vars AS $key => $var) { | ||||
|                     if (!array_key_exists($key, $_result)) { | ||||
|                         $_result[$key] = $var->value; | ||||
|                     } | ||||
|                 } | ||||
|                 // not found, try at parent | ||||
|                 if ($search_parents) { | ||||
|                     $_ptr = $_ptr->parent; | ||||
|                 } else { | ||||
|                     $_ptr = null; | ||||
|                 } | ||||
|             } | ||||
|             if ($search_parents && isset(Smarty::$global_tpl_vars)) { | ||||
|                 foreach (Smarty::$global_tpl_vars AS $key => $var) { | ||||
|                     if (!array_key_exists($key, $_result)) { | ||||
|                         $_result[$key] = $var->value; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return $_result; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * clear the given assigned template variable. | ||||
|      * | ||||
|      * @param  string|array $tpl_var the template variable(s) to clear | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function clearAssign($tpl_var) | ||||
|     { | ||||
|         if (is_array($tpl_var)) { | ||||
|             foreach ($tpl_var as $curr_var) { | ||||
|                 unset($this->tpl_vars[$curr_var]); | ||||
|             } | ||||
|         } else { | ||||
|             unset($this->tpl_vars[$tpl_var]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * clear all the assigned template variables. | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function clearAllAssign() | ||||
|     { | ||||
|         $this->tpl_vars = array(); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * load a config file, optionally load just selected sections | ||||
|      * | ||||
|      * @param  string $config_file filename | ||||
|      * @param  mixed  $sections    array of section names, single section or null | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function configLoad($config_file, $sections = null) | ||||
|     { | ||||
|         // load Config class | ||||
|         $config = new Smarty_Internal_Config($config_file, $this->smarty, $this); | ||||
|         $config->loadConfigVars($sections); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets the object of a Smarty variable | ||||
|      * | ||||
|      * @param  string  $variable       the name of the Smarty variable | ||||
|      * @param  object  $_ptr           optional pointer to data object | ||||
|      * @param  boolean $search_parents search also in parent data | ||||
|      * @param bool     $error_enable | ||||
|      * | ||||
|      * @return object  the object of the variable | ||||
|      */ | ||||
|     public function getVariable($variable, $_ptr = null, $search_parents = true, $error_enable = true) | ||||
|     { | ||||
|         if ($_ptr === null) { | ||||
|             $_ptr = $this; | ||||
|         } | ||||
|         while ($_ptr !== null) { | ||||
|             if (isset($_ptr->tpl_vars[$variable])) { | ||||
|                 // found it, return it | ||||
|                 return $_ptr->tpl_vars[$variable]; | ||||
|             } | ||||
|             // not found, try at parent | ||||
|             if ($search_parents) { | ||||
|                 $_ptr = $_ptr->parent; | ||||
|             } else { | ||||
|                 $_ptr = null; | ||||
|             } | ||||
|         } | ||||
|         if (isset(Smarty::$global_tpl_vars[$variable])) { | ||||
|             // found it, return it | ||||
|             return Smarty::$global_tpl_vars[$variable]; | ||||
|         } | ||||
|         if ($this->smarty->error_unassigned && $error_enable) { | ||||
|             // force a notice | ||||
|             $x = $$variable; | ||||
|         } | ||||
|  | ||||
|         return new Undefined_Smarty_Variable; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets  a config variable | ||||
|      * | ||||
|      * @param  string $variable the name of the config variable | ||||
|      * @param bool    $error_enable | ||||
|      * | ||||
|      * @return mixed  the value of the config variable | ||||
|      */ | ||||
|     public function getConfigVariable($variable, $error_enable = true) | ||||
|     { | ||||
|         $_ptr = $this; | ||||
|         while ($_ptr !== null) { | ||||
|             if (isset($_ptr->config_vars[$variable])) { | ||||
|                 // found it, return it | ||||
|                 return $_ptr->config_vars[$variable]; | ||||
|             } | ||||
|             // not found, try at parent | ||||
|             $_ptr = $_ptr->parent; | ||||
|         } | ||||
|         if ($this->smarty->error_unassigned && $error_enable) { | ||||
|             // force a notice | ||||
|             $x = $$variable; | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets  a stream variable | ||||
|      * | ||||
|      * @param  string $variable the stream of the variable | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return mixed  the value of the stream variable | ||||
|      */ | ||||
|     public function getStreamVariable($variable) | ||||
|     { | ||||
|         $_result = ''; | ||||
|         $fp = fopen($variable, 'r+'); | ||||
|         if ($fp) { | ||||
|             while (!feof($fp) && ($current_line = fgets($fp)) !== false) { | ||||
|                 $_result .= $current_line; | ||||
|             } | ||||
|             fclose($fp); | ||||
|  | ||||
|             return $_result; | ||||
|         } | ||||
|  | ||||
|         if ($this->smarty->error_unassigned) { | ||||
|             throw new SmartyException('Undefined stream variable "' . $variable . '"'); | ||||
|         } else { | ||||
|             return null; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all config variables | ||||
|      * | ||||
|      * @param  string $varname variable name or null | ||||
|      * @param bool    $search_parents | ||||
|      * | ||||
|      * @return string variable value or or array of variables | ||||
|      */ | ||||
|     public function getConfigVars($varname = null, $search_parents = true) | ||||
|     { | ||||
|         $_ptr = $this; | ||||
|         $var_array = array(); | ||||
|         while ($_ptr !== null) { | ||||
|             if (isset($varname)) { | ||||
|                 if (isset($_ptr->config_vars[$varname])) { | ||||
|                     return $_ptr->config_vars[$varname]; | ||||
|                 } | ||||
|             } else { | ||||
|                 $var_array = array_merge($_ptr->config_vars, $var_array); | ||||
|             } | ||||
|             // not found, try at parent | ||||
|             if ($search_parents) { | ||||
|                 $_ptr = $_ptr->parent; | ||||
|             } else { | ||||
|                 $_ptr = null; | ||||
|             } | ||||
|         } | ||||
|         if (isset($varname)) { | ||||
|             return ''; | ||||
|         } else { | ||||
|             return $var_array; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Deassigns a single or all config variables | ||||
|      * | ||||
|      * @param  string $varname variable name or null | ||||
|      * | ||||
|      * @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function clearConfig($varname = null) | ||||
|     { | ||||
|         if (isset($varname)) { | ||||
|             unset($this->config_vars[$varname]); | ||||
|         } else { | ||||
|             $this->config_vars = array(); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * class for the Smarty data object | ||||
|  * The Smarty data object will hold Smarty variables in the current scope | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  */ | ||||
| class Smarty_Data extends Smarty_Internal_Data | ||||
| { | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var Smarty | ||||
|      */ | ||||
|     public $smarty = null; | ||||
|  | ||||
|     /** | ||||
|      * create Smarty data object | ||||
|      * | ||||
|      * @param Smarty|array $_parent parent template | ||||
|      * @param Smarty|Smarty_Internal_Template       $smarty  global smarty instance | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function __construct($_parent = null, $smarty = null) | ||||
|     { | ||||
|         $this->smarty = $smarty; | ||||
|         if (is_object($_parent)) { | ||||
|             // when object set up back pointer | ||||
|             $this->parent = $_parent; | ||||
|         } elseif (is_array($_parent)) { | ||||
|             // set up variable values | ||||
|             foreach ($_parent as $_key => $_val) { | ||||
|                 $this->tpl_vars[$_key] = new Smarty_variable($_val); | ||||
|             } | ||||
|         } elseif ($_parent != null) { | ||||
|             throw new SmartyException("Wrong type for template variables"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * class for the Smarty variable object | ||||
|  * This class defines the Smarty variable object | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  */ | ||||
| class Smarty_Variable | ||||
| { | ||||
|     /** | ||||
|      * template variable | ||||
|      * | ||||
|      * @var mixed | ||||
|      */ | ||||
|     public $value = null; | ||||
|     /** | ||||
|      * if true any output of this variable will be not cached | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $nocache = false; | ||||
|     /** | ||||
|      * the scope the variable will have  (local,parent or root) | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $scope = Smarty::SCOPE_LOCAL; | ||||
|  | ||||
|     /** | ||||
|      * create Smarty variable object | ||||
|      * | ||||
|      * @param mixed   $value   the value to assign | ||||
|      * @param boolean $nocache if true any output of this variable will be not cached | ||||
|      * @param int     $scope   the scope the variable will have  (local,parent or root) | ||||
|      */ | ||||
|     public function __construct($value = null, $nocache = false, $scope = Smarty::SCOPE_LOCAL) | ||||
|     { | ||||
|         $this->value = $value; | ||||
|         $this->nocache = $nocache; | ||||
|         $this->scope = $scope; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * <<magic>> String conversion | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function __toString() | ||||
|     { | ||||
|         return (string) $this->value; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * class for undefined variable object | ||||
|  * This class defines an object for undefined variable handling | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  */ | ||||
| class Undefined_Smarty_Variable | ||||
| { | ||||
|     /** | ||||
|      * Returns FALSE for 'nocache' and NULL otherwise. | ||||
|      * | ||||
|      * @param  string $name | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function __get($name) | ||||
|     { | ||||
|         if ($name == 'nocache') { | ||||
|             return false; | ||||
|         } else { | ||||
|             return null; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Always returns an empty string. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function __toString() | ||||
|     { | ||||
|         return ""; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										254
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										254
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,254 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Debug | ||||
|  * Class to collect data for the Smarty Debugging Consol | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Debug | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Debug Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Debug | ||||
|  */ | ||||
| class Smarty_Internal_Debug extends Smarty_Internal_Data | ||||
| { | ||||
|     /** | ||||
|      * template data | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $template_data = array(); | ||||
|  | ||||
|     /** | ||||
|      * List of uid's which shall be ignored | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $ignore_uid = array(); | ||||
|  | ||||
|     /** | ||||
|      * Ignore template | ||||
|      * | ||||
|      * @param object $template | ||||
|      */ | ||||
|     public static function ignore($template) | ||||
|     { | ||||
|         // calculate Uid if not already done | ||||
|         if ($template->source->uid == '') { | ||||
|             $template->source->filepath; | ||||
|         } | ||||
|         self::$ignore_uid[$template->source->uid] = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of compile time | ||||
|      * | ||||
|      * @param object $template | ||||
|      */ | ||||
|     public static function start_compile($template) | ||||
|     { | ||||
|         static $_is_stringy = array('string' => true, 'eval' => true); | ||||
|         if (!empty($template->compiler->trace_uid)) { | ||||
|             $key = $template->compiler->trace_uid; | ||||
|             if (!isset(self::$template_data[$key])) { | ||||
|                 if (isset($_is_stringy[$template->source->type])) { | ||||
|                     self::$template_data[$key]['name'] = '\'' . substr($template->source->name, 0, 25) . '...\''; | ||||
|                 } else { | ||||
|                     self::$template_data[$key]['name'] = $template->source->filepath; | ||||
|                 } | ||||
|                 self::$template_data[$key]['compile_time'] = 0; | ||||
|                 self::$template_data[$key]['render_time'] = 0; | ||||
|                 self::$template_data[$key]['cache_time'] = 0; | ||||
|             } | ||||
|         } else { | ||||
|             if (isset(self::$ignore_uid[$template->source->uid])) { | ||||
|                 return; | ||||
|             } | ||||
|             $key = self::get_key($template); | ||||
|         } | ||||
|         self::$template_data[$key]['start_time'] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of compile time | ||||
|      * | ||||
|      * @param object $template | ||||
|      */ | ||||
|     public static function end_compile($template) | ||||
|     { | ||||
|         if (!empty($template->compiler->trace_uid)) { | ||||
|             $key = $template->compiler->trace_uid; | ||||
|         } else { | ||||
|             if (isset(self::$ignore_uid[$template->source->uid])) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             $key = self::get_key($template); | ||||
|         } | ||||
|         self::$template_data[$key]['compile_time'] += microtime(true) - self::$template_data[$key]['start_time']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of render time | ||||
|      * | ||||
|      * @param object $template | ||||
|      */ | ||||
|     public static function start_render($template) | ||||
|     { | ||||
|         $key = self::get_key($template); | ||||
|         self::$template_data[$key]['start_time'] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of compile time | ||||
|      * | ||||
|      * @param object $template | ||||
|      */ | ||||
|     public static function end_render($template) | ||||
|     { | ||||
|         $key = self::get_key($template); | ||||
|         self::$template_data[$key]['render_time'] += microtime(true) - self::$template_data[$key]['start_time']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of cache time | ||||
|      * | ||||
|      * @param object $template cached template | ||||
|      */ | ||||
|     public static function start_cache($template) | ||||
|     { | ||||
|         $key = self::get_key($template); | ||||
|         self::$template_data[$key]['start_time'] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of cache time | ||||
|      * | ||||
|      * @param object $template cached template | ||||
|      */ | ||||
|     public static function end_cache($template) | ||||
|     { | ||||
|         $key = self::get_key($template); | ||||
|         self::$template_data[$key]['cache_time'] += microtime(true) - self::$template_data[$key]['start_time']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Opens a window for the Smarty Debugging Consol and display the data | ||||
|      * | ||||
|      * @param Smarty_Internal_Template|Smarty $obj object to debug | ||||
|      */ | ||||
|     public static function display_debug($obj) | ||||
|     { | ||||
|         // prepare information of assigned variables | ||||
|         $ptr = self::get_debug_vars($obj); | ||||
|         if ($obj instanceof Smarty) { | ||||
|             $smarty = clone $obj; | ||||
|         } else { | ||||
|             $smarty = clone $obj->smarty; | ||||
|         } | ||||
|         $_assigned_vars = $ptr->tpl_vars; | ||||
|         ksort($_assigned_vars); | ||||
|         $_config_vars = $ptr->config_vars; | ||||
|         ksort($_config_vars); | ||||
|         $smarty->registered_filters = array(); | ||||
|         $smarty->autoload_filters = array(); | ||||
|         $smarty->default_modifiers = array(); | ||||
|         $smarty->force_compile = false; | ||||
|         $smarty->left_delimiter = '{'; | ||||
|         $smarty->right_delimiter = '}'; | ||||
|         $smarty->debugging = false; | ||||
|         $smarty->debugging_ctrl = 'NONE'; | ||||
|         $smarty->force_compile = false; | ||||
|         $_template = new Smarty_Internal_Template($smarty->debug_tpl, $smarty); | ||||
|         $_template->caching = false; | ||||
|         $_template->disableSecurity(); | ||||
|         $_template->cache_id = null; | ||||
|         $_template->compile_id = null; | ||||
|         if ($obj instanceof Smarty_Internal_Template) { | ||||
|             $_template->assign('template_name', $obj->source->type . ':' . $obj->source->name); | ||||
|         } | ||||
|         if ($obj instanceof Smarty) { | ||||
|             $_template->assign('template_data', self::$template_data); | ||||
|         } else { | ||||
|             $_template->assign('template_data', null); | ||||
|         } | ||||
|         $_template->assign('assigned_vars', $_assigned_vars); | ||||
|         $_template->assign('config_vars', $_config_vars); | ||||
|         $_template->assign('execution_time', microtime(true) - $smarty->start_time); | ||||
|         echo $_template->fetch(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Recursively gets variables from all template/data scopes | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template|Smarty_Data $obj object to debug | ||||
|      * | ||||
|      * @return StdClass | ||||
|      */ | ||||
|     public static function get_debug_vars($obj) | ||||
|     { | ||||
|         $config_vars = $obj->config_vars; | ||||
|         $tpl_vars = array(); | ||||
|         foreach ($obj->tpl_vars as $key => $var) { | ||||
|             $tpl_vars[$key] = clone $var; | ||||
|             if ($obj instanceof Smarty_Internal_Template) { | ||||
|                 $tpl_vars[$key]->scope = $obj->source->type . ':' . $obj->source->name; | ||||
|             } elseif ($obj instanceof Smarty_Data) { | ||||
|                 $tpl_vars[$key]->scope = 'Data object'; | ||||
|             } else { | ||||
|                 $tpl_vars[$key]->scope = 'Smarty root'; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (isset($obj->parent)) { | ||||
|             $parent = self::get_debug_vars($obj->parent); | ||||
|             $tpl_vars = array_merge($parent->tpl_vars, $tpl_vars); | ||||
|             $config_vars = array_merge($parent->config_vars, $config_vars); | ||||
|         } else { | ||||
|             foreach (Smarty::$global_tpl_vars as $name => $var) { | ||||
|                 if (!array_key_exists($name, $tpl_vars)) { | ||||
|                     $clone = clone $var; | ||||
|                     $clone->scope = 'Global'; | ||||
|                     $tpl_vars[$name] = $clone; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return (object) array('tpl_vars' => $tpl_vars, 'config_vars' => $config_vars); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return key into $template_data for template | ||||
|      * | ||||
|      * @param  object $template template object | ||||
|      * | ||||
|      * @return string key into $template_data | ||||
|      */ | ||||
|     private static function get_key($template) | ||||
|     { | ||||
|         static $_is_stringy = array('string' => true, 'eval' => true); | ||||
|         // calculate Uid if not already done | ||||
|         if ($template->source->uid == '') { | ||||
|             $template->source->filepath; | ||||
|         } | ||||
|         $key = $template->source->uid; | ||||
|         if (isset(self::$template_data[$key])) { | ||||
|             return $key; | ||||
|         } else { | ||||
|             if (isset($_is_stringy[$template->source->type])) { | ||||
|                 self::$template_data[$key]['name'] = '\'' . substr($template->source->name, 0, 25) . '...\''; | ||||
|             } else { | ||||
|                 self::$template_data[$key]['name'] = $template->source->filepath; | ||||
|             } | ||||
|             self::$template_data[$key]['compile_time'] = 0; | ||||
|             self::$template_data[$key]['render_time'] = 0; | ||||
|             self::$template_data[$key]['cache_time'] = 0; | ||||
|  | ||||
|             return $key; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,67 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Filter Handler | ||||
|  * Smarty filter handler class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Class for filter processing | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  */ | ||||
| class Smarty_Internal_Filter_Handler | ||||
| { | ||||
|     /** | ||||
|      * Run filters over content | ||||
|      * The filters will be lazy loaded if required | ||||
|      * class name format: Smarty_FilterType_FilterName | ||||
|      * plugin filename format: filtertype.filtername.php | ||||
|      * Smarty2 filter plugins could be used | ||||
|      * | ||||
|      * @param  string                   $type     the type of filter ('pre','post','output') which shall run | ||||
|      * @param  string                   $content  the content which shall be processed by the filters | ||||
|      * @param  Smarty_Internal_Template $template template object | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return string                   the filtered content | ||||
|      */ | ||||
|     public static function runFilter($type, $content, Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $output = $content; | ||||
|         // loop over autoload filters of specified type | ||||
|         if (!empty($template->smarty->autoload_filters[$type])) { | ||||
|             foreach ((array) $template->smarty->autoload_filters[$type] as $name) { | ||||
|                 $plugin_name = "Smarty_{$type}filter_{$name}"; | ||||
|                 if ($template->smarty->loadPlugin($plugin_name)) { | ||||
|                     if (function_exists($plugin_name)) { | ||||
|                         // use loaded Smarty2 style plugin | ||||
|                         $output = $plugin_name($output, $template); | ||||
|                     } elseif (class_exists($plugin_name, false)) { | ||||
|                         // loaded class of filter plugin | ||||
|                         $output = call_user_func(array($plugin_name, 'execute'), $output, $template); | ||||
|                     } | ||||
|                 } else { | ||||
|                     // nothing found, throw exception | ||||
|                     throw new SmartyException("Unable to load filter {$plugin_name}"); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // loop over registerd filters of specified type | ||||
|         if (!empty($template->smarty->registered_filters[$type])) { | ||||
|             foreach ($template->smarty->registered_filters[$type] as $key => $name) { | ||||
|                 if (is_array($template->smarty->registered_filters[$type][$key])) { | ||||
|                     $output = call_user_func($template->smarty->registered_filters[$type][$key], $output, $template); | ||||
|                 } else { | ||||
|                     $output = $template->smarty->registered_filters[$type][$key]($output, $template); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // return filtered output | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,52 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Function Call Handler | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * This class does call function defined with the {function} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  */ | ||||
| class Smarty_Internal_Function_Call_Handler | ||||
| { | ||||
|     /** | ||||
|      * This function handles calls to template functions defined by {function} | ||||
|      * It does create a PHP function at the first call | ||||
|      * | ||||
|      * @param string                   $_name     template function name | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param array                    $_params   Smarty variables passed as call parameter | ||||
|      * @param string                   $_hash     nocache hash value | ||||
|      * @param bool                     $_nocache  nocache flag | ||||
|      */ | ||||
|     public static function call($_name, Smarty_Internal_Template $_template, $_params, $_hash, $_nocache) | ||||
|     { | ||||
|         if ($_nocache) { | ||||
|             $_function = "smarty_template_function_{$_name}_nocache"; | ||||
|         } else { | ||||
|             $_function = "smarty_template_function_{$_hash}_{$_name}"; | ||||
|         } | ||||
|         if (!is_callable($_function)) { | ||||
|             $_code = "function {$_function}(\$_smarty_tpl,\$params) { | ||||
|     \$saved_tpl_vars = \$_smarty_tpl->tpl_vars; | ||||
|     foreach (\$_smarty_tpl->smarty->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}; | ||||
|     foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>"; | ||||
|             if ($_nocache) { | ||||
|                 $_code .= preg_replace(array("!<\?php echo \\'/\*%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/|/\*/%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/\\';\?>!", | ||||
|                                              "!\\\'!"), array('', "'"), $_template->smarty->template_functions[$_name]['compiled']); | ||||
|                 $_template->smarty->template_functions[$_name]['called_nocache'] = true; | ||||
|             } else { | ||||
|                 $_code .= preg_replace("/{$_template->smarty->template_functions[$_name]['nocache_hash']}/", $_template->properties['nocache_hash'], $_template->smarty->template_functions[$_name]['compiled']); | ||||
|             } | ||||
|             $_code .= "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars;}"; | ||||
|             eval($_code); | ||||
|         } | ||||
|         $_function($_template, $_params); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,46 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty read include path plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Monte Ohrt | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Read Include Path Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  */ | ||||
| class Smarty_Internal_Get_Include_Path | ||||
| { | ||||
|     /** | ||||
|      * Return full file path from PHP include_path | ||||
|      * | ||||
|      * @param  string $filepath filepath | ||||
|      * | ||||
|      * @return string|boolean full filepath or false | ||||
|      */ | ||||
|     public static function getIncludePath($filepath) | ||||
|     { | ||||
|         static $_include_path = null; | ||||
|  | ||||
|         if (function_exists('stream_resolve_include_path')) { | ||||
|             // available since PHP 5.3.2 | ||||
|             return stream_resolve_include_path($filepath); | ||||
|         } | ||||
|  | ||||
|         if ($_include_path === null) { | ||||
|             $_include_path = explode(PATH_SEPARATOR, get_include_path()); | ||||
|         } | ||||
|  | ||||
|         foreach ($_include_path as $_path) { | ||||
|             if (file_exists($_path . DS . $filepath)) { | ||||
|                 return $_path . DS . $filepath; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Nocache Insert | ||||
|  * Compiles the {insert} tag into the cache file | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Insert Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Nocache_Insert | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {insert} tag into cache file | ||||
|      * | ||||
|      * @param  string                   $_function insert function name | ||||
|      * @param  array                    $_attr     array with parameter | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * @param  string                   $_script   script name to load or 'null' | ||||
|      * @param  string                   $_assign   optional variable name | ||||
|      * | ||||
|      * @return string                   compiled code | ||||
|      */ | ||||
|     public static function compile($_function, $_attr, $_template, $_script, $_assign = null) | ||||
|     { | ||||
|         $_output = '<?php '; | ||||
|         if ($_script != 'null') { | ||||
|             // script which must be included | ||||
|             // code for script file loading | ||||
|             $_output .= "require_once '{$_script}';"; | ||||
|         } | ||||
|         // call insert | ||||
|         if (isset($_assign)) { | ||||
|             $_output .= "\$_smarty_tpl->assign('{$_assign}' , {$_function} (" . var_export($_attr, true) . ",\$_smarty_tpl), true);?>"; | ||||
|         } else { | ||||
|             $_output .= "echo {$_function}(" . var_export($_attr, true) . ",\$_smarty_tpl);?>"; | ||||
|         } | ||||
|         $_tpl = $_template; | ||||
|         while ($_tpl->parent instanceof Smarty_Internal_Template) { | ||||
|             $_tpl = $_tpl->parent; | ||||
|         } | ||||
|  | ||||
|         return "/*%%SmartyNocache:{$_tpl->properties['nocache_hash']}%%*/" . $_output . "/*/%%SmartyNocache:{$_tpl->properties['nocache_hash']}%%*/"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										394
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_parsetree.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										394
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_parsetree.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,394 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Templateparser Parsetrees | ||||
|  * These are classes to build parsetrees in the template parser | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Thue Kristensen | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| abstract class _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Parser object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $parser; | ||||
|     /** | ||||
|      * Buffer content | ||||
|      * | ||||
|      * @var mixed | ||||
|      */ | ||||
|     public $data; | ||||
|  | ||||
|     /** | ||||
|      * Subtree array | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $subtrees = array(); | ||||
|  | ||||
|     /** | ||||
|      * Return buffer | ||||
|      * | ||||
|      * @return string buffer content | ||||
|      */ | ||||
|     abstract public function to_smarty_php(); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * A complete smarty tag. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_tag extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Saved block nesting level | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $saved_block_nesting; | ||||
|  | ||||
|     /** | ||||
|      * Create parse tree buffer for Smarty tag | ||||
|      * | ||||
|      * @param object $parser parser object | ||||
|      * @param string $data   content | ||||
|      */ | ||||
|     public function __construct($parser, $data) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->data = $data; | ||||
|         $this->saved_block_nesting = $parser->block_nesting_level; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return buffer content | ||||
|      * | ||||
|      * @return string content | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         return $this->data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return complied code that loads the evaluated output of buffer content into a temporary variable | ||||
|      * | ||||
|      * @return string template code | ||||
|      */ | ||||
|     public function assign_to_var() | ||||
|     { | ||||
|         $var = sprintf('$_tmp%d', ++Smarty_Internal_Templateparser::$prefix_number); | ||||
|         $this->parser->compiler->prefix_code[] = sprintf('<?php ob_start();?>%s<?php %s=ob_get_clean();?>', $this->data, $var); | ||||
|  | ||||
|         return $var; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Code fragment inside a tag. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_code extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Create parse tree buffer for code fragment | ||||
|      * | ||||
|      * @param object $parser parser object | ||||
|      * @param string $data   content | ||||
|      */ | ||||
|     public function __construct($parser, $data) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->data = $data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return buffer content in parentheses | ||||
|      * | ||||
|      * @return string content | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         return sprintf("(%s)", $this->data); | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Double quoted string inside a tag. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_doublequoted extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Create parse tree buffer for double quoted string subtrees | ||||
|      * | ||||
|      * @param object            $parser  parser object | ||||
|      * @param _smarty_parsetree $subtree parsetree buffer | ||||
|      */ | ||||
|     public function __construct($parser, _smarty_parsetree $subtree) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->subtrees[] = $subtree; | ||||
|         if ($subtree instanceof _smarty_tag) { | ||||
|             $this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Append buffer to subtree | ||||
|      * | ||||
|      * @param _smarty_parsetree $subtree parsetree buffer | ||||
|      */ | ||||
|     public function append_subtree(_smarty_parsetree $subtree) | ||||
|     { | ||||
|         $last_subtree = count($this->subtrees) - 1; | ||||
|         if ($last_subtree >= 0 && $this->subtrees[$last_subtree] instanceof _smarty_tag && $this->subtrees[$last_subtree]->saved_block_nesting < $this->parser->block_nesting_level) { | ||||
|             if ($subtree instanceof _smarty_code) { | ||||
|                 $this->subtrees[$last_subtree]->data .= '<?php echo ' . $subtree->data . ';?>'; | ||||
|             } elseif ($subtree instanceof _smarty_dq_content) { | ||||
|                 $this->subtrees[$last_subtree]->data .= '<?php echo "' . $subtree->data . '";?>'; | ||||
|             } else { | ||||
|                 $this->subtrees[$last_subtree]->data .= $subtree->data; | ||||
|             } | ||||
|         } else { | ||||
|             $this->subtrees[] = $subtree; | ||||
|         } | ||||
|         if ($subtree instanceof _smarty_tag) { | ||||
|             $this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Merge subtree buffer content together | ||||
|      * | ||||
|      * @return string compiled template code | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         $code = ''; | ||||
|         foreach ($this->subtrees as $subtree) { | ||||
|             if ($code !== "") { | ||||
|                 $code .= "."; | ||||
|             } | ||||
|             if ($subtree instanceof _smarty_tag) { | ||||
|                 $more_php = $subtree->assign_to_var(); | ||||
|             } else { | ||||
|                 $more_php = $subtree->to_smarty_php(); | ||||
|             } | ||||
|  | ||||
|             $code .= $more_php; | ||||
|  | ||||
|             if (!$subtree instanceof _smarty_dq_content) { | ||||
|                 $this->parser->compiler->has_variable_string = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $code; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Raw chars as part of a double quoted string. | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_dq_content extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Create parse tree buffer with string content | ||||
|      * | ||||
|      * @param object $parser parser object | ||||
|      * @param string $data   string section | ||||
|      */ | ||||
|     public function __construct($parser, $data) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->data = $data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return content as double quoted string | ||||
|      * | ||||
|      * @return string doubled quoted string | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         return '"' . $this->data . '"'; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Template element | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_template_buffer extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Array of template elements | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $subtrees = Array(); | ||||
|  | ||||
|     /** | ||||
|      * Create root of parse tree for template elements | ||||
|      * | ||||
|      * @param object $parser parse object | ||||
|      */ | ||||
|     public function __construct($parser) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Append buffer to subtree | ||||
|      * | ||||
|      * @param _smarty_parsetree $subtree | ||||
|      */ | ||||
|     public function append_subtree(_smarty_parsetree $subtree) | ||||
|     { | ||||
|         $this->subtrees[] = $subtree; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sanitize and merge subtree buffers together | ||||
|      * | ||||
|      * @return string template code content | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         $code = ''; | ||||
|         for ($key = 0, $cnt = count($this->subtrees); $key < $cnt; $key ++) { | ||||
|             if ($key + 2 < $cnt) { | ||||
|                 if ($this->subtrees[$key] instanceof _smarty_linebreak && $this->subtrees[$key + 1] instanceof _smarty_tag && $this->subtrees[$key + 1]->data == '' && $this->subtrees[$key + 2] instanceof _smarty_linebreak) { | ||||
|                     $key = $key + 1; | ||||
|                     continue; | ||||
|                 } | ||||
|                 if (substr($this->subtrees[$key]->data, - 1) == '<' && $this->subtrees[$key + 1]->data == '' && substr($this->subtrees[$key + 2]->data, - 1) == '?') { | ||||
|                     $key = $key + 2; | ||||
|                     continue; | ||||
|                 } | ||||
|             } | ||||
|             if (substr($code, - 1) == '<') { | ||||
|                 $subtree = $this->subtrees[$key]->to_smarty_php(); | ||||
|                 if (substr($subtree, 0, 1) == '?') { | ||||
|                     $code = substr($code, 0, strlen($code) - 1) . '<<?php ?>?' . substr($subtree, 1); | ||||
|                 } elseif ($this->parser->asp_tags && substr($subtree, 0, 1) == '%') { | ||||
|                     $code = substr($code, 0, strlen($code) - 1) . '<<?php ?>%' . substr($subtree, 1); | ||||
|                 } else { | ||||
|                     $code .= $subtree; | ||||
|                 } | ||||
|                 continue; | ||||
|             } | ||||
|             if ($this->parser->asp_tags && substr($code, - 1) == '%') { | ||||
|                 $subtree = $this->subtrees[$key]->to_smarty_php(); | ||||
|                 if (substr($subtree, 0, 1) == '>') { | ||||
|                     $code = substr($code, 0, strlen($code) - 1) . '%<?php ?>>' . substr($subtree, 1); | ||||
|                 } else { | ||||
|                     $code .= $subtree; | ||||
|                 } | ||||
|                 continue; | ||||
|             } | ||||
|             if (substr($code, - 1) == '?') { | ||||
|                 $subtree = $this->subtrees[$key]->to_smarty_php(); | ||||
|                 if (substr($subtree, 0, 1) == '>') { | ||||
|                     $code = substr($code, 0, strlen($code) - 1) . '?<?php ?>>' . substr($subtree, 1); | ||||
|                 } else { | ||||
|                     $code .= $subtree; | ||||
|                 } | ||||
|                 continue; | ||||
|             } | ||||
|             $code .= $this->subtrees[$key]->to_smarty_php(); | ||||
|         } | ||||
|  | ||||
|         return $code; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * template text | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_text extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Create template text buffer | ||||
|      * | ||||
|      * @param object $parser parser object | ||||
|      * @param string $data   text | ||||
|      */ | ||||
|     public function __construct($parser, $data) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->data = $data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return buffer content | ||||
|      * | ||||
|      * @return strint text | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         return $this->data; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * template linebreaks | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @ignore | ||||
|  */ | ||||
| class _smarty_linebreak extends _smarty_parsetree | ||||
| { | ||||
|     /** | ||||
|      * Create buffer with linebreak content | ||||
|      * | ||||
|      * @param object $parser parser object | ||||
|      * @param string $data   linebreak string | ||||
|      */ | ||||
|     public function __construct($parser, $data) | ||||
|     { | ||||
|         $this->parser = $parser; | ||||
|         $this->data = $data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return linebrak | ||||
|      * | ||||
|      * @return string linebreak | ||||
|      */ | ||||
|     public function to_smarty_php() | ||||
|     { | ||||
|         return $this->data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,96 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Eval | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Eval | ||||
|  * Implements the strings as resource for Smarty template | ||||
|  * {@internal unlike string-resources the compiled state of eval-resources is NOT saved for subsequent access}} | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| class Smarty_Internal_Resource_Eval extends Smarty_Resource_Recompiled | ||||
| { | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->uid = $source->filepath = sha1($source->name); | ||||
|         $source->timestamp = false; | ||||
|         $source->exists = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from $resource_name into current template object | ||||
|      * | ||||
|      * @uses decode() to decode base64 and urlencoded template_resources | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return $this->decode($source->name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * decode base64 and urlencode | ||||
|      * | ||||
|      * @param  string $string template_resource to decode | ||||
|      * | ||||
|      * @return string decoded template_resource | ||||
|      */ | ||||
|     protected function decode($string) | ||||
|     { | ||||
|         // decode if specified | ||||
|         if (($pos = strpos($string, ':')) !== false) { | ||||
|             if (!strncmp($string, 'base64', 6)) { | ||||
|                 return base64_decode(substr($string, 7)); | ||||
|             } elseif (!strncmp($string, 'urlencode', 9)) { | ||||
|                 return urldecode(substr($string, 10)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $string; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * modify resource_name according to resource handlers specifications | ||||
|      * | ||||
|      * @param  Smarty  $smarty        Smarty instance | ||||
|      * @param  string  $resource_name resource_name to make unique | ||||
|      * @param  boolean $is_config     flag for config resource | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|     protected function buildUniqueResourceName(Smarty $smarty, $resource_name, $is_config = false) | ||||
|     { | ||||
|         return get_class($this) . '#' . $this->decode($resource_name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     protected function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return ''; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,112 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Extends | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Extends | ||||
|  * Implements the file system as resource for Smarty which {extend}s a chain of template files templates | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| class Smarty_Internal_Resource_Extends extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * mbstring.overload flag | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $mbstring_overload = 0; | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source   $source    source object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $uid = ''; | ||||
|         $sources = array(); | ||||
|         $components = explode('|', $source->name); | ||||
|         $exists = true; | ||||
|         foreach ($components as $component) { | ||||
|             $s = Smarty_Resource::source(null, $source->smarty, $component); | ||||
|             if ($s->type == 'php') { | ||||
|                 throw new SmartyException("Resource type {$s->type} cannot be used with the extends resource type"); | ||||
|             } | ||||
|             $sources[$s->uid] = $s; | ||||
|             $uid .= $s->filepath; | ||||
|             if ($_template && $_template->smarty->compile_check) { | ||||
|                 $exists = $exists && $s->exists; | ||||
|             } | ||||
|         } | ||||
|         $source->components = $sources; | ||||
|         $source->filepath = $s->filepath; | ||||
|         $source->uid = sha1(realpath($uid)); | ||||
|         if ($_template && $_template->smarty->compile_check) { | ||||
|             $source->timestamp = $s->timestamp; | ||||
|             $source->exists = $exists; | ||||
|         } | ||||
|         // need the template at getContent() | ||||
|         $source->template = $_template; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $source->exists = true; | ||||
|         foreach ($source->components as $s) { | ||||
|             $source->exists = $source->exists && $s->exists; | ||||
|         } | ||||
|         $source->timestamp = $s->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from files into current template object | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string template source | ||||
|      * @throws SmartyException if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         if (!$source->exists) { | ||||
|             throw new SmartyException("Unable to read template {$source->type} '{$source->name}'"); | ||||
|         } | ||||
|  | ||||
|         $_components = array_reverse($source->components); | ||||
|  | ||||
|         $_content = ''; | ||||
|         foreach ($_components as $_component) { | ||||
|             // read content | ||||
|             $_content .= $_component->content; | ||||
|         } | ||||
|         return $_content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string resource's basename | ||||
|      */ | ||||
|     public function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return str_replace(':', '.', basename($source->filepath)); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,89 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource File | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource File | ||||
|  * Implements the file system as resource for Smarty templates | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| class Smarty_Internal_Resource_File extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source   $source    source object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->filepath = $this->buildFilepath($source, $_template); | ||||
|  | ||||
|         if ($source->filepath !== false) { | ||||
|             if (is_object($source->smarty->security_policy)) { | ||||
|                 $source->smarty->security_policy->isTrustedResourceDir($source->filepath); | ||||
|             } | ||||
|  | ||||
|             $source->uid = sha1(realpath($source->filepath)); | ||||
|             if ($source->smarty->compile_check && !isset($source->timestamp)) { | ||||
|                 $source->timestamp = @filemtime($source->filepath); | ||||
|                 $source->exists = !!$source->timestamp; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $source->timestamp = @filemtime($source->filepath); | ||||
|         $source->exists = !!$source->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from file into current template object | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      * @throws SmartyException        if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         if ($source->timestamp) { | ||||
|             return file_get_contents($source->filepath); | ||||
|         } | ||||
|         if ($source instanceof Smarty_Config_Source) { | ||||
|             throw new SmartyException("Unable to read config {$source->type} '{$source->name}'"); | ||||
|         } | ||||
|         throw new SmartyException("Unable to read template {$source->type} '{$source->name}'"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     public function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $_file = $source->name; | ||||
|         if (($_pos = strpos($_file, ']')) !== false) { | ||||
|             $_file = substr($_file, $_pos + 1); | ||||
|         } | ||||
|  | ||||
|         return basename($_file); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,119 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource PHP | ||||
|  * Implements the file system as resource for PHP templates | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| class Smarty_Internal_Resource_PHP extends Smarty_Resource_Uncompiled | ||||
| { | ||||
|     /** | ||||
|      * container for short_open_tag directive's value before executing PHP templates | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $short_open_tag; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHP Resource | ||||
|  | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         $this->short_open_tag = ini_get('short_open_tag'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->filepath = $this->buildFilepath($source, $_template); | ||||
|  | ||||
|         if ($source->filepath !== false) { | ||||
|             if (is_object($source->smarty->security_policy)) { | ||||
|                 $source->smarty->security_policy->isTrustedResourceDir($source->filepath); | ||||
|             } | ||||
|  | ||||
|             $source->uid = sha1($source->filepath); | ||||
|             if ($source->smarty->compile_check) { | ||||
|                 $source->timestamp = @filemtime($source->filepath); | ||||
|                 $source->exists = !!$source->timestamp; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $source->timestamp = @filemtime($source->filepath); | ||||
|         $source->exists = !!$source->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from file into current template object | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      * @throws SmartyException        if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         if ($source->timestamp) { | ||||
|             return ''; | ||||
|         } | ||||
|         throw new SmartyException("Unable to read template {$source->type} '{$source->name}'"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render and output the template (without using the compiler) | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      * @throws SmartyException          if template cannot be loaded or allow_php_templates is disabled | ||||
|      */ | ||||
|     public function renderUncompiled(Smarty_Template_Source $source, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         if (!$source->smarty->allow_php_templates) { | ||||
|             throw new SmartyException("PHP templates are disabled"); | ||||
|         } | ||||
|         if (!$source->exists) { | ||||
|             if ($_template->parent instanceof Smarty_Internal_Template) { | ||||
|                 $parent_resource = " in '{$_template->parent->template_resource}'"; | ||||
|             } else { | ||||
|                 $parent_resource = ''; | ||||
|             } | ||||
|             throw new SmartyException("Unable to load template {$source->type} '{$source->name}'{$parent_resource}"); | ||||
|         } | ||||
|  | ||||
|         // prepare variables | ||||
|         extract($_template->getTemplateVars()); | ||||
|  | ||||
|         // include PHP template with short open tags enabled | ||||
|         ini_set('short_open_tag', '1'); | ||||
|         /** @var Smarty_Internal_Template $_smarty_template | ||||
|          * used in included file | ||||
|          */ | ||||
|         $_smarty_template = $_template; | ||||
|         include($source->filepath); | ||||
|         ini_set('short_open_tag', $this->short_open_tag); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,98 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Registered | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Registered | ||||
|  * Implements the registered resource for Smarty template | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @deprecated | ||||
|  */ | ||||
| class Smarty_Internal_Resource_Registered extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->filepath = $source->type . ':' . $source->name; | ||||
|         $source->uid = sha1($source->filepath); | ||||
|         if ($source->smarty->compile_check) { | ||||
|             $source->timestamp = $this->getTemplateTimestamp($source); | ||||
|             $source->exists = !!$source->timestamp; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $source->timestamp = $this->getTemplateTimestamp($source); | ||||
|         $source->exists = !!$source->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get timestamp (epoch) the template source was modified | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return integer|boolean        timestamp (epoch) the template was modified, false if resources has no timestamp | ||||
|      */ | ||||
|     public function getTemplateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         // return timestamp | ||||
|         $time_stamp = false; | ||||
|         call_user_func_array($source->smarty->registered_resources[$source->type][0][1], array($source->name, &$time_stamp, $source->smarty)); | ||||
|  | ||||
|         return is_numeric($time_stamp) ? (int) $time_stamp : $time_stamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source by invoking the registered callback into current template object | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      * @throws SmartyException        if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         // return template string | ||||
|         $t = call_user_func_array($source->smarty->registered_resources[$source->type][0][0], array($source->name, &$source->content, $source->smarty)); | ||||
|         if (is_bool($t) && !$t) { | ||||
|             throw new SmartyException("Unable to read template {$source->type} '{$source->name}'"); | ||||
|         } | ||||
|  | ||||
|         return $source->content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     protected function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return basename($source->name); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,81 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Stream | ||||
|  * Implements the streams as resource for Smarty template | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource Stream | ||||
|  * Implements the streams as resource for Smarty template | ||||
|  * | ||||
|  * @link       http://php.net/streams | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| class Smarty_Internal_Resource_Stream extends Smarty_Resource_Recompiled | ||||
| { | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source   $source    source object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         if (strpos($source->resource, '://') !== false) { | ||||
|             $source->filepath = $source->resource; | ||||
|         } else { | ||||
|             $source->filepath = str_replace(':', '://', $source->resource); | ||||
|         } | ||||
|         $source->uid = false; | ||||
|         $source->content = $this->getContent($source); | ||||
|         $source->timestamp = false; | ||||
|         $source->exists = !!$source->content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from stream into current template object | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string template source | ||||
|      * @throws SmartyException if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $t = ''; | ||||
|         // the availability of the stream has already been checked in Smarty_Resource::fetch() | ||||
|         $fp = fopen($source->filepath, 'r+'); | ||||
|         if ($fp) { | ||||
|             while (!feof($fp) && ($current_line = fgets($fp)) !== false) { | ||||
|                 $t .= $current_line; | ||||
|             } | ||||
|             fclose($fp); | ||||
|  | ||||
|             return $t; | ||||
|         } else { | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * modify resource_name according to resource handlers specifications | ||||
|      * | ||||
|      * @param Smarty   $smarty        Smarty instance | ||||
|      * @param string   $resource_name resource_name to make unique | ||||
|      * @param  boolean $is_config     flag for config resource | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|     protected function buildUniqueResourceName(Smarty $smarty, $resource_name, $is_config = false) | ||||
|     { | ||||
|         return get_class($this) . '#' . $resource_name; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,97 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource String | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Uwe Tews | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Resource String | ||||
|  * Implements the strings as resource for Smarty template | ||||
|  * {@internal unlike eval-resources the compiled state of string-resources is saved for subsequent access}} | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| class Smarty_Internal_Resource_String extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->uid = $source->filepath = sha1($source->name); | ||||
|         $source->timestamp = 0; | ||||
|         $source->exists = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source from $resource_name into current template object | ||||
|      * | ||||
|      * @uses decode() to decode base64 and urlencoded template_resources | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return $this->decode($source->name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * decode base64 and urlencode | ||||
|      * | ||||
|      * @param  string $string template_resource to decode | ||||
|      * | ||||
|      * @return string decoded template_resource | ||||
|      */ | ||||
|     protected function decode($string) | ||||
|     { | ||||
|         // decode if specified | ||||
|         if (($pos = strpos($string, ':')) !== false) { | ||||
|             if (!strncmp($string, 'base64', 6)) { | ||||
|                 return base64_decode(substr($string, 7)); | ||||
|             } elseif (!strncmp($string, 'urlencode', 9)) { | ||||
|                 return urldecode(substr($string, 10)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $string; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * modify resource_name according to resource handlers specifications | ||||
|      * | ||||
|      * @param  Smarty  $smarty        Smarty instance | ||||
|      * @param  string  $resource_name resource_name to make unique | ||||
|      * @param  boolean $is_config     flag for config resource | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|     protected function buildUniqueResourceName(Smarty $smarty, $resource_name, $is_config = false) | ||||
|     { | ||||
|         return get_class($this) . '#' . $this->decode($resource_name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * Always returns an empty string. | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     protected function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return ''; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,140 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Smarty Template Compiler Base | ||||
|  * This file contains the basic classes and methods for compiling Smarty templates with lexer/parser | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * @ignore | ||||
|  */ | ||||
| include 'smarty_internal_parsetree.php'; | ||||
|  | ||||
| /** | ||||
|  * Class SmartyTemplateCompiler | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCompilerBase | ||||
| { | ||||
|     /** | ||||
|      * Lexer class name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $lexer_class; | ||||
|  | ||||
|     /** | ||||
|      * Parser class name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $parser_class; | ||||
|  | ||||
|     /** | ||||
|      * Lexer object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $lex; | ||||
|  | ||||
|     /** | ||||
|      * Parser object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $parser; | ||||
|  | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     public $smarty; | ||||
|  | ||||
|     /** | ||||
|      * array of vars which can be compiled in local scope | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $local_var = array(); | ||||
|  | ||||
|     /** | ||||
|      * Initialize compiler | ||||
|      * | ||||
|      * @param string $lexer_class  class name | ||||
|      * @param string $parser_class class name | ||||
|      * @param Smarty $smarty       global instance | ||||
|      */ | ||||
|     public function __construct($lexer_class, $parser_class, $smarty) | ||||
|     { | ||||
|         $this->smarty = $smarty; | ||||
|         parent::__construct(); | ||||
|         // get required plugins | ||||
|         $this->lexer_class = $lexer_class; | ||||
|         $this->parser_class = $parser_class; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * method to compile a Smarty template | ||||
|      * | ||||
|      * @param  mixed $_content template source | ||||
|      * | ||||
|      * @return bool  true if compiling succeeded, false if it failed | ||||
|      */ | ||||
|     protected function doCompile($_content) | ||||
|     { | ||||
|         /* here is where the compiling takes place. Smarty | ||||
|           tags in the templates are replaces with PHP code, | ||||
|           then written to compiled files. */ | ||||
|         // init the lexer/parser to compile the template | ||||
|         $this->lex = new $this->lexer_class($_content, $this); | ||||
|         $this->parser = new $this->parser_class($this->lex, $this); | ||||
|         if ($this->inheritance_child) { | ||||
|             // start state on child templates | ||||
|             $this->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY); | ||||
|         } | ||||
|         if (function_exists('mb_internal_encoding') && ((int) ini_get('mbstring.func_overload')) & 2) { | ||||
|             $mbEncoding = mb_internal_encoding(); | ||||
|             mb_internal_encoding('ASCII'); | ||||
|         } else { | ||||
|             $mbEncoding = null; | ||||
|         } | ||||
|  | ||||
|         if ($this->smarty->_parserdebug) { | ||||
|             $this->parser->PrintTrace(); | ||||
|             $this->lex->PrintTrace(); | ||||
|         } | ||||
|         // get tokens from lexer and parse them | ||||
|         while ($this->lex->yylex() && !$this->abort_and_recompile) { | ||||
|             if ($this->smarty->_parserdebug) { | ||||
|                 echo "<pre>Line {$this->lex->line} Parsing  {$this->parser->yyTokenName[$this->lex->token]} Token " . | ||||
|                     htmlentities($this->lex->value) . "</pre>"; | ||||
|             } | ||||
|             $this->parser->doParse($this->lex->token, $this->lex->value); | ||||
|         } | ||||
|  | ||||
|         if ($this->abort_and_recompile) { | ||||
|             // exit here on abort | ||||
|             return false; | ||||
|         } | ||||
|         // finish parsing process | ||||
|         $this->parser->doParse(0, 0); | ||||
|         if ($mbEncoding) { | ||||
|             mb_internal_encoding($mbEncoding); | ||||
|         } | ||||
|         // check for unclosed tags | ||||
|         if (count($this->_tag_stack) > 0) { | ||||
|             // get stacked info | ||||
|             list($openTag, $_data) = array_pop($this->_tag_stack); | ||||
|             $this->trigger_template_error("unclosed {$this->smarty->left_delimiter}" . $openTag . "{$this->smarty->right_delimiter} tag"); | ||||
|         } | ||||
|         // return compiled code | ||||
|         // return str_replace(array("? >\n<?php","? ><?php"), array('',''), $this->parser->retvalue); | ||||
|         return $this->parser->retvalue; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										737
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_template.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										737
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_template.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,737 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Template | ||||
|  * This file contains the Smarty template engine | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Main class with template data structures and methods | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  * @property Smarty_Template_Source   $source | ||||
|  * @property Smarty_Template_Compiled $compiled | ||||
|  * @property Smarty_Template_Cached   $cached | ||||
|  */ | ||||
| class Smarty_Internal_Template extends Smarty_Internal_TemplateBase | ||||
| { | ||||
|     /** | ||||
|      * cache_id | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $cache_id = null; | ||||
|     /** | ||||
|      * $compile_id | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compile_id = null; | ||||
|     /** | ||||
|      * caching enabled | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $caching = null; | ||||
|     /** | ||||
|      * cache lifetime in seconds | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $cache_lifetime = null; | ||||
|     /** | ||||
|      * Template resource | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_resource = null; | ||||
|     /** | ||||
|      * flag if compiled template is invalid and must be (re)compiled | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $mustCompile = null; | ||||
|     /** | ||||
|      * flag if template does contain nocache code sections | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $has_nocache_code = false; | ||||
|     /** | ||||
|      * special compiled and cached template properties | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $properties = array('file_dependency' => array(), | ||||
|                                'nocache_hash'    => '', | ||||
|                                'function'        => array()); | ||||
|     /** | ||||
|      * required plugins | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $required_plugins = array('compiled' => array(), 'nocache' => array()); | ||||
|     /** | ||||
|      * Global smarty instance | ||||
|      * | ||||
|      * @var Smarty | ||||
|      */ | ||||
|     public $smarty = null; | ||||
|     /** | ||||
|      * blocks for template inheritance | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $block_data = array(); | ||||
|     /** | ||||
|      * variable filters | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $variable_filters = array(); | ||||
|     /** | ||||
|      * optional log of tag/attributes | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $used_tags = array(); | ||||
|     /** | ||||
|      * internal flag to allow relative path in child template blocks | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $allow_relative_path = false; | ||||
|     /** | ||||
|      * internal capture runtime stack | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $_capture_stack = array(0 => array()); | ||||
|  | ||||
|     /** | ||||
|      * Create template data object | ||||
|      * Some of the global Smarty settings copied to template scope | ||||
|      * It load the required template resources and cacher plugins | ||||
|      * | ||||
|      * @param string                   $template_resource template resource string | ||||
|      * @param Smarty                   $smarty            Smarty instance | ||||
|      * @param Smarty_Internal_Template $_parent           back pointer to parent object with variables or null | ||||
|      * @param mixed                    $_cache_id         cache   id or null | ||||
|      * @param mixed                    $_compile_id       compile id or null | ||||
|      * @param bool                     $_caching          use caching? | ||||
|      * @param int                      $_cache_lifetime   cache life-time in seconds | ||||
|      */ | ||||
|     public function __construct($template_resource, $smarty, $_parent = null, $_cache_id = null, $_compile_id = null, $_caching = null, $_cache_lifetime = null) | ||||
|     { | ||||
|         $this->smarty = & $smarty; | ||||
|         // Smarty parameter | ||||
|         $this->cache_id = $_cache_id === null ? $this->smarty->cache_id : $_cache_id; | ||||
|         $this->compile_id = $_compile_id === null ? $this->smarty->compile_id : $_compile_id; | ||||
|         $this->caching = $_caching === null ? $this->smarty->caching : $_caching; | ||||
|         if ($this->caching === true) { | ||||
|             $this->caching = Smarty::CACHING_LIFETIME_CURRENT; | ||||
|         } | ||||
|         $this->cache_lifetime = $_cache_lifetime === null ? $this->smarty->cache_lifetime : $_cache_lifetime; | ||||
|         $this->parent = $_parent; | ||||
|         // Template resource | ||||
|         $this->template_resource = $template_resource; | ||||
|         // copy block data of template inheritance | ||||
|         if ($this->parent instanceof Smarty_Internal_Template) { | ||||
|             $this->block_data = $this->parent->block_data; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns if the current template must be compiled by the Smarty compiler | ||||
|      * It does compare the timestamps of template source and the compiled templates and checks the force compile configuration | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return boolean true if the template must be compiled | ||||
|      */ | ||||
|     public function mustCompile() | ||||
|     { | ||||
|         if (!$this->source->exists) { | ||||
|             if ($this->parent instanceof Smarty_Internal_Template) { | ||||
|                 $parent_resource = " in '$this->parent->template_resource}'"; | ||||
|             } else { | ||||
|                 $parent_resource = ''; | ||||
|             } | ||||
|             throw new SmartyException("Unable to load template {$this->source->type} '{$this->source->name}'{$parent_resource}"); | ||||
|         } | ||||
|         if ($this->mustCompile === null) { | ||||
|             $this->mustCompile = (!$this->source->uncompiled && ($this->smarty->force_compile || $this->source->recompiled || $this->compiled->timestamp === false || | ||||
|                     ($this->smarty->compile_check && $this->compiled->timestamp < $this->source->timestamp))); | ||||
|         } | ||||
|  | ||||
|         return $this->mustCompile; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiles the template | ||||
|      * If the template is not evaluated the compiled template is saved on disk | ||||
|      */ | ||||
|     public function compileTemplateSource() | ||||
|     { | ||||
|         if (!$this->source->recompiled) { | ||||
|             $this->properties['file_dependency'] = array(); | ||||
|             if ($this->source->components) { | ||||
|                 // for the extends resource the compiler will fill it | ||||
|                 // uses real resource for file dependency | ||||
|                 // $source = end($this->source->components); | ||||
|                 // $this->properties['file_dependency'][$this->source->uid] = array($this->source->filepath, $this->source->timestamp, $source->type); | ||||
|             } else { | ||||
|                 $this->properties['file_dependency'][$this->source->uid] = array($this->source->filepath, $this->source->timestamp, $this->source->type); | ||||
|             } | ||||
|         } | ||||
|         // compile locking | ||||
|         if ($this->smarty->compile_locking && !$this->source->recompiled) { | ||||
|             if ($saved_timestamp = $this->compiled->timestamp) { | ||||
|                 touch($this->compiled->filepath); | ||||
|             } | ||||
|         } | ||||
|         // call compiler | ||||
|         try { | ||||
|             $code = $this->compiler->compileTemplate($this); | ||||
|         } | ||||
|         catch (Exception $e) { | ||||
|             // restore old timestamp in case of error | ||||
|             if ($this->smarty->compile_locking && !$this->source->recompiled && $saved_timestamp) { | ||||
|                 touch($this->compiled->filepath, $saved_timestamp); | ||||
|             } | ||||
|             throw $e; | ||||
|         } | ||||
|         // compiling succeded | ||||
|         if (!$this->source->recompiled && $this->compiler->write_compiled_code) { | ||||
|             // write compiled template | ||||
|             $_filepath = $this->compiled->filepath; | ||||
|             if ($_filepath === false) { | ||||
|                 throw new SmartyException('getCompiledFilepath() did not return a destination to save the compiled template to'); | ||||
|             } | ||||
|             Smarty_Internal_Write_File::writeFile($_filepath, $code, $this->smarty); | ||||
|             $this->compiled->exists = true; | ||||
|             $this->compiled->isCompiled = true; | ||||
|         } | ||||
|         // release compiler object to free memory | ||||
|         unset($this->compiler); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Writes the cached template output | ||||
|      * | ||||
|      * @param string $content | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function writeCachedContent($content) | ||||
|     { | ||||
|         if ($this->source->recompiled || !($this->caching == Smarty::CACHING_LIFETIME_CURRENT || $this->caching == Smarty::CACHING_LIFETIME_SAVED)) { | ||||
|             // don't write cache file | ||||
|             return false; | ||||
|         } | ||||
|         $this->properties['cache_lifetime'] = $this->cache_lifetime; | ||||
|         $this->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true)); | ||||
|         $content = $this->createTemplateCodeFrame($content, true); | ||||
|         /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|          * used in evaluated code | ||||
|          */ | ||||
|         $_smarty_tpl = $this; | ||||
|         eval("?>" . $content); | ||||
|         $this->cached->valid = true; | ||||
|         $this->cached->processed = true; | ||||
|  | ||||
|         return $this->cached->write($this, $content); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Template code runtime function to get subtemplate content | ||||
|      * | ||||
|      * @param string  $template       the resource handle of the template file | ||||
|      * @param mixed   $cache_id       cache id to be used with this template | ||||
|      * @param mixed   $compile_id     compile id to be used with this template | ||||
|      * @param integer $caching        cache mode | ||||
|      * @param integer $cache_lifetime life time of cache data | ||||
|      * @param         $data | ||||
|      * @param int     $parent_scope   scope in which {include} should execute | ||||
|      * | ||||
|      * @returns string template content | ||||
|      */ | ||||
|     public function getSubTemplate($template, $cache_id, $compile_id, $caching, $cache_lifetime, $data, $parent_scope) | ||||
|     { | ||||
|         // already in template cache? | ||||
|         if ($this->smarty->allow_ambiguous_resources) { | ||||
|             $_templateId = Smarty_Resource::getUniqueTemplateName($this, $template) . $cache_id . $compile_id; | ||||
|         } else { | ||||
|             $_templateId = $this->smarty->joined_template_dir . '#' . $template . $cache_id . $compile_id; | ||||
|         } | ||||
|  | ||||
|         if (isset($_templateId[150])) { | ||||
|             $_templateId = sha1($_templateId); | ||||
|         } | ||||
|         if (isset($this->smarty->template_objects[$_templateId])) { | ||||
|             // clone cached template object because of possible recursive call | ||||
|             $tpl = clone $this->smarty->template_objects[$_templateId]; | ||||
|             $tpl->parent = $this; | ||||
|             $tpl->caching = $caching; | ||||
|             $tpl->cache_lifetime = $cache_lifetime; | ||||
|         } else { | ||||
|             $tpl = new $this->smarty->template_class($template, $this->smarty, $this, $cache_id, $compile_id, $caching, $cache_lifetime); | ||||
|         } | ||||
|         // get variables from calling scope | ||||
|         if ($parent_scope == Smarty::SCOPE_LOCAL) { | ||||
|             $tpl->tpl_vars = $this->tpl_vars; | ||||
|             $tpl->tpl_vars['smarty'] = clone $this->tpl_vars['smarty']; | ||||
|         } elseif ($parent_scope == Smarty::SCOPE_PARENT) { | ||||
|             $tpl->tpl_vars = & $this->tpl_vars; | ||||
|         } elseif ($parent_scope == Smarty::SCOPE_GLOBAL) { | ||||
|             $tpl->tpl_vars = & Smarty::$global_tpl_vars; | ||||
|         } elseif (($scope_ptr = $this->getScopePointer($parent_scope)) == null) { | ||||
|             $tpl->tpl_vars = & $this->tpl_vars; | ||||
|         } else { | ||||
|             $tpl->tpl_vars = & $scope_ptr->tpl_vars; | ||||
|         } | ||||
|         $tpl->config_vars = $this->config_vars; | ||||
|         if (!empty($data)) { | ||||
|             // set up variable values | ||||
|             foreach ($data as $_key => $_val) { | ||||
|                 $tpl->tpl_vars[$_key] = new Smarty_variable($_val); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $tpl->fetch(null, null, null, null, false, false, true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Template code runtime function to set up an inline subtemplate | ||||
|      * | ||||
|      * @param string  $template       the resource handle of the template file | ||||
|      * @param mixed   $cache_id       cache id to be used with this template | ||||
|      * @param mixed   $compile_id     compile id to be used with this template | ||||
|      * @param integer $caching        cache mode | ||||
|      * @param integer $cache_lifetime life time of cache data | ||||
|      * @param         $data | ||||
|      * @param int     $parent_scope   scope in which {include} should execute | ||||
|      * @param string  $hash           nocache hash code | ||||
|      * | ||||
|      * @returns string template content | ||||
|      */ | ||||
|     public function setupInlineSubTemplate($template, $cache_id, $compile_id, $caching, $cache_lifetime, $data, $parent_scope, $hash) | ||||
|     { | ||||
|         $tpl = new $this->smarty->template_class($template, $this->smarty, $this, $cache_id, $compile_id, $caching, $cache_lifetime); | ||||
|         $tpl->properties['nocache_hash'] = $hash; | ||||
|         // get variables from calling scope | ||||
|         if ($parent_scope == Smarty::SCOPE_LOCAL) { | ||||
|             $tpl->tpl_vars = $this->tpl_vars; | ||||
|             $tpl->tpl_vars['smarty'] = clone $this->tpl_vars['smarty']; | ||||
|         } elseif ($parent_scope == Smarty::SCOPE_PARENT) { | ||||
|             $tpl->tpl_vars = & $this->tpl_vars; | ||||
|         } elseif ($parent_scope == Smarty::SCOPE_GLOBAL) { | ||||
|             $tpl->tpl_vars = & Smarty::$global_tpl_vars; | ||||
|         } elseif (($scope_ptr = $this->getScopePointer($parent_scope)) == null) { | ||||
|             $tpl->tpl_vars = & $this->tpl_vars; | ||||
|         } else { | ||||
|             $tpl->tpl_vars = & $scope_ptr->tpl_vars; | ||||
|         } | ||||
|         $tpl->config_vars = $this->config_vars; | ||||
|         if (!empty($data)) { | ||||
|             // set up variable values | ||||
|             foreach ($data as $_key => $_val) { | ||||
|                 $tpl->tpl_vars[$_key] = new Smarty_variable($_val); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $tpl; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create code frame for compiled and cached templates | ||||
|      * | ||||
|      * @param  string $content optional template content | ||||
|      * @param  bool   $cache   flag for cache file | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function createTemplateCodeFrame($content = '', $cache = false) | ||||
|     { | ||||
|         $plugins_string = ''; | ||||
|         // include code for plugins | ||||
|         if (!$cache) { | ||||
|             if (!empty($this->required_plugins['compiled'])) { | ||||
|                 $plugins_string = '<?php '; | ||||
|                 foreach ($this->required_plugins['compiled'] as $tmp) { | ||||
|                     foreach ($tmp as $data) { | ||||
|                         $file = addslashes($data['file']); | ||||
|                         if (is_Array($data['function'])) { | ||||
|                             $plugins_string .= "if (!is_callable(array('{$data['function'][0]}','{$data['function'][1]}'))) include '{$file}';\n"; | ||||
|                         } else { | ||||
|                             $plugins_string .= "if (!is_callable('{$data['function']}')) include '{$file}';\n"; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 $plugins_string .= '?>'; | ||||
|             } | ||||
|             if (!empty($this->required_plugins['nocache'])) { | ||||
|                 $this->has_nocache_code = true; | ||||
|                 $plugins_string .= "<?php echo '/*%%SmartyNocache:{$this->properties['nocache_hash']}%%*/<?php \$_smarty = \$_smarty_tpl->smarty; "; | ||||
|                 foreach ($this->required_plugins['nocache'] as $tmp) { | ||||
|                     foreach ($tmp as $data) { | ||||
|                         $file = addslashes($data['file']); | ||||
|                         if (is_Array($data['function'])) { | ||||
|                             $plugins_string .= addslashes("if (!is_callable(array('{$data['function'][0]}','{$data['function'][1]}'))) include '{$file}';\n"); | ||||
|                         } else { | ||||
|                             $plugins_string .= addslashes("if (!is_callable('{$data['function']}')) include '{$file}';\n"); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 $plugins_string .= "?>/*/%%SmartyNocache:{$this->properties['nocache_hash']}%%*/';?>\n"; | ||||
|             } | ||||
|         } | ||||
|         // build property code | ||||
|         $this->properties['has_nocache_code'] = $this->has_nocache_code; | ||||
|         $output = ''; | ||||
|         if (!$this->source->recompiled) { | ||||
|             $output = "<?php /*%%SmartyHeaderCode:{$this->properties['nocache_hash']}%%*/"; | ||||
|             if ($this->smarty->direct_access_security) { | ||||
|                 $output .= "if(!defined('SMARTY_DIR')) exit('no direct access allowed');\n"; | ||||
|             } | ||||
|         } | ||||
|         if ($cache) { | ||||
|             // remove compiled code of{function} definition | ||||
|             unset($this->properties['function']); | ||||
|             if (!empty($this->smarty->template_functions)) { | ||||
|                 // copy code of {function} tags called in nocache mode | ||||
|                 foreach ($this->smarty->template_functions as $name => $function_data) { | ||||
|                     if (isset($function_data['called_nocache'])) { | ||||
|                         foreach ($function_data['called_functions'] as $func_name) { | ||||
|                             $this->smarty->template_functions[$func_name]['called_nocache'] = true; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 foreach ($this->smarty->template_functions as $name => $function_data) { | ||||
|                     if (isset($function_data['called_nocache'])) { | ||||
|                         unset($function_data['called_nocache'], $function_data['called_functions'], $this->smarty->template_functions[$name]['called_nocache']); | ||||
|                         $this->properties['function'][$name] = $function_data; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $this->properties['version'] = Smarty::SMARTY_VERSION; | ||||
|         if (!isset($this->properties['unifunc'])) { | ||||
|             $this->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true)); | ||||
|         } | ||||
|         if (!$this->source->recompiled) { | ||||
|             $output .= "\$_valid = \$_smarty_tpl->decodeProperties(" . var_export($this->properties, true) . ',' . ($cache ? 'true' : 'false') . "); /*/%%SmartyHeaderCode%%*/?>\n"; | ||||
|             $output .= '<?php if ($_valid && !is_callable(\'' . $this->properties['unifunc'] . '\')) {function ' . $this->properties['unifunc'] . '($_smarty_tpl) {?>'; | ||||
|         } | ||||
|         $output .= $plugins_string; | ||||
|         $output .= $content; | ||||
|         if (!$this->source->recompiled) { | ||||
|             $output .= "<?php }} ?>\n"; | ||||
|         } | ||||
|  | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * This function is executed automatically when a compiled or cached template file is included | ||||
|      * - Decode saved properties from compiled template and cache files | ||||
|      * - Check if compiled or cache file is valid | ||||
|      * | ||||
|      * @param  array $properties special template properties | ||||
|      * @param  bool  $cache      flag if called from cache file | ||||
|      * | ||||
|      * @return bool  flag if compiled or cache file is valid | ||||
|      */ | ||||
|     public function decodeProperties($properties, $cache = false) | ||||
|     { | ||||
|         $this->has_nocache_code = $properties['has_nocache_code']; | ||||
|         $this->properties['nocache_hash'] = $properties['nocache_hash']; | ||||
|         if (isset($properties['cache_lifetime'])) { | ||||
|             $this->properties['cache_lifetime'] = $properties['cache_lifetime']; | ||||
|         } | ||||
|         if (isset($properties['file_dependency'])) { | ||||
|             $this->properties['file_dependency'] = array_merge($this->properties['file_dependency'], $properties['file_dependency']); | ||||
|         } | ||||
|         if (!empty($properties['function'])) { | ||||
|             $this->properties['function'] = array_merge($this->properties['function'], $properties['function']); | ||||
|             $this->smarty->template_functions = array_merge($this->smarty->template_functions, $properties['function']); | ||||
|         } | ||||
|         $this->properties['version'] = (isset($properties['version'])) ? $properties['version'] : ''; | ||||
|         $this->properties['unifunc'] = $properties['unifunc']; | ||||
|         // check file dependencies at compiled code | ||||
|         $is_valid = true; | ||||
|         if ($this->properties['version'] != Smarty::SMARTY_VERSION) { | ||||
|             $is_valid = false; | ||||
|         } elseif (((!$cache && $this->smarty->compile_check && empty($this->compiled->_properties) && !$this->compiled->isCompiled) || $cache && ($this->smarty->compile_check === true || $this->smarty->compile_check === Smarty::COMPILECHECK_ON)) && !empty($this->properties['file_dependency'])) { | ||||
|             foreach ($this->properties['file_dependency'] as $_file_to_check) { | ||||
|                 if ($_file_to_check[2] == 'file' || $_file_to_check[2] == 'php') { | ||||
|                     if ($this->source->filepath == $_file_to_check[0] && isset($this->source->timestamp)) { | ||||
|                         // do not recheck current template | ||||
|                         $mtime = $this->source->timestamp; | ||||
|                     } else { | ||||
|                         // file and php types can be checked without loading the respective resource handlers | ||||
|                         $mtime = @filemtime($_file_to_check[0]); | ||||
|                     } | ||||
|                 } elseif ($_file_to_check[2] == 'string') { | ||||
|                     continue; | ||||
|                 } else { | ||||
|                     $source = Smarty_Resource::source(null, $this->smarty, $_file_to_check[0]); | ||||
|                     $mtime = $source->timestamp; | ||||
|                 } | ||||
|                 if (!$mtime || $mtime > $_file_to_check[1]) { | ||||
|                     $is_valid = false; | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($cache) { | ||||
|             // CACHING_LIFETIME_SAVED cache expiry has to be validated here since otherwise we'd define the unifunc | ||||
|             if ($this->caching === Smarty::CACHING_LIFETIME_SAVED && | ||||
|                 $this->properties['cache_lifetime'] >= 0 && | ||||
|                 (time() > ($this->cached->timestamp + $this->properties['cache_lifetime'])) | ||||
|             ) { | ||||
|                 $is_valid = false; | ||||
|             } | ||||
|             $this->cached->valid = $is_valid; | ||||
|         } else { | ||||
|             $this->mustCompile = !$is_valid; | ||||
|         } | ||||
|         // store data in reusable Smarty_Template_Compiled | ||||
|         if (!$cache) { | ||||
|             $this->compiled->_properties = $properties; | ||||
|         } | ||||
|  | ||||
|         return $is_valid; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Template code runtime function to create a local Smarty variable for array assignments | ||||
|      * | ||||
|      * @param string $tpl_var tempate variable name | ||||
|      * @param bool   $nocache cache mode of variable | ||||
|      * @param int    $scope   scope of variable | ||||
|      */ | ||||
|     public function createLocalArrayVariable($tpl_var, $nocache = false, $scope = Smarty::SCOPE_LOCAL) | ||||
|     { | ||||
|         if (!isset($this->tpl_vars[$tpl_var])) { | ||||
|             $this->tpl_vars[$tpl_var] = new Smarty_variable(array(), $nocache, $scope); | ||||
|         } else { | ||||
|             $this->tpl_vars[$tpl_var] = clone $this->tpl_vars[$tpl_var]; | ||||
|             if ($scope != Smarty::SCOPE_LOCAL) { | ||||
|                 $this->tpl_vars[$tpl_var]->scope = $scope; | ||||
|             } | ||||
|             if (!(is_array($this->tpl_vars[$tpl_var]->value) || $this->tpl_vars[$tpl_var]->value instanceof ArrayAccess)) { | ||||
|                 settype($this->tpl_vars[$tpl_var]->value, 'array'); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Template code runtime function to get pointer to template variable array of requested scope | ||||
|      * | ||||
|      * @param  int $scope requested variable scope | ||||
|      * | ||||
|      * @return array array of template variables | ||||
|      */ | ||||
|     public function &getScope($scope) | ||||
|     { | ||||
|         if ($scope == Smarty::SCOPE_PARENT && !empty($this->parent)) { | ||||
|             return $this->parent->tpl_vars; | ||||
|         } elseif ($scope == Smarty::SCOPE_ROOT && !empty($this->parent)) { | ||||
|             $ptr = $this->parent; | ||||
|             while (!empty($ptr->parent)) { | ||||
|                 $ptr = $ptr->parent; | ||||
|             } | ||||
|  | ||||
|             return $ptr->tpl_vars; | ||||
|         } elseif ($scope == Smarty::SCOPE_GLOBAL) { | ||||
|             return Smarty::$global_tpl_vars; | ||||
|         } | ||||
|         $null = null; | ||||
|  | ||||
|         return $null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get parent or root of template parent chain | ||||
|      * | ||||
|      * @param  int $scope pqrent or root scope | ||||
|      * | ||||
|      * @return mixed object | ||||
|      */ | ||||
|     public function getScopePointer($scope) | ||||
|     { | ||||
|         if ($scope == Smarty::SCOPE_PARENT && !empty($this->parent)) { | ||||
|             return $this->parent; | ||||
|         } elseif ($scope == Smarty::SCOPE_ROOT && !empty($this->parent)) { | ||||
|             $ptr = $this->parent; | ||||
|             while (!empty($ptr->parent)) { | ||||
|                 $ptr = $ptr->parent; | ||||
|             } | ||||
|  | ||||
|             return $ptr; | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * [util function] counts an array, arrayaccess/traversable or PDOStatement object | ||||
|      * | ||||
|      * @param  mixed $value | ||||
|      * | ||||
|      * @return int   the count for arrays and objects that implement countable, 1 for other objects that don't, and 0 for empty elements | ||||
|      */ | ||||
|     public function _count($value) | ||||
|     { | ||||
|         if (is_array($value) === true || $value instanceof Countable) { | ||||
|             return count($value); | ||||
|         } elseif ($value instanceof IteratorAggregate) { | ||||
|             // Note: getIterator() returns a Traversable, not an Iterator | ||||
|             // thus rewind() and valid() methods may not be present | ||||
|             return iterator_count($value->getIterator()); | ||||
|         } elseif ($value instanceof Iterator) { | ||||
|             return iterator_count($value); | ||||
|         } elseif ($value instanceof PDOStatement) { | ||||
|             return $value->rowCount(); | ||||
|         } elseif ($value instanceof Traversable) { | ||||
|             return iterator_count($value); | ||||
|         } elseif ($value instanceof ArrayAccess) { | ||||
|             if ($value->offsetExists(0)) { | ||||
|                 return 1; | ||||
|             } | ||||
|         } elseif (is_object($value)) { | ||||
|             return count($value); | ||||
|         } | ||||
|  | ||||
|         return 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * runtime error not matching capture tags | ||||
|  | ||||
|      */ | ||||
|     public function capture_error() | ||||
|     { | ||||
|         throw new SmartyException("Not matching {capture} open/close in \"{$this->template_resource}\""); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for this template | ||||
|      * | ||||
|      * @param integer $exp_time expiration time | ||||
|      * | ||||
|      * @return integer number of cache files deleted | ||||
|      */ | ||||
|     public function clearCache($exp_time = null) | ||||
|     { | ||||
|         Smarty_CacheResource::invalidLoadedCache($this->smarty); | ||||
|  | ||||
|         return $this->cached->handler->clear($this->smarty, $this->template_name, $this->cache_id, $this->compile_id, $exp_time); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * set Smarty property in template context | ||||
|      * | ||||
|      * @param string $property_name property name | ||||
|      * @param mixed  $value         value | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function __set($property_name, $value) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'source': | ||||
|             case 'compiled': | ||||
|             case 'cached': | ||||
|             case 'compiler': | ||||
|                 $this->$property_name = $value; | ||||
|  | ||||
|                 return; | ||||
|  | ||||
|             // FIXME: routing of template -> smarty attributes | ||||
|             default: | ||||
|                 if (property_exists($this->smarty, $property_name)) { | ||||
|                     $this->smarty->$property_name = $value; | ||||
|  | ||||
|                     return; | ||||
|                 } | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("invalid template property '$property_name'."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * get Smarty property in template context | ||||
|      * | ||||
|      * @param string $property_name property name | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function __get($property_name) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'source': | ||||
|                 if (strlen($this->template_resource) == 0) { | ||||
|                     throw new SmartyException('Missing template name'); | ||||
|                 } | ||||
|                 $this->source = Smarty_Resource::source($this); | ||||
|                 // cache template object under a unique ID | ||||
|                 // do not cache eval resources | ||||
|                 if ($this->source->type != 'eval') { | ||||
|                     if ($this->smarty->allow_ambiguous_resources) { | ||||
|                         $_templateId = $this->source->unique_resource . $this->cache_id . $this->compile_id; | ||||
|                     } else { | ||||
|                         $_templateId = $this->smarty->joined_template_dir . '#' . $this->template_resource . $this->cache_id . $this->compile_id; | ||||
|                     } | ||||
|  | ||||
|                     if (isset($_templateId[150])) { | ||||
|                         $_templateId = sha1($_templateId); | ||||
|                     } | ||||
|                     $this->smarty->template_objects[$_templateId] = $this; | ||||
|                 } | ||||
|  | ||||
|                 return $this->source; | ||||
|  | ||||
|             case 'compiled': | ||||
|                 $this->compiled = $this->source->getCompiled($this); | ||||
|  | ||||
|                 return $this->compiled; | ||||
|  | ||||
|             case 'cached': | ||||
|                 if (!class_exists('Smarty_Template_Cached')) { | ||||
|                     include SMARTY_SYSPLUGINS_DIR . 'smarty_cacheresource.php'; | ||||
|                 } | ||||
|                 $this->cached = new Smarty_Template_Cached($this); | ||||
|  | ||||
|                 return $this->cached; | ||||
|  | ||||
|             case 'compiler': | ||||
|                 $this->smarty->loadPlugin($this->source->compiler_class); | ||||
|                 $this->compiler = new $this->source->compiler_class($this->source->template_lexer_class, $this->source->template_parser_class, $this->smarty); | ||||
|  | ||||
|                 return $this->compiler; | ||||
|  | ||||
|             // FIXME: routing of template -> smarty attributes | ||||
|             default: | ||||
|                 if (property_exists($this->smarty, $property_name)) { | ||||
|                     return $this->smarty->$property_name; | ||||
|                 } | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("template property '$property_name' does not exist."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Template data object destructor | ||||
|  | ||||
|      */ | ||||
|     public function __destruct() | ||||
|     { | ||||
|         if ($this->smarty->cache_locking && isset($this->cached) && $this->cached->is_locked) { | ||||
|             $this->cached->handler->releaseLock($this->smarty, $this->cached); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,860 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Smarty Template  Base | ||||
|  * This file contains the basic shared methods for template handling | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Class with shared template methods | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  */ | ||||
| abstract class Smarty_Internal_TemplateBase extends Smarty_Internal_Data | ||||
| { | ||||
|     /** | ||||
|      * fetches a rendered Smarty template | ||||
|      * | ||||
|      * @param  string $template         the resource handle of the template file or template object | ||||
|      * @param  mixed  $cache_id         cache id to be used with this template | ||||
|      * @param  mixed  $compile_id       compile id to be used with this template | ||||
|      * @param  object $parent           next higher level of Smarty variables | ||||
|      * @param  bool   $display          true: display, false: fetch | ||||
|      * @param  bool   $merge_tpl_vars   if true parent template variables merged in to local scope | ||||
|      * @param  bool   $no_output_filter if true do not run output filter | ||||
|      * | ||||
|      * @throws Exception | ||||
|      * @throws SmartyException | ||||
|      * @return string rendered template output | ||||
|      */ | ||||
|     public function fetch($template = null, $cache_id = null, $compile_id = null, $parent = null, $display = false, $merge_tpl_vars = true, $no_output_filter = false) | ||||
|     { | ||||
|         if ($template === null && $this instanceof $this->template_class) { | ||||
|             $template = $this; | ||||
|         } | ||||
|         if ($cache_id !== null && is_object($cache_id)) { | ||||
|             $parent = $cache_id; | ||||
|             $cache_id = null; | ||||
|         } | ||||
|         if ($parent === null && ($this instanceof Smarty || is_string($template))) { | ||||
|             $parent = $this; | ||||
|         } | ||||
|         // create template object if necessary | ||||
|         $_template = ($template instanceof $this->template_class) | ||||
|             ? $template | ||||
|             : $this->smarty->createTemplate($template, $cache_id, $compile_id, $parent, false); | ||||
|         // if called by Smarty object make sure we use current caching status | ||||
|         if ($this instanceof Smarty) { | ||||
|             $_template->caching = $this->caching; | ||||
|         } | ||||
|         // merge all variable scopes into template | ||||
|         if ($merge_tpl_vars) { | ||||
|             // save local variables | ||||
|             $save_tpl_vars = $_template->tpl_vars; | ||||
|             $save_config_vars = $_template->config_vars; | ||||
|             $ptr_array = array($_template); | ||||
|             $ptr = $_template; | ||||
|             while (isset($ptr->parent)) { | ||||
|                 $ptr_array[] = $ptr = $ptr->parent; | ||||
|             } | ||||
|             $ptr_array = array_reverse($ptr_array); | ||||
|             $parent_ptr = reset($ptr_array); | ||||
|             $tpl_vars = $parent_ptr->tpl_vars; | ||||
|             $config_vars = $parent_ptr->config_vars; | ||||
|             while ($parent_ptr = next($ptr_array)) { | ||||
|                 if (!empty($parent_ptr->tpl_vars)) { | ||||
|                     $tpl_vars = array_merge($tpl_vars, $parent_ptr->tpl_vars); | ||||
|                 } | ||||
|                 if (!empty($parent_ptr->config_vars)) { | ||||
|                     $config_vars = array_merge($config_vars, $parent_ptr->config_vars); | ||||
|                 } | ||||
|             } | ||||
|             if (!empty(Smarty::$global_tpl_vars)) { | ||||
|                 $tpl_vars = array_merge(Smarty::$global_tpl_vars, $tpl_vars); | ||||
|             } | ||||
|             $_template->tpl_vars = $tpl_vars; | ||||
|             $_template->config_vars = $config_vars; | ||||
|         } | ||||
|         // dummy local smarty variable | ||||
|         if (!isset($_template->tpl_vars['smarty'])) { | ||||
|             $_template->tpl_vars['smarty'] = new Smarty_Variable; | ||||
|         } | ||||
|         if (isset($this->smarty->error_reporting)) { | ||||
|             $_smarty_old_error_level = error_reporting($this->smarty->error_reporting); | ||||
|         } | ||||
|         // check URL debugging control | ||||
|         if (!$this->smarty->debugging && $this->smarty->debugging_ctrl == 'URL') { | ||||
|             if (isset($_SERVER['QUERY_STRING'])) { | ||||
|                 $_query_string = $_SERVER['QUERY_STRING']; | ||||
|             } else { | ||||
|                 $_query_string = ''; | ||||
|             } | ||||
|             if (false !== strpos($_query_string, $this->smarty->smarty_debug_id)) { | ||||
|                 if (false !== strpos($_query_string, $this->smarty->smarty_debug_id . '=on')) { | ||||
|                     // enable debugging for this browser session | ||||
|                     setcookie('SMARTY_DEBUG', true); | ||||
|                     $this->smarty->debugging = true; | ||||
|                 } elseif (false !== strpos($_query_string, $this->smarty->smarty_debug_id . '=off')) { | ||||
|                     // disable debugging for this browser session | ||||
|                     setcookie('SMARTY_DEBUG', false); | ||||
|                     $this->smarty->debugging = false; | ||||
|                 } else { | ||||
|                     // enable debugging for this page | ||||
|                     $this->smarty->debugging = true; | ||||
|                 } | ||||
|             } else { | ||||
|                 if (isset($_COOKIE['SMARTY_DEBUG'])) { | ||||
|                     $this->smarty->debugging = true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // must reset merge template date | ||||
|         $_template->smarty->merged_templates_func = array(); | ||||
|         // get rendered template | ||||
|         // disable caching for evaluated code | ||||
|         if ($_template->source->recompiled) { | ||||
|             $_template->caching = false; | ||||
|         } | ||||
|         // checks if template exists | ||||
|         if (!$_template->source->exists) { | ||||
|             if ($_template->parent instanceof Smarty_Internal_Template) { | ||||
|                 $parent_resource = " in '{$_template->parent->template_resource}'"; | ||||
|             } else { | ||||
|                 $parent_resource = ''; | ||||
|             } | ||||
|             throw new SmartyException("Unable to load template {$_template->source->type} '{$_template->source->name}'{$parent_resource}"); | ||||
|         } | ||||
|         // read from cache or render | ||||
|         if (!($_template->caching == Smarty::CACHING_LIFETIME_CURRENT || $_template->caching == Smarty::CACHING_LIFETIME_SAVED) || !$_template->cached->valid) { | ||||
|             // render template (not loaded and not in cache) | ||||
|             if (!$_template->source->uncompiled) { | ||||
|                 /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|                  * used in evaluated code | ||||
|                  */ | ||||
|                 $_smarty_tpl = $_template; | ||||
|                 if ($_template->source->recompiled) { | ||||
|                     $code = $_template->compiler->compileTemplate($_template); | ||||
|                     if ($this->smarty->debugging) { | ||||
|                         Smarty_Internal_Debug::start_render($_template); | ||||
|                     } | ||||
|                     try { | ||||
|                         ob_start(); | ||||
|                         eval("?>" . $code); | ||||
|                         unset($code); | ||||
|                     } | ||||
|                     catch (Exception $e) { | ||||
|                         ob_get_clean(); | ||||
|                         throw $e; | ||||
|                     } | ||||
|                 } else { | ||||
|                     if (!$_template->compiled->exists || ($_template->smarty->force_compile && !$_template->compiled->isCompiled)) { | ||||
|                         $_template->compileTemplateSource(); | ||||
|                         $code = file_get_contents($_template->compiled->filepath); | ||||
|                         eval("?>" . $code); | ||||
|                         unset($code); | ||||
|                         $_template->compiled->loaded = true; | ||||
|                         $_template->compiled->isCompiled = true; | ||||
|                     } | ||||
|                     if ($this->smarty->debugging) { | ||||
|                         Smarty_Internal_Debug::start_render($_template); | ||||
|                     } | ||||
|                     if (!$_template->compiled->loaded) { | ||||
|                         include($_template->compiled->filepath); | ||||
|                         if ($_template->mustCompile) { | ||||
|                             // recompile and load again | ||||
|                             $_template->compileTemplateSource(); | ||||
|                             $code = file_get_contents($_template->compiled->filepath); | ||||
|                             eval("?>" . $code); | ||||
|                             unset($code); | ||||
|                             $_template->compiled->isCompiled = true; | ||||
|                         } | ||||
|                         $_template->compiled->loaded = true; | ||||
|                     } else { | ||||
|                         $_template->decodeProperties($_template->compiled->_properties, false); | ||||
|                     } | ||||
|                     try { | ||||
|                         ob_start(); | ||||
|                         if (empty($_template->properties['unifunc']) || !is_callable($_template->properties['unifunc'])) { | ||||
|                             throw new SmartyException("Invalid compiled template for '{$_template->template_resource}'"); | ||||
|                         } | ||||
|                         array_unshift($_template->_capture_stack, array()); | ||||
|                         // | ||||
|                         // render compiled template | ||||
|                         // | ||||
|                         $_template->properties['unifunc']($_template); | ||||
|                         // any unclosed {capture} tags ? | ||||
|                         if (isset($_template->_capture_stack[0][0])) { | ||||
|                             $_template->capture_error(); | ||||
|                         } | ||||
|                         array_shift($_template->_capture_stack); | ||||
|                     } | ||||
|                     catch (Exception $e) { | ||||
|                         ob_get_clean(); | ||||
|                         throw $e; | ||||
|                     } | ||||
|                 } | ||||
|             } else { | ||||
|                 if ($_template->source->uncompiled) { | ||||
|                     if ($this->smarty->debugging) { | ||||
|                         Smarty_Internal_Debug::start_render($_template); | ||||
|                     } | ||||
|                     try { | ||||
|                         ob_start(); | ||||
|                         $_template->source->renderUncompiled($_template); | ||||
|                     } | ||||
|                     catch (Exception $e) { | ||||
|                         ob_get_clean(); | ||||
|                         throw $e; | ||||
|                     } | ||||
|                 } else { | ||||
|                     throw new SmartyException("Resource '$_template->source->type' must have 'renderUncompiled' method"); | ||||
|                 } | ||||
|             } | ||||
|             $_output = ob_get_clean(); | ||||
|             if (!$_template->source->recompiled && empty($_template->properties['file_dependency'][$_template->source->uid])) { | ||||
|                 $_template->properties['file_dependency'][$_template->source->uid] = array($_template->source->filepath, $_template->source->timestamp, $_template->source->type); | ||||
|             } | ||||
|             if ($_template->parent instanceof Smarty_Internal_Template) { | ||||
|                 $_template->parent->properties['file_dependency'] = array_merge($_template->parent->properties['file_dependency'], $_template->properties['file_dependency']); | ||||
|                 foreach ($_template->required_plugins as $code => $tmp1) { | ||||
|                     foreach ($tmp1 as $name => $tmp) { | ||||
|                         foreach ($tmp as $type => $data) { | ||||
|                             $_template->parent->required_plugins[$code][$name][$type] = $data; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::end_render($_template); | ||||
|             } | ||||
|             // write to cache when nessecary | ||||
|             if (!$_template->source->recompiled && ($_template->caching == Smarty::CACHING_LIFETIME_SAVED || $_template->caching == Smarty::CACHING_LIFETIME_CURRENT)) { | ||||
|                 if ($this->smarty->debugging) { | ||||
|                     Smarty_Internal_Debug::start_cache($_template); | ||||
|                 } | ||||
|                 $_template->properties['has_nocache_code'] = false; | ||||
|                 // get text between non-cached items | ||||
|                 $cache_split = preg_split("!/\*%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*\/(.+?)/\*/%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!s", $_output); | ||||
|                 // get non-cached items | ||||
|                 preg_match_all("!/\*%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*\/(.+?)/\*/%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!s", $_output, $cache_parts); | ||||
|                 $output = ''; | ||||
|                 // loop over items, stitch back together | ||||
|                 foreach ($cache_split as $curr_idx => $curr_split) { | ||||
|                     // escape PHP tags in template content | ||||
|                     $output .= preg_replace('/(<%|%>|<\?php|<\?|\?>)/', "<?php echo '\$1'; ?>\n", $curr_split); | ||||
|                     if (isset($cache_parts[0][$curr_idx])) { | ||||
|                         $_template->properties['has_nocache_code'] = true; | ||||
|                         // remove nocache tags from cache output | ||||
|                         $output .= preg_replace("!/\*/?%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!", '', $cache_parts[0][$curr_idx]); | ||||
|                     } | ||||
|                 } | ||||
|                 if (!$no_output_filter && !$_template->has_nocache_code && (isset($this->smarty->autoload_filters['output']) || isset($this->smarty->registered_filters['output']))) { | ||||
|                     $output = Smarty_Internal_Filter_Handler::runFilter('output', $output, $_template); | ||||
|                 } | ||||
|                 // rendering (must be done before writing cache file because of {function} nocache handling) | ||||
|                 /** @var Smarty_Internal_Template $_smarty_tpl | ||||
|                  * used in evaluated code | ||||
|                  */ | ||||
|                 $_smarty_tpl = $_template; | ||||
|                 try { | ||||
|                     ob_start(); | ||||
|                     eval("?>" . $output); | ||||
|                     $_output = ob_get_clean(); | ||||
|                 } | ||||
|                 catch (Exception $e) { | ||||
|                     ob_get_clean(); | ||||
|                     throw $e; | ||||
|                 } | ||||
|                 // write cache file content | ||||
|                 $_template->writeCachedContent($output); | ||||
|                 if ($this->smarty->debugging) { | ||||
|                     Smarty_Internal_Debug::end_cache($_template); | ||||
|                 } | ||||
|             } else { | ||||
|                 // var_dump('renderTemplate', $_template->has_nocache_code, $_template->template_resource, $_template->properties['nocache_hash'], $_template->parent->properties['nocache_hash'], $_output); | ||||
|                 if (!empty($_template->properties['nocache_hash']) && !empty($_template->parent->properties['nocache_hash'])) { | ||||
|                     // replace nocache_hash | ||||
|                     $_output = str_replace("{$_template->properties['nocache_hash']}", $_template->parent->properties['nocache_hash'], $_output); | ||||
|                     $_template->parent->has_nocache_code = $_template->parent->has_nocache_code || $_template->has_nocache_code; | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::start_cache($_template); | ||||
|             } | ||||
|             try { | ||||
|                 ob_start(); | ||||
|                 array_unshift($_template->_capture_stack, array()); | ||||
|                 // | ||||
|                 // render cached template | ||||
|                 // | ||||
|                 $_template->properties['unifunc']($_template); | ||||
|                 // any unclosed {capture} tags ? | ||||
|                 if (isset($_template->_capture_stack[0][0])) { | ||||
|                     $_template->capture_error(); | ||||
|                 } | ||||
|                 array_shift($_template->_capture_stack); | ||||
|                 $_output = ob_get_clean(); | ||||
|             } | ||||
|             catch (Exception $e) { | ||||
|                 ob_get_clean(); | ||||
|                 throw $e; | ||||
|             } | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::end_cache($_template); | ||||
|             } | ||||
|         } | ||||
|         if ((!$this->caching || $_template->has_nocache_code || $_template->source->recompiled) && !$no_output_filter && (isset($this->smarty->autoload_filters['output']) || isset($this->smarty->registered_filters['output']))) { | ||||
|             $_output = Smarty_Internal_Filter_Handler::runFilter('output', $_output, $_template); | ||||
|         } | ||||
|         if (isset($this->error_reporting)) { | ||||
|             error_reporting($_smarty_old_error_level); | ||||
|         } | ||||
|         // display or fetch | ||||
|         if ($display) { | ||||
|             if ($this->caching && $this->cache_modified_check) { | ||||
|                 $_isCached = $_template->isCached() && !$_template->has_nocache_code; | ||||
|                 $_last_modified_date = @substr($_SERVER['HTTP_IF_MODIFIED_SINCE'], 0, strpos($_SERVER['HTTP_IF_MODIFIED_SINCE'], 'GMT') + 3); | ||||
|                 if ($_isCached && $_template->cached->timestamp <= strtotime($_last_modified_date)) { | ||||
|                     switch (PHP_SAPI) { | ||||
|                         case 'cgi': // php-cgi < 5.3 | ||||
|                         case 'cgi-fcgi': // php-cgi >= 5.3 | ||||
|                         case 'fpm-fcgi': // php-fpm >= 5.3.3 | ||||
|                             header('Status: 304 Not Modified'); | ||||
|                             break; | ||||
|  | ||||
|                         case 'cli': | ||||
|                             if ( /* ^phpunit */ | ||||
|                             !empty($_SERVER['SMARTY_PHPUNIT_DISABLE_HEADERS']) /* phpunit$ */ | ||||
|                             ) { | ||||
|                                 $_SERVER['SMARTY_PHPUNIT_HEADERS'][] = '304 Not Modified'; | ||||
|                             } | ||||
|                             break; | ||||
|  | ||||
|                         default: | ||||
|                             header($_SERVER['SERVER_PROTOCOL'] . ' 304 Not Modified'); | ||||
|                             break; | ||||
|                     } | ||||
|                 } else { | ||||
|                     switch (PHP_SAPI) { | ||||
|                         case 'cli': | ||||
|                             if ( /* ^phpunit */ | ||||
|                             !empty($_SERVER['SMARTY_PHPUNIT_DISABLE_HEADERS']) /* phpunit$ */ | ||||
|                             ) { | ||||
|                                 $_SERVER['SMARTY_PHPUNIT_HEADERS'][] = 'Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->cached->timestamp) . ' GMT'; | ||||
|                             } | ||||
|                             break; | ||||
|  | ||||
|                         default: | ||||
|                             header('Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->cached->timestamp) . ' GMT'); | ||||
|                             break; | ||||
|                     } | ||||
|                     echo $_output; | ||||
|                 } | ||||
|             } else { | ||||
|                 echo $_output; | ||||
|             } | ||||
|             // debug output | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::display_debug($_template); | ||||
|             } | ||||
|             if ($merge_tpl_vars) { | ||||
|                 // restore local variables | ||||
|                 $_template->tpl_vars = $save_tpl_vars; | ||||
|                 $_template->config_vars = $save_config_vars; | ||||
|             } | ||||
|  | ||||
|             return; | ||||
|         } else { | ||||
|             if ($merge_tpl_vars) { | ||||
|                 // restore local variables | ||||
|                 $_template->tpl_vars = $save_tpl_vars; | ||||
|                 $_template->config_vars = $save_config_vars; | ||||
|             } | ||||
|             // return fetched content | ||||
|             return $_output; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * displays a Smarty template | ||||
|      * | ||||
|      * @param string $template   the resource handle of the template file or template object | ||||
|      * @param mixed  $cache_id   cache id to be used with this template | ||||
|      * @param mixed  $compile_id compile id to be used with this template | ||||
|      * @param object $parent     next higher level of Smarty variables | ||||
|      */ | ||||
|     public function display($template = null, $cache_id = null, $compile_id = null, $parent = null) | ||||
|     { | ||||
|         // display template | ||||
|         $this->fetch($template, $cache_id, $compile_id, $parent, true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * test if cache is valid | ||||
|      * | ||||
|      * @param  string|object $template   the resource handle of the template file or template object | ||||
|      * @param  mixed         $cache_id   cache id to be used with this template | ||||
|      * @param  mixed         $compile_id compile id to be used with this template | ||||
|      * @param  object        $parent     next higher level of Smarty variables | ||||
|      * | ||||
|      * @return boolean       cache status | ||||
|      */ | ||||
|     public function isCached($template = null, $cache_id = null, $compile_id = null, $parent = null) | ||||
|     { | ||||
|         if ($template === null && $this instanceof $this->template_class) { | ||||
|             return $this->cached->valid; | ||||
|         } | ||||
|         if (!($template instanceof $this->template_class)) { | ||||
|             if ($parent === null) { | ||||
|                 $parent = $this; | ||||
|             } | ||||
|             $template = $this->smarty->createTemplate($template, $cache_id, $compile_id, $parent, false); | ||||
|         } | ||||
|         // return cache status of template | ||||
|         return $template->cached->valid; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * creates a data object | ||||
|      * | ||||
|      * @param object $parent next higher level of Smarty variables | ||||
|      * | ||||
|      * @returns Smarty_Data data object | ||||
|      */ | ||||
|     public function createData($parent = null) | ||||
|     { | ||||
|         return new Smarty_Data($parent, $this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers plugin to be used in templates | ||||
|      * | ||||
|      * @param  string   $type       plugin type | ||||
|      * @param  string   $tag        name of template tag | ||||
|      * @param  callback $callback   PHP callback to register | ||||
|      * @param  boolean  $cacheable  if true (default) this fuction is cachable | ||||
|      * @param  array    $cache_attr caching attributes if any | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      * @throws SmartyException              when the plugin tag is invalid | ||||
|      */ | ||||
|     public function registerPlugin($type, $tag, $callback, $cacheable = true, $cache_attr = null) | ||||
|     { | ||||
|         if (isset($this->smarty->registered_plugins[$type][$tag])) { | ||||
|             throw new SmartyException("Plugin tag \"{$tag}\" already registered"); | ||||
|         } elseif (!is_callable($callback)) { | ||||
|             throw new SmartyException("Plugin \"{$tag}\" not callable"); | ||||
|         } else { | ||||
|             $this->smarty->registered_plugins[$type][$tag] = array($callback, (bool) $cacheable, (array) $cache_attr); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unregister Plugin | ||||
|      * | ||||
|      * @param  string $type of plugin | ||||
|      * @param  string $tag  name of plugin | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unregisterPlugin($type, $tag) | ||||
|     { | ||||
|         if (isset($this->smarty->registered_plugins[$type][$tag])) { | ||||
|             unset($this->smarty->registered_plugins[$type][$tag]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a resource to fetch a template | ||||
|      * | ||||
|      * @param  string                $type     name of resource type | ||||
|      * @param  Smarty_Resource|array $callback or instance of Smarty_Resource, or array of callbacks to handle resource (deprecated) | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function registerResource($type, $callback) | ||||
|     { | ||||
|         $this->smarty->registered_resources[$type] = $callback instanceof Smarty_Resource ? $callback : array($callback, false); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unregisters a resource | ||||
|      * | ||||
|      * @param  string $type name of resource type | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unregisterResource($type) | ||||
|     { | ||||
|         if (isset($this->smarty->registered_resources[$type])) { | ||||
|             unset($this->smarty->registered_resources[$type]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a cache resource to cache a template's output | ||||
|      * | ||||
|      * @param  string               $type     name of cache resource type | ||||
|      * @param  Smarty_CacheResource $callback instance of Smarty_CacheResource to handle output caching | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function registerCacheResource($type, Smarty_CacheResource $callback) | ||||
|     { | ||||
|         $this->smarty->registered_cache_resources[$type] = $callback; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unregisters a cache resource | ||||
|      * | ||||
|      * @param  string $type name of cache resource type | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unregisterCacheResource($type) | ||||
|     { | ||||
|         if (isset($this->smarty->registered_cache_resources[$type])) { | ||||
|             unset($this->smarty->registered_cache_resources[$type]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers object to be used in templates | ||||
|      * | ||||
|      * @param          $object_name | ||||
|      * @param  object  $object_impl   the referenced PHP object to register | ||||
|      * @param  array   $allowed       list of allowed methods (empty = all) | ||||
|      * @param  boolean $smarty_args   smarty argument format, else traditional | ||||
|      * @param  array   $block_methods list of block-methods | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function registerObject($object_name, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array()) | ||||
|     { | ||||
|         // test if allowed methods callable | ||||
|         if (!empty($allowed)) { | ||||
|             foreach ((array) $allowed as $method) { | ||||
|                 if (!is_callable(array($object_impl, $method)) && !property_exists($object_impl, $method)) { | ||||
|                     throw new SmartyException("Undefined method or property '$method' in registered object"); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // test if block methods callable | ||||
|         if (!empty($block_methods)) { | ||||
|             foreach ((array) $block_methods as $method) { | ||||
|                 if (!is_callable(array($object_impl, $method))) { | ||||
|                     throw new SmartyException("Undefined method '$method' in registered object"); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // register the object | ||||
|         $this->smarty->registered_objects[$object_name] = | ||||
|             array($object_impl, (array) $allowed, (boolean) $smarty_args, (array) $block_methods); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * return a reference to a registered object | ||||
|      * | ||||
|      * @param  string $name object name | ||||
|      * | ||||
|      * @return object | ||||
|      * @throws SmartyException if no such object is found | ||||
|      */ | ||||
|     public function getRegisteredObject($name) | ||||
|     { | ||||
|         if (!isset($this->smarty->registered_objects[$name])) { | ||||
|             throw new SmartyException("'$name' is not a registered object"); | ||||
|         } | ||||
|         if (!is_object($this->smarty->registered_objects[$name][0])) { | ||||
|             throw new SmartyException("registered '$name' is not an object"); | ||||
|         } | ||||
|  | ||||
|         return $this->smarty->registered_objects[$name][0]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * unregister an object | ||||
|      * | ||||
|      * @param  string $name object name | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unregisterObject($name) | ||||
|     { | ||||
|         if (isset($this->smarty->registered_objects[$name])) { | ||||
|             unset($this->smarty->registered_objects[$name]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers static classes to be used in templates | ||||
|      * | ||||
|      * @param         $class_name | ||||
|      * @param  string $class_impl the referenced PHP class to register | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function registerClass($class_name, $class_impl) | ||||
|     { | ||||
|         // test if exists | ||||
|         if (!class_exists($class_impl)) { | ||||
|             throw new SmartyException("Undefined class '$class_impl' in register template class"); | ||||
|         } | ||||
|         // register the class | ||||
|         $this->smarty->registered_classes[$class_name] = $class_impl; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a default plugin handler | ||||
|      * | ||||
|      * @param  callable $callback class/method name | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultPluginHandler($callback) | ||||
|     { | ||||
|         if (is_callable($callback)) { | ||||
|             $this->smarty->default_plugin_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException("Default plugin handler '$callback' not callable"); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a default template handler | ||||
|      * | ||||
|      * @param  callable $callback class/method name | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultTemplateHandler($callback) | ||||
|     { | ||||
|         if (is_callable($callback)) { | ||||
|             $this->smarty->default_template_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException("Default template handler '$callback' not callable"); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a default template handler | ||||
|      * | ||||
|      * @param  callable $callback class/method name | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultConfigHandler($callback) | ||||
|     { | ||||
|         if (is_callable($callback)) { | ||||
|             $this->smarty->default_config_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException("Default config handler '$callback' not callable"); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Registers a filter function | ||||
|      * | ||||
|      * @param  string   $type filter type | ||||
|      * @param  callback $callback | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function registerFilter($type, $callback) | ||||
|     { | ||||
|         $this->smarty->registered_filters[$type][$this->_get_filter_name($callback)] = $callback; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unregisters a filter function | ||||
|      * | ||||
|      * @param  string   $type filter type | ||||
|      * @param  callback $callback | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unregisterFilter($type, $callback) | ||||
|     { | ||||
|         $name = $this->_get_filter_name($callback); | ||||
|         if (isset($this->smarty->registered_filters[$type][$name])) { | ||||
|             unset($this->smarty->registered_filters[$type][$name]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return internal filter name | ||||
|      * | ||||
|      * @param  callback $function_name | ||||
|      * | ||||
|      * @return string   internal filter name | ||||
|      */ | ||||
|     public function _get_filter_name($function_name) | ||||
|     { | ||||
|         if (is_array($function_name)) { | ||||
|             $_class_name = (is_object($function_name[0]) ? | ||||
|                 get_class($function_name[0]) : $function_name[0]); | ||||
|  | ||||
|             return $_class_name . '_' . $function_name[1]; | ||||
|         } else { | ||||
|             return $function_name; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * load a filter of specified type and name | ||||
|      * | ||||
|      * @param  string $type filter type | ||||
|      * @param  string $name filter name | ||||
|      * | ||||
|      * @throws SmartyException if filter could not be loaded | ||||
|      */ | ||||
|     public function loadFilter($type, $name) | ||||
|     { | ||||
|         $_plugin = "smarty_{$type}filter_{$name}"; | ||||
|         $_filter_name = $_plugin; | ||||
|         if ($this->smarty->loadPlugin($_plugin)) { | ||||
|             if (class_exists($_plugin, false)) { | ||||
|                 $_plugin = array($_plugin, 'execute'); | ||||
|             } | ||||
|             if (is_callable($_plugin)) { | ||||
|                 $this->smarty->registered_filters[$type][$_filter_name] = $_plugin; | ||||
|  | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|         throw new SmartyException("{$type}filter \"{$name}\" not callable"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * unload a filter of specified type and name | ||||
|      * | ||||
|      * @param  string $type filter type | ||||
|      * @param  string $name filter name | ||||
|      * | ||||
|      * @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining | ||||
|      */ | ||||
|     public function unloadFilter($type, $name) | ||||
|     { | ||||
|         $_filter_name = "smarty_{$type}filter_{$name}"; | ||||
|         if (isset($this->smarty->registered_filters[$type][$_filter_name])) { | ||||
|             unset ($this->smarty->registered_filters[$type][$_filter_name]); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * preg_replace callback to convert camelcase getter/setter to underscore property names | ||||
|      * | ||||
|      * @param  string $match match string | ||||
|      * | ||||
|      * @return string replacemant | ||||
|      */ | ||||
|     private function replaceCamelcase($match) | ||||
|     { | ||||
|         return "_" . strtolower($match[1]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Handle unknown class methods | ||||
|      * | ||||
|      * @param string $name unknown method-name | ||||
|      * @param array  $args argument array | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function __call($name, $args) | ||||
|     { | ||||
|         static $_prefixes = array('set' => true, 'get' => true); | ||||
|         static $_resolved_property_name = array(); | ||||
|         static $_resolved_property_source = array(); | ||||
|  | ||||
|         // method of Smarty object? | ||||
|         if (method_exists($this->smarty, $name)) { | ||||
|             return call_user_func_array(array($this->smarty, $name), $args); | ||||
|         } | ||||
|         // see if this is a set/get for a property | ||||
|         $first3 = strtolower(substr($name, 0, 3)); | ||||
|         if (isset($_prefixes[$first3]) && isset($name[3]) && $name[3] !== '_') { | ||||
|             if (isset($_resolved_property_name[$name])) { | ||||
|                 $property_name = $_resolved_property_name[$name]; | ||||
|             } else { | ||||
|                 // try to keep case correct for future PHP 6.0 case-sensitive class methods | ||||
|                 // lcfirst() not available < PHP 5.3.0, so improvise | ||||
|                 $property_name = strtolower(substr($name, 3, 1)) . substr($name, 4); | ||||
|                 // convert camel case to underscored name | ||||
|                 $property_name = preg_replace_callback('/([A-Z])/', array($this, 'replaceCamelcase'), $property_name); | ||||
|                 $_resolved_property_name[$name] = $property_name; | ||||
|             } | ||||
|             if (isset($_resolved_property_source[$property_name])) { | ||||
|                 $_is_this = $_resolved_property_source[$property_name]; | ||||
|             } else { | ||||
|                 $_is_this = null; | ||||
|                 if (property_exists($this, $property_name)) { | ||||
|                     $_is_this = true; | ||||
|                 } elseif (property_exists($this->smarty, $property_name)) { | ||||
|                     $_is_this = false; | ||||
|                 } | ||||
|                 $_resolved_property_source[$property_name] = $_is_this; | ||||
|             } | ||||
|             if ($_is_this) { | ||||
|                 if ($first3 == 'get') { | ||||
|                     return $this->$property_name; | ||||
|                 } else { | ||||
|                     return $this->$property_name = $args[0]; | ||||
|                 } | ||||
|             } elseif ($_is_this === false) { | ||||
|                 if ($first3 == 'get') { | ||||
|                     return $this->smarty->$property_name; | ||||
|                 } else { | ||||
|                     return $this->smarty->$property_name = $args[0]; | ||||
|                 } | ||||
|             } else { | ||||
|                 throw new SmartyException("property '$property_name' does not exist."); | ||||
|            } | ||||
|         } | ||||
|         if ($name == 'Smarty') { | ||||
|             throw new SmartyException("PHP5 requires you to call __construct() instead of Smarty()"); | ||||
|         } | ||||
|         // must be unknown | ||||
|         throw new SmartyException("Call of unknown method '$name'."); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,823 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Smarty Template Compiler Base | ||||
|  * This file contains the basic classes and methods for compiling Smarty templates with lexer/parser | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Main abstract compiler class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| abstract class Smarty_Internal_TemplateCompilerBase | ||||
| { | ||||
|     /** | ||||
|      * hash for nocache sections | ||||
|      * | ||||
|      * @var mixed | ||||
|      */ | ||||
|     private $nocache_hash = null; | ||||
|  | ||||
|     /** | ||||
|      * suppress generation of nocache code | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $suppressNocacheProcessing = false; | ||||
|  | ||||
|     /** | ||||
|      * suppress generation of merged template code | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $suppressMergedTemplates = false; | ||||
|  | ||||
|     /** | ||||
|      * compile tag objects | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $_tag_objects = array(); | ||||
|  | ||||
|     /** | ||||
|      * tag stack | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $_tag_stack = array(); | ||||
|  | ||||
|     /** | ||||
|      * current template | ||||
|      * | ||||
|      * @var Smarty_Internal_Template | ||||
|      */ | ||||
|     public $template = null; | ||||
|  | ||||
|     /** | ||||
|      * merged templates | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $merged_templates = array(); | ||||
|  | ||||
|     /** | ||||
|      * sources which must be compiled | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $sources = array(); | ||||
|  | ||||
|     /** | ||||
|      * flag that we are inside {block} | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $inheritance = false; | ||||
|  | ||||
|     /** | ||||
|      * flag when compiling inheritance child template | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $inheritance_child = false; | ||||
|  | ||||
|     /** | ||||
|      * uid of templates called by {extends} for recursion check | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $extends_uid = array(); | ||||
|  | ||||
|     /** | ||||
|      * source line offset for error messages | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $trace_line_offset = 0; | ||||
|  | ||||
|     /** | ||||
|      * trace uid | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $trace_uid = ''; | ||||
|  | ||||
|     /** | ||||
|      * trace file path | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $trace_filepath = ''; | ||||
|     /** | ||||
|      * stack for tracing file and line of nested {block} tags | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $trace_stack = array(); | ||||
|  | ||||
|     /** | ||||
|      * plugins loaded by default plugin handler | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $default_handler_plugins = array(); | ||||
|  | ||||
|     /** | ||||
|      * saved preprocessed modifier list | ||||
|      * | ||||
|      * @var mixed | ||||
|      */ | ||||
|     public $default_modifier_list = null; | ||||
|  | ||||
|     /** | ||||
|      * force compilation of complete template as nocache | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $forceNocache = false; | ||||
|  | ||||
|     /** | ||||
|      * suppress Smarty header code in compiled template | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $suppressHeader = false; | ||||
|  | ||||
|     /** | ||||
|      * suppress template property header code in compiled template | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $suppressTemplatePropertyHeader = false; | ||||
|  | ||||
|     /** | ||||
|      * suppress pre and post filter | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $suppressFilter = false; | ||||
|  | ||||
|     /** | ||||
|      * flag if compiled template file shall we written | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $write_compiled_code = true; | ||||
|  | ||||
|     /** | ||||
|      * flag if currently a template function is compiled | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $compiles_template_function = false; | ||||
|  | ||||
|     /** | ||||
|      * called subfuntions from template function | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $called_functions = array(); | ||||
|  | ||||
|     /** | ||||
|      * flags for used modifier plugins | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $modifier_plugins = array(); | ||||
|  | ||||
|     /** | ||||
|      * type of already compiled modifier | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $known_modifier_type = array(); | ||||
|  | ||||
|     /** | ||||
|      * method to compile a Smarty template | ||||
|      * | ||||
|      * @param  mixed $_content template source | ||||
|      * | ||||
|      * @return bool  true if compiling succeeded, false if it failed | ||||
|      */ | ||||
|     abstract protected function doCompile($_content); | ||||
|  | ||||
|     /** | ||||
|      * Initialize compiler | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         $this->nocache_hash = str_replace(array('.', ','), '-', uniqid(rand(), true)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Method to compile a Smarty template | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $template template object to compile | ||||
|      * @param  bool                     $nocache  true is shall be compiled in nocache mode | ||||
|      * | ||||
|      * @return bool             true if compiling succeeded, false if it failed | ||||
|      */ | ||||
|     public function compileTemplate(Smarty_Internal_Template $template, $nocache = false) | ||||
|     { | ||||
|         if (empty($template->properties['nocache_hash'])) { | ||||
|             $template->properties['nocache_hash'] = $this->nocache_hash; | ||||
|         } else { | ||||
|             $this->nocache_hash = $template->properties['nocache_hash']; | ||||
|         } | ||||
|         // flag for nochache sections | ||||
|         $this->nocache = $nocache; | ||||
|         $this->tag_nocache = false; | ||||
|         // save template object in compiler class | ||||
|         $this->template = $template; | ||||
|         // reset has nocache code flag | ||||
|         $this->template->has_nocache_code = false; | ||||
|         $save_source = $this->template->source; | ||||
|         // template header code | ||||
|         $template_header = ''; | ||||
|         if (!$this->suppressHeader) { | ||||
|             $template_header .= "<?php /* Smarty version " . Smarty::SMARTY_VERSION . ", created on " . strftime("%Y-%m-%d %H:%M:%S") . "\n"; | ||||
|             $template_header .= "         compiled from \"" . $this->template->source->filepath . "\" */ ?>\n"; | ||||
|         } | ||||
|  | ||||
|         if (empty($this->template->source->components)) { | ||||
|             $this->sources = array($template->source); | ||||
|         } else { | ||||
|             // we have array of inheritance templates by extends: resource | ||||
|             $this->sources = array_reverse($template->source->components); | ||||
|         } | ||||
|         $loop = 0; | ||||
|         // the $this->sources array can get additional elements while compiling by the {extends} tag | ||||
|         while ($this->template->source = array_shift($this->sources)) { | ||||
|             $this->smarty->_current_file = $this->template->source->filepath; | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::start_compile($this->template); | ||||
|             } | ||||
|             $no_sources = count($this->sources); | ||||
|             if ($loop || $no_sources) { | ||||
|                 $this->template->properties['file_dependency'][$this->template->source->uid] = array($this->template->source->filepath, $this->template->source->timestamp, $this->template->source->type); | ||||
|             } | ||||
|             $loop ++; | ||||
|             if ($no_sources) { | ||||
|                 $this->inheritance_child = true; | ||||
|             } else { | ||||
|                 $this->inheritance_child = false; | ||||
|             } | ||||
|             do { | ||||
|                 $_compiled_code = ''; | ||||
|                 // flag for aborting current and start recompile | ||||
|                 $this->abort_and_recompile = false; | ||||
|                 // get template source | ||||
|                 $_content = $this->template->source->content; | ||||
|                 if ($_content != '') { | ||||
|                     // run prefilter if required | ||||
|                     if ((isset($this->smarty->autoload_filters['pre']) || isset($this->smarty->registered_filters['pre'])) && !$this->suppressFilter) { | ||||
|                         $_content = Smarty_Internal_Filter_Handler::runFilter('pre', $_content, $template); | ||||
|                     } | ||||
|                     // call compiler | ||||
|                     $_compiled_code = $this->doCompile($_content); | ||||
|                 } | ||||
|             } while ($this->abort_and_recompile); | ||||
|             if ($this->smarty->debugging) { | ||||
|                 Smarty_Internal_Debug::end_compile($this->template); | ||||
|             } | ||||
|         } | ||||
|         // restore source | ||||
|         $this->template->source = $save_source; | ||||
|         unset($save_source); | ||||
|         $this->smarty->_current_file = $this->template->source->filepath; | ||||
|         // free memory | ||||
|         unset($this->parser->root_buffer, $this->parser->current_buffer, $this->parser, $this->lex, $this->template); | ||||
|         self::$_tag_objects = array(); | ||||
|         // return compiled code to template object | ||||
|         $merged_code = ''; | ||||
|         if (!$this->suppressMergedTemplates && !empty($this->merged_templates)) { | ||||
|             foreach ($this->merged_templates as $code) { | ||||
|                 $merged_code .= $code; | ||||
|             } | ||||
|         } | ||||
|         // run postfilter if required on compiled template code | ||||
|         if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter && $_compiled_code != '') { | ||||
|             $_compiled_code = Smarty_Internal_Filter_Handler::runFilter('post', $_compiled_code, $template); | ||||
|         } | ||||
|         if ($this->suppressTemplatePropertyHeader) { | ||||
|             $code = $_compiled_code . $merged_code; | ||||
|         } else { | ||||
|             $code = $template_header . $template->createTemplateCodeFrame($_compiled_code) . $merged_code; | ||||
|         } | ||||
|         // unset content because template inheritance could have replace source with parent code | ||||
|         unset ($template->source->content); | ||||
|  | ||||
|         return $code; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile Tag | ||||
|      * This is a call back from the lexer/parser | ||||
|      * It executes the required compile plugin for the Smarty tag | ||||
|      * | ||||
|      * @param  string $tag       tag name | ||||
|      * @param  array  $args      array with tag attributes | ||||
|      * @param  array  $parameter array with compilation parameter | ||||
|      * | ||||
|      * @throws SmartyCompilerException | ||||
|      * @throws SmartyException | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compileTag($tag, $args, $parameter = array()) | ||||
|     { | ||||
|         // $args contains the attributes parsed and compiled by the lexer/parser | ||||
|         // assume that tag does compile into code, but creates no HTML output | ||||
|         $this->has_code = true; | ||||
|         $this->has_output = false; | ||||
|         // log tag/attributes | ||||
|         if (isset($this->smarty->get_used_tags) && $this->smarty->get_used_tags) { | ||||
|             $this->template->used_tags[] = array($tag, $args); | ||||
|         } | ||||
|         // check nocache option flag | ||||
|         if (in_array("'nocache'", $args) || in_array(array('nocache' => 'true'), $args) | ||||
|             || in_array(array('nocache' => '"true"'), $args) || in_array(array('nocache' => "'true'"), $args) | ||||
|         ) { | ||||
|             $this->tag_nocache = true; | ||||
|         } | ||||
|         // compile the smarty tag (required compile classes to compile the tag are autoloaded) | ||||
|         if (($_output = $this->callTagCompiler($tag, $args, $parameter)) === false) { | ||||
|             if (isset($this->smarty->template_functions[$tag])) { | ||||
|                 // template defined by {template} tag | ||||
|                 $args['_attr']['name'] = "'" . $tag . "'"; | ||||
|                 $_output = $this->callTagCompiler('call', $args, $parameter); | ||||
|             } | ||||
|         } | ||||
|         if ($_output !== false) { | ||||
|             if ($_output !== true) { | ||||
|                 // did we get compiled code | ||||
|                 if ($this->has_code) { | ||||
|                     // Does it create output? | ||||
|                     if ($this->has_output) { | ||||
|                         $_output .= "\n"; | ||||
|                     } | ||||
|                     // return compiled code | ||||
|                     return $_output; | ||||
|                 } | ||||
|             } | ||||
|             // tag did not produce compiled code | ||||
|             return null; | ||||
|         } else { | ||||
|             // map_named attributes | ||||
|             if (isset($args['_attr'])) { | ||||
|                 foreach ($args['_attr'] as $key => $attribute) { | ||||
|                     if (is_array($attribute)) { | ||||
|                         $args = array_merge($args, $attribute); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             // not an internal compiler tag | ||||
|             if (strlen($tag) < 6 || substr($tag, - 5) != 'close') { | ||||
|                 // check if tag is a registered object | ||||
|                 if (isset($this->smarty->registered_objects[$tag]) && isset($parameter['object_method'])) { | ||||
|                     $method = $parameter['object_method']; | ||||
|                     if (!in_array($method, $this->smarty->registered_objects[$tag][3]) && | ||||
|                         (empty($this->smarty->registered_objects[$tag][1]) || in_array($method, $this->smarty->registered_objects[$tag][1])) | ||||
|                     ) { | ||||
|                         return $this->callTagCompiler('private_object_function', $args, $parameter, $tag, $method); | ||||
|                     } elseif (in_array($method, $this->smarty->registered_objects[$tag][3])) { | ||||
|                         return $this->callTagCompiler('private_object_block_function', $args, $parameter, $tag, $method); | ||||
|                     } else { | ||||
|                         // throw exception | ||||
|                         $this->trigger_template_error('not allowed method "' . $method . '" in registered object "' . $tag . '"', $this->lex->taglineno); | ||||
|                     } | ||||
|                 } | ||||
|                 // check if tag is registered | ||||
|                 foreach (array(Smarty::PLUGIN_COMPILER, Smarty::PLUGIN_FUNCTION, Smarty::PLUGIN_BLOCK) as $plugin_type) { | ||||
|                     if (isset($this->smarty->registered_plugins[$plugin_type][$tag])) { | ||||
|                         // if compiler function plugin call it now | ||||
|                         if ($plugin_type == Smarty::PLUGIN_COMPILER) { | ||||
|                             $new_args = array(); | ||||
|                             foreach ($args as $key => $mixed) { | ||||
|                                 if (is_array($mixed)) { | ||||
|                                     $new_args = array_merge($new_args, $mixed); | ||||
|                                 } else { | ||||
|                                     $new_args[$key] = $mixed; | ||||
|                                 } | ||||
|                             } | ||||
|                             if (!$this->smarty->registered_plugins[$plugin_type][$tag][1]) { | ||||
|                                 $this->tag_nocache = true; | ||||
|                             } | ||||
|                             $function = $this->smarty->registered_plugins[$plugin_type][$tag][0]; | ||||
|                             if (!is_array($function)) { | ||||
|                                 return $function($new_args, $this); | ||||
|                             } elseif (is_object($function[0])) { | ||||
|                                 return $this->smarty->registered_plugins[$plugin_type][$tag][0][0]->$function[1]($new_args, $this); | ||||
|                             } else { | ||||
|                                 return call_user_func_array($function, array($new_args, $this)); | ||||
|                             } | ||||
|                         } | ||||
|                         // compile registered function or block function | ||||
|                         if ($plugin_type == Smarty::PLUGIN_FUNCTION || $plugin_type == Smarty::PLUGIN_BLOCK) { | ||||
|                             return $this->callTagCompiler('private_registered_' . $plugin_type, $args, $parameter, $tag); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 // check plugins from plugins folder | ||||
|                 foreach ($this->smarty->plugin_search_order as $plugin_type) { | ||||
|                     if ($plugin_type == Smarty::PLUGIN_COMPILER && $this->smarty->loadPlugin('smarty_compiler_' . $tag) && (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this))) { | ||||
|                         $plugin = 'smarty_compiler_' . $tag; | ||||
|                         if (is_callable($plugin)) { | ||||
|                             // convert arguments format for old compiler plugins | ||||
|                             $new_args = array(); | ||||
|                             foreach ($args as $key => $mixed) { | ||||
|                                 if (is_array($mixed)) { | ||||
|                                     $new_args = array_merge($new_args, $mixed); | ||||
|                                 } else { | ||||
|                                     $new_args[$key] = $mixed; | ||||
|                                 } | ||||
|                             } | ||||
|  | ||||
|                             return $plugin($new_args, $this->smarty); | ||||
|                         } | ||||
|                         if (class_exists($plugin, false)) { | ||||
|                             $plugin_object = new $plugin; | ||||
|                             if (method_exists($plugin_object, 'compile')) { | ||||
|                                 return $plugin_object->compile($args, $this); | ||||
|                             } | ||||
|                         } | ||||
|                         throw new SmartyException("Plugin \"{$tag}\" not callable"); | ||||
|                     } else { | ||||
|                         if ($function = $this->getPlugin($tag, $plugin_type)) { | ||||
|                             if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this)) { | ||||
|                                 return $this->callTagCompiler('private_' . $plugin_type . '_plugin', $args, $parameter, $tag, $function); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 if (is_callable($this->smarty->default_plugin_handler_func)) { | ||||
|                     $found = false; | ||||
|                     // look for already resolved tags | ||||
|                     foreach ($this->smarty->plugin_search_order as $plugin_type) { | ||||
|                         if (isset($this->default_handler_plugins[$plugin_type][$tag])) { | ||||
|                             $found = true; | ||||
|                             break; | ||||
|                         } | ||||
|                     } | ||||
|                     if (!$found) { | ||||
|                         // call default handler | ||||
|                         foreach ($this->smarty->plugin_search_order as $plugin_type) { | ||||
|                             if ($this->getPluginFromDefaultHandler($tag, $plugin_type)) { | ||||
|                                 $found = true; | ||||
|                                 break; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     if ($found) { | ||||
|                         // if compiler function plugin call it now | ||||
|                         if ($plugin_type == Smarty::PLUGIN_COMPILER) { | ||||
|                             $new_args = array(); | ||||
|                             foreach ($args as $mixed) { | ||||
|                                 $new_args = array_merge($new_args, $mixed); | ||||
|                             } | ||||
|                             $function = $this->default_handler_plugins[$plugin_type][$tag][0]; | ||||
|                             if (!is_array($function)) { | ||||
|                                 return $function($new_args, $this); | ||||
|                             } elseif (is_object($function[0])) { | ||||
|                                 return $this->default_handler_plugins[$plugin_type][$tag][0][0]->$function[1]($new_args, $this); | ||||
|                             } else { | ||||
|                                 return call_user_func_array($function, array($new_args, $this)); | ||||
|                             } | ||||
|                         } else { | ||||
|                             return $this->callTagCompiler('private_registered_' . $plugin_type, $args, $parameter, $tag); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } else { | ||||
|                 // compile closing tag of block function | ||||
|                 $base_tag = substr($tag, 0, - 5); | ||||
|                 // check if closing tag is a registered object | ||||
|                 if (isset($this->smarty->registered_objects[$base_tag]) && isset($parameter['object_method'])) { | ||||
|                     $method = $parameter['object_method']; | ||||
|                     if (in_array($method, $this->smarty->registered_objects[$base_tag][3])) { | ||||
|                         return $this->callTagCompiler('private_object_block_function', $args, $parameter, $tag, $method); | ||||
|                     } else { | ||||
|                         // throw exception | ||||
|                         $this->trigger_template_error('not allowed closing tag method "' . $method . '" in registered object "' . $base_tag . '"', $this->lex->taglineno); | ||||
|                     } | ||||
|                 } | ||||
|                 // registered block tag ? | ||||
|                 if (isset($this->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag]) || isset($this->default_handler_plugins[Smarty::PLUGIN_BLOCK][$base_tag])) { | ||||
|                     return $this->callTagCompiler('private_registered_block', $args, $parameter, $tag); | ||||
|                 } | ||||
|                 // block plugin? | ||||
|                 if ($function = $this->getPlugin($base_tag, Smarty::PLUGIN_BLOCK)) { | ||||
|                     return $this->callTagCompiler('private_block_plugin', $args, $parameter, $tag, $function); | ||||
|                 } | ||||
|                 // registered compiler plugin ? | ||||
|                 if (isset($this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag])) { | ||||
|                     // if compiler function plugin call it now | ||||
|                     $args = array(); | ||||
|                     if (!$this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][1]) { | ||||
|                         $this->tag_nocache = true; | ||||
|                     } | ||||
|                     $function = $this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][0]; | ||||
|                     if (!is_array($function)) { | ||||
|                         return $function($args, $this); | ||||
|                     } elseif (is_object($function[0])) { | ||||
|                         return $this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][0][0]->$function[1]($args, $this); | ||||
|                     } else { | ||||
|                         return call_user_func_array($function, array($args, $this)); | ||||
|                     } | ||||
|                 } | ||||
|                 if ($this->smarty->loadPlugin('smarty_compiler_' . $tag)) { | ||||
|                     $plugin = 'smarty_compiler_' . $tag; | ||||
|                     if (is_callable($plugin)) { | ||||
|                         return $plugin($args, $this->smarty); | ||||
|                     } | ||||
|                     if (class_exists($plugin, false)) { | ||||
|                         $plugin_object = new $plugin; | ||||
|                         if (method_exists($plugin_object, 'compile')) { | ||||
|                             return $plugin_object->compile($args, $this); | ||||
|                         } | ||||
|                     } | ||||
|                     throw new SmartyException("Plugin \"{$tag}\" not callable"); | ||||
|                 } | ||||
|             } | ||||
|             $this->trigger_template_error("unknown tag \"" . $tag . "\"", $this->lex->taglineno); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * lazy loads internal compile plugin for tag and calls the compile method | ||||
|      * compile objects cached for reuse. | ||||
|      * class name format:  Smarty_Internal_Compile_TagName | ||||
|      * plugin filename format: Smarty_Internal_Tagname.php | ||||
|      * | ||||
|      * @param  string $tag    tag name | ||||
|      * @param  array  $args   list of tag attributes | ||||
|      * @param  mixed  $param1 optional parameter | ||||
|      * @param  mixed  $param2 optional parameter | ||||
|      * @param  mixed  $param3 optional parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function callTagCompiler($tag, $args, $param1 = null, $param2 = null, $param3 = null) | ||||
|     { | ||||
|         // re-use object if already exists | ||||
|         if (isset(self::$_tag_objects[$tag])) { | ||||
|             // compile this tag | ||||
|             return self::$_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3); | ||||
|         } | ||||
|         // lazy load internal compiler plugin | ||||
|         $class_name = 'Smarty_Internal_Compile_' . $tag; | ||||
|         if ($this->smarty->loadPlugin($class_name)) { | ||||
|             // check if tag allowed by security | ||||
|             if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this)) { | ||||
|                 // use plugin if found | ||||
|                 self::$_tag_objects[$tag] = new $class_name; | ||||
|                 // compile this tag | ||||
|                 return self::$_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3); | ||||
|             } | ||||
|         } | ||||
|         // no internal compile plugin for this tag | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check for plugins and return function name | ||||
|      * | ||||
|      * @param         $plugin_name | ||||
|      * @param  string $plugin_type type of plugin | ||||
|      * | ||||
|      * @return string call name of function | ||||
|      */ | ||||
|     public function getPlugin($plugin_name, $plugin_type) | ||||
|     { | ||||
|         $function = null; | ||||
|         if ($this->template->caching && ($this->nocache || $this->tag_nocache)) { | ||||
|             if (isset($this->template->required_plugins['nocache'][$plugin_name][$plugin_type])) { | ||||
|                 $function = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function']; | ||||
|             } elseif (isset($this->template->required_plugins['compiled'][$plugin_name][$plugin_type])) { | ||||
|                 $this->template->required_plugins['nocache'][$plugin_name][$plugin_type] = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]; | ||||
|                 $function = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function']; | ||||
|             } | ||||
|         } else { | ||||
|             if (isset($this->template->required_plugins['compiled'][$plugin_name][$plugin_type])) { | ||||
|                 $function = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function']; | ||||
|             } elseif (isset($this->template->required_plugins['nocache'][$plugin_name][$plugin_type])) { | ||||
|                 $this->template->required_plugins['compiled'][$plugin_name][$plugin_type] = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]; | ||||
|                 $function = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function']; | ||||
|             } | ||||
|         } | ||||
|         if (isset($function)) { | ||||
|             if ($plugin_type == 'modifier') { | ||||
|                 $this->modifier_plugins[$plugin_name] = true; | ||||
|             } | ||||
|  | ||||
|             return $function; | ||||
|         } | ||||
|         // loop through plugin dirs and find the plugin | ||||
|         $function = 'smarty_' . $plugin_type . '_' . $plugin_name; | ||||
|         $file = $this->smarty->loadPlugin($function, false); | ||||
|  | ||||
|         if (is_string($file)) { | ||||
|             if ($this->template->caching && ($this->nocache || $this->tag_nocache)) { | ||||
|                 $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['file'] = $file; | ||||
|                 $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function'] = $function; | ||||
|             } else { | ||||
|                 $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['file'] = $file; | ||||
|                 $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function'] = $function; | ||||
|             } | ||||
|             if ($plugin_type == 'modifier') { | ||||
|                 $this->modifier_plugins[$plugin_name] = true; | ||||
|             } | ||||
|  | ||||
|             return $function; | ||||
|         } | ||||
|         if (is_callable($function)) { | ||||
|             // plugin function is defined in the script | ||||
|             return $function; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check for plugins by default plugin handler | ||||
|      * | ||||
|      * @param  string $tag         name of tag | ||||
|      * @param  string $plugin_type type of plugin | ||||
|      * | ||||
|      * @return boolean true if found | ||||
|      */ | ||||
|     public function getPluginFromDefaultHandler($tag, $plugin_type) | ||||
|     { | ||||
|         $callback = null; | ||||
|         $script = null; | ||||
|         $cacheable = true; | ||||
|         $result = call_user_func_array( | ||||
|             $this->smarty->default_plugin_handler_func, array($tag, $plugin_type, $this->template, &$callback, &$script, &$cacheable) | ||||
|         ); | ||||
|         if ($result) { | ||||
|             $this->tag_nocache = $this->tag_nocache || !$cacheable; | ||||
|             if ($script !== null) { | ||||
|                 if (is_file($script)) { | ||||
|                     if ($this->template->caching && ($this->nocache || $this->tag_nocache)) { | ||||
|                         $this->template->required_plugins['nocache'][$tag][$plugin_type]['file'] = $script; | ||||
|                         $this->template->required_plugins['nocache'][$tag][$plugin_type]['function'] = $callback; | ||||
|                     } else { | ||||
|                         $this->template->required_plugins['compiled'][$tag][$plugin_type]['file'] = $script; | ||||
|                         $this->template->required_plugins['compiled'][$tag][$plugin_type]['function'] = $callback; | ||||
|                     } | ||||
|                     include_once $script; | ||||
|                 } else { | ||||
|                     $this->trigger_template_error("Default plugin handler: Returned script file \"{$script}\" for \"{$tag}\" not found"); | ||||
|                 } | ||||
|             } | ||||
|             if (!is_string($callback) && !(is_array($callback) && is_string($callback[0]) && is_string($callback[1]))) { | ||||
|                 $this->trigger_template_error("Default plugin handler: Returned callback for \"{$tag}\" must be a static function name or array of class and function name"); | ||||
|             } | ||||
|             if (is_callable($callback)) { | ||||
|                 $this->default_handler_plugins[$plugin_type][$tag] = array($callback, true, array()); | ||||
|  | ||||
|                 return true; | ||||
|             } else { | ||||
|                 $this->trigger_template_error("Default plugin handler: Returned callback for \"{$tag}\" not callable"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Inject inline code for nocache template sections | ||||
|      * This method gets the content of each template element from the parser. | ||||
|      * If the content is compiled code and it should be not cached the code is injected | ||||
|      * into the rendered output. | ||||
|      * | ||||
|      * @param  string  $content content of template element | ||||
|      * @param  boolean $is_code true if content is compiled code | ||||
|      * | ||||
|      * @return string  content | ||||
|      */ | ||||
|     public function processNocacheCode($content, $is_code) | ||||
|     { | ||||
|         // If the template is not evaluated and we have a nocache section and or a nocache tag | ||||
|         if ($is_code && !empty($content)) { | ||||
|             // generate replacement code | ||||
|             if ((!($this->template->source->recompiled) || $this->forceNocache) && $this->template->caching && !$this->suppressNocacheProcessing && | ||||
|                 ($this->nocache || $this->tag_nocache) | ||||
|             ) { | ||||
|                 $this->template->has_nocache_code = true; | ||||
|                 $_output = addcslashes($content, '\'\\'); | ||||
|                 $_output = str_replace("^#^", "'", $_output); | ||||
|                 $_output = "<?php echo '/*%%SmartyNocache:{$this->nocache_hash}%%*/" . $_output . "/*/%%SmartyNocache:{$this->nocache_hash}%%*/';?>\n"; | ||||
|                 // make sure we include modifier plugins for nocache code | ||||
|                 foreach ($this->modifier_plugins as $plugin_name => $dummy) { | ||||
|                     if (isset($this->template->required_plugins['compiled'][$plugin_name]['modifier'])) { | ||||
|                         $this->template->required_plugins['nocache'][$plugin_name]['modifier'] = $this->template->required_plugins['compiled'][$plugin_name]['modifier']; | ||||
|                     } | ||||
|                 } | ||||
|             } else { | ||||
|                 $_output = $content; | ||||
|             } | ||||
|         } else { | ||||
|             $_output = $content; | ||||
|         } | ||||
|         $this->modifier_plugins = array(); | ||||
|         $this->suppressNocacheProcessing = false; | ||||
|         $this->tag_nocache = false; | ||||
|  | ||||
|         return $_output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      *  push current file and line offset on stack for tracing {block} source lines | ||||
|      * | ||||
|      * @param string      $file  new filename | ||||
|      * @param string      $uid   uid of file | ||||
|      * @param int         $line  line offset to source | ||||
|      * @param bool $debug false debug end_compile shall not be called | ||||
|      */ | ||||
|     public function pushTrace($file, $uid, $line, $debug = true) | ||||
|     { | ||||
|         if ($this->smarty->debugging && $debug) { | ||||
|             Smarty_Internal_Debug::end_compile($this->template); | ||||
|         } | ||||
|         array_push($this->trace_stack, array($this->smarty->_current_file, $this->trace_filepath, $this->trace_uid, $this->trace_line_offset)); | ||||
|         $this->trace_filepath = $this->smarty->_current_file = $file; | ||||
|         $this->trace_uid = $uid; | ||||
|         $this->trace_line_offset = $line; | ||||
|         if ($this->smarty->debugging) { | ||||
|             Smarty_Internal_Debug::start_compile($this->template); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      *  restore file and line offset | ||||
|  | ||||
|      */ | ||||
|     public function popTrace() | ||||
|     { | ||||
|         if ($this->smarty->debugging) { | ||||
|             Smarty_Internal_Debug::end_compile($this->template); | ||||
|         } | ||||
|         $r = array_pop($this->trace_stack); | ||||
|         $this->smarty->_current_file = $r[0]; | ||||
|         $this->trace_filepath = $r[1]; | ||||
|         $this->trace_uid = $r[2]; | ||||
|         $this->trace_line_offset = $r[3]; | ||||
|         if ($this->smarty->debugging) { | ||||
|             Smarty_Internal_Debug::start_compile($this->template); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * display compiler error messages without dying | ||||
|      * If parameter $args is empty it is a parser detected syntax error. | ||||
|      * In this case the parser is called to obtain information about expected tokens. | ||||
|      * If parameter $args contains a string this is used as error message | ||||
|      * | ||||
|      * @param  string $args individual error message or null | ||||
|      * @param  string $line line-number | ||||
|      * | ||||
|      * @throws SmartyCompilerException when an unexpected token is found | ||||
|      */ | ||||
|     public function trigger_template_error($args = null, $line = null) | ||||
|     { | ||||
|         // get template source line which has error | ||||
|         if (!isset($line)) { | ||||
|             $line = $this->lex->line; | ||||
|         } | ||||
|         //        $line += $this->trace_line_offset; | ||||
|         $match = preg_split("/\n/", $this->lex->data); | ||||
|         $error_text = 'Syntax error in template "' . (empty($this->trace_filepath) ? $this->template->source->filepath : $this->trace_filepath) . '"  on line ' . ($line + $this->trace_line_offset) . ' "' . trim(preg_replace('![\t\r\n]+!', ' ', $match[$line - 1])) . '" '; | ||||
|         if (isset($args)) { | ||||
|             // individual error message | ||||
|             $error_text .= $args; | ||||
|         } else { | ||||
|             // expected token from parser | ||||
|             $error_text .= ' - Unexpected "' . $this->lex->value . '"'; | ||||
|             if (count($this->parser->yy_get_expected_tokens($this->parser->yymajor)) <= 4) { | ||||
|                 foreach ($this->parser->yy_get_expected_tokens($this->parser->yymajor) as $token) { | ||||
|                     $exp_token = $this->parser->yyTokenName[$token]; | ||||
|                     if (isset($this->lex->smarty_token_names[$exp_token])) { | ||||
|                         // token type from lexer | ||||
|                         $expect[] = '"' . $this->lex->smarty_token_names[$exp_token] . '"'; | ||||
|                     } else { | ||||
|                         // otherwise internal token name | ||||
|                         $expect[] = $this->parser->yyTokenName[$token]; | ||||
|                     } | ||||
|                 } | ||||
|                 $error_text .= ', expected one of: ' . implode(' , ', $expect); | ||||
|             } | ||||
|         } | ||||
|         $e = new SmartyCompilerException($error_text); | ||||
|         $e->line = $line; | ||||
|         $e->source = trim(preg_replace('![\t\r\n]+!', ' ', $match[$line - 1])); | ||||
|         $e->desc = $args; | ||||
|         $e->template = $this->template->source->filepath; | ||||
|         throw $e; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1557
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_templatelexer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1557
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_templatelexer.php
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										4546
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_templateparser.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4546
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_templateparser.php
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										837
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										837
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_internal_utility.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,837 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Project:     Smarty: the PHP compiling template engine | ||||
|  * File:        smarty_internal_utility.php | ||||
|  * SVN:         $Id: $ | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  * modify it under the terms of the GNU Lesser General Public | ||||
|  * License as published by the Free Software Foundation; either | ||||
|  * version 2.1 of the License, or (at your option) any later version. | ||||
|  * This library is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  * Lesser General Public License for more details. | ||||
|  * You should have received a copy of the GNU Lesser General Public | ||||
|  * License along with this library; if not, write to the Free Software | ||||
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | ||||
|  * For questions, help, comments, discussion, etc., please join the | ||||
|  * Smarty mailing list. Send a blank e-mail to | ||||
|  * smarty-discussion-subscribe@googlegroups.com | ||||
|  * | ||||
|  * @link       http://www.smarty.net/ | ||||
|  * @copyright  2008 New Digital Group, Inc. | ||||
|  * @author     Monte Ohrt <monte at ohrt dot com> | ||||
|  * @author     Uwe Tews | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @version    3-SVN$Rev: 3286 $ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Utility class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Security | ||||
|  */ | ||||
| class Smarty_Internal_Utility | ||||
| { | ||||
|     /** | ||||
|      * private constructor to prevent calls creation of new instances | ||||
|      */ | ||||
|     final private function __construct() | ||||
|     { | ||||
|         // intentionally left blank | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile all template files | ||||
|      * | ||||
|      * @param  string $extension     template file name extension | ||||
|      * @param  bool   $force_compile force all to recompile | ||||
|      * @param  int    $time_limit    set maximum execution time | ||||
|      * @param  int    $max_errors    set maximum allowed errors | ||||
|      * @param  Smarty $smarty        Smarty instance | ||||
|      * | ||||
|      * @return integer number of template files compiled | ||||
|      */ | ||||
|     public static function compileAllTemplates($extension, $force_compile, $time_limit, $max_errors, Smarty $smarty) | ||||
|     { | ||||
|         // switch off time limit | ||||
|         if (function_exists('set_time_limit')) { | ||||
|             @set_time_limit($time_limit); | ||||
|         } | ||||
|         $smarty->force_compile = $force_compile; | ||||
|         $_count = 0; | ||||
|         $_error_count = 0; | ||||
|         // loop over array of template directories | ||||
|         foreach ($smarty->getTemplateDir() as $_dir) { | ||||
|             $_compileDirs = new RecursiveDirectoryIterator($_dir); | ||||
|             $_compile = new RecursiveIteratorIterator($_compileDirs); | ||||
|             foreach ($_compile as $_fileinfo) { | ||||
|                 $_file = $_fileinfo->getFilename(); | ||||
|                 if (substr(basename($_fileinfo->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 if (!substr_compare($_file, $extension, - strlen($extension)) == 0) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 if ($_fileinfo->getPath() == substr($_dir, 0, - 1)) { | ||||
|                     $_template_file = $_file; | ||||
|                 } else { | ||||
|                     $_template_file = substr($_fileinfo->getPath(), strlen($_dir)) . DS . $_file; | ||||
|                 } | ||||
|                 echo '<br>', $_dir, '---', $_template_file; | ||||
|                 flush(); | ||||
|                 $_start_time = microtime(true); | ||||
|                 try { | ||||
|                     $_tpl = $smarty->createTemplate($_template_file, null, null, null, false); | ||||
|                     if ($_tpl->mustCompile()) { | ||||
|                         $_tpl->compileTemplateSource(); | ||||
|                         $_count ++; | ||||
|                         echo ' compiled in  ', microtime(true) - $_start_time, ' seconds'; | ||||
|                         flush(); | ||||
|                     } else { | ||||
|                         echo ' is up to date'; | ||||
|                         flush(); | ||||
|                     } | ||||
|                 } | ||||
|                 catch (Exception $e) { | ||||
|                     echo 'Error: ', $e->getMessage(), "<br><br>"; | ||||
|                     $_error_count ++; | ||||
|                 } | ||||
|                 // free memory | ||||
|                 $smarty->template_objects = array(); | ||||
|                 $_tpl->smarty->template_objects = array(); | ||||
|                 $_tpl = null; | ||||
|                 if ($max_errors !== null && $_error_count == $max_errors) { | ||||
|                     echo '<br><br>too many errors'; | ||||
|                     exit(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_count; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile all config files | ||||
|      * | ||||
|      * @param  string $extension     config file name extension | ||||
|      * @param  bool   $force_compile force all to recompile | ||||
|      * @param  int    $time_limit    set maximum execution time | ||||
|      * @param  int    $max_errors    set maximum allowed errors | ||||
|      * @param  Smarty $smarty        Smarty instance | ||||
|      * | ||||
|      * @return integer number of config files compiled | ||||
|      */ | ||||
|     public static function compileAllConfig($extension, $force_compile, $time_limit, $max_errors, Smarty $smarty) | ||||
|     { | ||||
|         // switch off time limit | ||||
|         if (function_exists('set_time_limit')) { | ||||
|             @set_time_limit($time_limit); | ||||
|         } | ||||
|         $smarty->force_compile = $force_compile; | ||||
|         $_count = 0; | ||||
|         $_error_count = 0; | ||||
|         // loop over array of template directories | ||||
|         foreach ($smarty->getConfigDir() as $_dir) { | ||||
|             $_compileDirs = new RecursiveDirectoryIterator($_dir); | ||||
|             $_compile = new RecursiveIteratorIterator($_compileDirs); | ||||
|             foreach ($_compile as $_fileinfo) { | ||||
|                 $_file = $_fileinfo->getFilename(); | ||||
|                 if (substr(basename($_fileinfo->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 if (!substr_compare($_file, $extension, - strlen($extension)) == 0) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 if ($_fileinfo->getPath() == substr($_dir, 0, - 1)) { | ||||
|                     $_config_file = $_file; | ||||
|                 } else { | ||||
|                     $_config_file = substr($_fileinfo->getPath(), strlen($_dir)) . DS . $_file; | ||||
|                 } | ||||
|                 echo '<br>', $_dir, '---', $_config_file; | ||||
|                 flush(); | ||||
|                 $_start_time = microtime(true); | ||||
|                 try { | ||||
|                     $_config = new Smarty_Internal_Config($_config_file, $smarty); | ||||
|                     if ($_config->mustCompile()) { | ||||
|                         $_config->compileConfigSource(); | ||||
|                         $_count ++; | ||||
|                         echo ' compiled in  ', microtime(true) - $_start_time, ' seconds'; | ||||
|                         flush(); | ||||
|                     } else { | ||||
|                         echo ' is up to date'; | ||||
|                         flush(); | ||||
|                     } | ||||
|                 } | ||||
|                 catch (Exception $e) { | ||||
|                     echo 'Error: ', $e->getMessage(), "<br><br>"; | ||||
|                     $_error_count ++; | ||||
|                 } | ||||
|                 if ($max_errors !== null && $_error_count == $max_errors) { | ||||
|                     echo '<br><br>too many errors'; | ||||
|                     exit(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $_count; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Delete compiled template file | ||||
|      * | ||||
|      * @param  string  $resource_name template name | ||||
|      * @param  string  $compile_id    compile id | ||||
|      * @param  integer $exp_time      expiration time | ||||
|      * @param  Smarty  $smarty        Smarty instance | ||||
|      * | ||||
|      * @return integer number of template files deleted | ||||
|      */ | ||||
|     public static function clearCompiledTemplate($resource_name, $compile_id, $exp_time, Smarty $smarty) | ||||
|     { | ||||
|         $_compile_dir = realpath($smarty->getCompileDir()) . '/'; | ||||
|         $_compile_id = isset($compile_id) ? preg_replace('![^\w\|]+!', '_', $compile_id) : null; | ||||
|         $_dir_sep = $smarty->use_sub_dirs ? '/' : '^'; | ||||
|         if (isset($resource_name)) { | ||||
|             $_save_stat = $smarty->caching; | ||||
|             $smarty->caching = false; | ||||
|             $tpl = new $smarty->template_class($resource_name, $smarty); | ||||
|             $smarty->caching = $_save_stat; | ||||
|  | ||||
|             // remove from template cache | ||||
|             $tpl->source; // have the template registered before unset() | ||||
|             if ($smarty->allow_ambiguous_resources) { | ||||
|                 $_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id; | ||||
|             } else { | ||||
|                 $_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id; | ||||
|             } | ||||
|             if (isset($_templateId[150])) { | ||||
|                 $_templateId = sha1($_templateId); | ||||
|             } | ||||
|             unset($smarty->template_objects[$_templateId]); | ||||
|  | ||||
|             if ($tpl->source->exists) { | ||||
|                 $_resource_part_1 = basename(str_replace('^', '/', $tpl->compiled->filepath)); | ||||
|                 $_resource_part_1_length = strlen($_resource_part_1); | ||||
|             } else { | ||||
|                 return 0; | ||||
|             } | ||||
|  | ||||
|             $_resource_part_2 = str_replace('.php', '.cache.php', $_resource_part_1); | ||||
|             $_resource_part_2_length = strlen($_resource_part_2); | ||||
|         } | ||||
|         $_dir = $_compile_dir; | ||||
|         if ($smarty->use_sub_dirs && isset($_compile_id)) { | ||||
|             $_dir .= $_compile_id . $_dir_sep; | ||||
|         } | ||||
|         if (isset($_compile_id)) { | ||||
|             $_compile_id_part = str_replace('\\', '/', $_compile_dir . $_compile_id . $_dir_sep); | ||||
|             $_compile_id_part_length = strlen($_compile_id_part); | ||||
|         } | ||||
|         $_count = 0; | ||||
|         try { | ||||
|             $_compileDirs = new RecursiveDirectoryIterator($_dir); | ||||
|             // NOTE: UnexpectedValueException thrown for PHP >= 5.3 | ||||
|         } | ||||
|         catch (Exception $e) { | ||||
|             return 0; | ||||
|         } | ||||
|         $_compile = new RecursiveIteratorIterator($_compileDirs, RecursiveIteratorIterator::CHILD_FIRST); | ||||
|         foreach ($_compile as $_file) { | ||||
|             if (substr(basename($_file->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $_filepath = str_replace('\\', '/', (string) $_file); | ||||
|  | ||||
|             if ($_file->isDir()) { | ||||
|                 if (!$_compile->isDot()) { | ||||
|                     // delete folder if empty | ||||
|                     @rmdir($_file->getPathname()); | ||||
|                 } | ||||
|             } else { | ||||
|                 $unlink = false; | ||||
|                 if ((!isset($_compile_id) || (isset($_filepath[$_compile_id_part_length]) && $a = !strncmp($_filepath, $_compile_id_part, $_compile_id_part_length))) | ||||
|                     && (!isset($resource_name) | ||||
|                         || (isset($_filepath[$_resource_part_1_length]) | ||||
|                             && substr_compare($_filepath, $_resource_part_1, - $_resource_part_1_length, $_resource_part_1_length) == 0) | ||||
|                         || (isset($_filepath[$_resource_part_2_length]) | ||||
|                             && substr_compare($_filepath, $_resource_part_2, - $_resource_part_2_length, $_resource_part_2_length) == 0)) | ||||
|                 ) { | ||||
|                     if (isset($exp_time)) { | ||||
|                         if (time() - @filemtime($_filepath) >= $exp_time) { | ||||
|                             $unlink = true; | ||||
|                         } | ||||
|                     } else { | ||||
|                         $unlink = true; | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 if ($unlink && @unlink($_filepath)) { | ||||
|                     $_count ++; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // clear compiled cache | ||||
|         Smarty_Resource::$sources = array(); | ||||
|         Smarty_Resource::$compileds = array(); | ||||
|  | ||||
|         return $_count; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return array of tag/attributes of all tags used by an template | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $template | ||||
|      * | ||||
|      * @throws Exception | ||||
|      * @throws SmartyException | ||||
|      * @return array                    of tag/attributes | ||||
|      */ | ||||
|     public static function getTags(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $template->smarty->get_used_tags = true; | ||||
|         $template->compileTemplateSource(); | ||||
|  | ||||
|         return $template->used_tags; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * diagnose Smarty setup | ||||
|      * If $errors is secified, the diagnostic report will be appended to the array, rather than being output. | ||||
|      * | ||||
|      * @param  Smarty $smarty Smarty instance to test | ||||
|      * @param  array  $errors array to push results into rather than outputting them | ||||
|      * | ||||
|      * @return bool   status, true if everything is fine, false else | ||||
|      */ | ||||
|     public static function testInstall(Smarty $smarty, &$errors = null) | ||||
|     { | ||||
|         $status = true; | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "<PRE>\n"; | ||||
|             echo "Smarty Installation test...\n"; | ||||
|             echo "Testing template directory...\n"; | ||||
|         } | ||||
|  | ||||
|         $_stream_resolve_include_path = function_exists('stream_resolve_include_path'); | ||||
|  | ||||
|         // test if all registered template_dir are accessible | ||||
|         foreach ($smarty->getTemplateDir() as $template_dir) { | ||||
|             $_template_dir = $template_dir; | ||||
|             $template_dir = realpath($template_dir); | ||||
|             // resolve include_path or fail existence | ||||
|             if (!$template_dir) { | ||||
|                 if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_template_dir)) { | ||||
|                     // try PHP include_path | ||||
|                     if ($_stream_resolve_include_path) { | ||||
|                         $template_dir = stream_resolve_include_path($_template_dir); | ||||
|                     } else { | ||||
|                         $template_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_template_dir); | ||||
|                     } | ||||
|  | ||||
|                     if ($template_dir !== false) { | ||||
|                         if ($errors === null) { | ||||
|                             echo "$template_dir is OK.\n"; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } else { | ||||
|                         $status = false; | ||||
|                         $message = "FAILED: $_template_dir does not exist (and couldn't be found in include_path either)"; | ||||
|                         if ($errors === null) { | ||||
|                             echo $message . ".\n"; | ||||
|                         } else { | ||||
|                             $errors['template_dir'] = $message; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } | ||||
|                 } else { | ||||
|                     $status = false; | ||||
|                     $message = "FAILED: $_template_dir does not exist"; | ||||
|                     if ($errors === null) { | ||||
|                         echo $message . ".\n"; | ||||
|                     } else { | ||||
|                         $errors['template_dir'] = $message; | ||||
|                     } | ||||
|  | ||||
|                     continue; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (!is_dir($template_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $template_dir is not a directory"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['template_dir'] = $message; | ||||
|                 } | ||||
|             } elseif (!is_readable($template_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $template_dir is not readable"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['template_dir'] = $message; | ||||
|                 } | ||||
|             } else { | ||||
|                 if ($errors === null) { | ||||
|                     echo "$template_dir is OK.\n"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing compile directory...\n"; | ||||
|         } | ||||
|  | ||||
|         // test if registered compile_dir is accessible | ||||
|         $__compile_dir = $smarty->getCompileDir(); | ||||
|         $_compile_dir = realpath($__compile_dir); | ||||
|         if (!$_compile_dir) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$__compile_dir} does not exist"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['compile_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_dir($_compile_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_compile_dir} is not a directory"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['compile_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_readable($_compile_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_compile_dir} is not readable"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['compile_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_writable($_compile_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_compile_dir} is not writable"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['compile_dir'] = $message; | ||||
|             } | ||||
|         } else { | ||||
|             if ($errors === null) { | ||||
|                 echo "{$_compile_dir} is OK.\n"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing plugins directory...\n"; | ||||
|         } | ||||
|  | ||||
|         // test if all registered plugins_dir are accessible | ||||
|         // and if core plugins directory is still registered | ||||
|         $_core_plugins_dir = realpath(dirname(__FILE__) . '/../plugins'); | ||||
|         $_core_plugins_available = false; | ||||
|         foreach ($smarty->getPluginsDir() as $plugin_dir) { | ||||
|             $_plugin_dir = $plugin_dir; | ||||
|             $plugin_dir = realpath($plugin_dir); | ||||
|             // resolve include_path or fail existence | ||||
|             if (!$plugin_dir) { | ||||
|                 if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_plugin_dir)) { | ||||
|                     // try PHP include_path | ||||
|                     if ($_stream_resolve_include_path) { | ||||
|                         $plugin_dir = stream_resolve_include_path($_plugin_dir); | ||||
|                     } else { | ||||
|                         $plugin_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_plugin_dir); | ||||
|                     } | ||||
|  | ||||
|                     if ($plugin_dir !== false) { | ||||
|                         if ($errors === null) { | ||||
|                             echo "$plugin_dir is OK.\n"; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } else { | ||||
|                         $status = false; | ||||
|                         $message = "FAILED: $_plugin_dir does not exist (and couldn't be found in include_path either)"; | ||||
|                         if ($errors === null) { | ||||
|                             echo $message . ".\n"; | ||||
|                         } else { | ||||
|                             $errors['plugins_dir'] = $message; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } | ||||
|                 } else { | ||||
|                     $status = false; | ||||
|                     $message = "FAILED: $_plugin_dir does not exist"; | ||||
|                     if ($errors === null) { | ||||
|                         echo $message . ".\n"; | ||||
|                     } else { | ||||
|                         $errors['plugins_dir'] = $message; | ||||
|                     } | ||||
|  | ||||
|                     continue; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (!is_dir($plugin_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $plugin_dir is not a directory"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['plugins_dir'] = $message; | ||||
|                 } | ||||
|             } elseif (!is_readable($plugin_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $plugin_dir is not readable"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['plugins_dir'] = $message; | ||||
|                 } | ||||
|             } elseif ($_core_plugins_dir && $_core_plugins_dir == realpath($plugin_dir)) { | ||||
|                 $_core_plugins_available = true; | ||||
|                 if ($errors === null) { | ||||
|                     echo "$plugin_dir is OK.\n"; | ||||
|                 } | ||||
|             } else { | ||||
|                 if ($errors === null) { | ||||
|                     echo "$plugin_dir is OK.\n"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (!$_core_plugins_available) { | ||||
|             $status = false; | ||||
|             $message = "WARNING: Smarty's own libs/plugins is not available"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } elseif (!isset($errors['plugins_dir'])) { | ||||
|                 $errors['plugins_dir'] = $message; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing cache directory...\n"; | ||||
|         } | ||||
|  | ||||
|         // test if all registered cache_dir is accessible | ||||
|         $__cache_dir = $smarty->getCacheDir(); | ||||
|         $_cache_dir = realpath($__cache_dir); | ||||
|         if (!$_cache_dir) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$__cache_dir} does not exist"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['cache_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_dir($_cache_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_cache_dir} is not a directory"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['cache_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_readable($_cache_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_cache_dir} is not readable"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['cache_dir'] = $message; | ||||
|             } | ||||
|         } elseif (!is_writable($_cache_dir)) { | ||||
|             $status = false; | ||||
|             $message = "FAILED: {$_cache_dir} is not writable"; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['cache_dir'] = $message; | ||||
|             } | ||||
|         } else { | ||||
|             if ($errors === null) { | ||||
|                 echo "{$_cache_dir} is OK.\n"; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing configs directory...\n"; | ||||
|         } | ||||
|  | ||||
|         // test if all registered config_dir are accessible | ||||
|         foreach ($smarty->getConfigDir() as $config_dir) { | ||||
|             $_config_dir = $config_dir; | ||||
|             $config_dir = realpath($config_dir); | ||||
|             // resolve include_path or fail existence | ||||
|             if (!$config_dir) { | ||||
|                 if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_config_dir)) { | ||||
|                     // try PHP include_path | ||||
|                     if ($_stream_resolve_include_path) { | ||||
|                         $config_dir = stream_resolve_include_path($_config_dir); | ||||
|                     } else { | ||||
|                         $config_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_config_dir); | ||||
|                     } | ||||
|  | ||||
|                     if ($config_dir !== false) { | ||||
|                         if ($errors === null) { | ||||
|                             echo "$config_dir is OK.\n"; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } else { | ||||
|                         $status = false; | ||||
|                         $message = "FAILED: $_config_dir does not exist (and couldn't be found in include_path either)"; | ||||
|                         if ($errors === null) { | ||||
|                             echo $message . ".\n"; | ||||
|                         } else { | ||||
|                             $errors['config_dir'] = $message; | ||||
|                         } | ||||
|  | ||||
|                         continue; | ||||
|                     } | ||||
|                 } else { | ||||
|                     $status = false; | ||||
|                     $message = "FAILED: $_config_dir does not exist"; | ||||
|                     if ($errors === null) { | ||||
|                         echo $message . ".\n"; | ||||
|                     } else { | ||||
|                         $errors['config_dir'] = $message; | ||||
|                     } | ||||
|  | ||||
|                     continue; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (!is_dir($config_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $config_dir is not a directory"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['config_dir'] = $message; | ||||
|                 } | ||||
|             } elseif (!is_readable($config_dir)) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: $config_dir is not readable"; | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['config_dir'] = $message; | ||||
|                 } | ||||
|             } else { | ||||
|                 if ($errors === null) { | ||||
|                     echo "$config_dir is OK.\n"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing sysplugin files...\n"; | ||||
|         } | ||||
|         // test if sysplugins are available | ||||
|         $source = SMARTY_SYSPLUGINS_DIR; | ||||
|         if (is_dir($source)) { | ||||
|             $expected = array( | ||||
|                 "smarty_cacheresource.php"                                  => true, | ||||
|                 "smarty_cacheresource_custom.php"                           => true, | ||||
|                 "smarty_cacheresource_keyvaluestore.php"                    => true, | ||||
|                 "smarty_config_source.php"                                  => true, | ||||
|                 "smarty_internal_cacheresource_file.php"                    => true, | ||||
|                 "smarty_internal_compile_append.php"                        => true, | ||||
|                 "smarty_internal_compile_assign.php"                        => true, | ||||
|                 "smarty_internal_compile_block.php"                         => true, | ||||
|                 "smarty_internal_compile_break.php"                         => true, | ||||
|                 "smarty_internal_compile_call.php"                          => true, | ||||
|                 "smarty_internal_compile_capture.php"                       => true, | ||||
|                 "smarty_internal_compile_config_load.php"                   => true, | ||||
|                 "smarty_internal_compile_continue.php"                      => true, | ||||
|                 "smarty_internal_compile_debug.php"                         => true, | ||||
|                 "smarty_internal_compile_eval.php"                          => true, | ||||
|                 "smarty_internal_compile_extends.php"                       => true, | ||||
|                 "smarty_internal_compile_for.php"                           => true, | ||||
|                 "smarty_internal_compile_foreach.php"                       => true, | ||||
|                 "smarty_internal_compile_function.php"                      => true, | ||||
|                 "smarty_internal_compile_if.php"                            => true, | ||||
|                 "smarty_internal_compile_include.php"                       => true, | ||||
|                 "smarty_internal_compile_include_php.php"                   => true, | ||||
|                 "smarty_internal_compile_insert.php"                        => true, | ||||
|                 "smarty_internal_compile_ldelim.php"                        => true, | ||||
|                 "smarty_internal_compile_nocache.php"                       => true, | ||||
|                 "smarty_internal_compile_private_block_plugin.php"          => true, | ||||
|                 "smarty_internal_compile_private_function_plugin.php"       => true, | ||||
|                 "smarty_internal_compile_private_modifier.php"              => true, | ||||
|                 "smarty_internal_compile_private_object_block_function.php" => true, | ||||
|                 "smarty_internal_compile_private_object_function.php"       => true, | ||||
|                 "smarty_internal_compile_private_print_expression.php"      => true, | ||||
|                 "smarty_internal_compile_private_registered_block.php"      => true, | ||||
|                 "smarty_internal_compile_private_registered_function.php"   => true, | ||||
|                 "smarty_internal_compile_private_special_variable.php"      => true, | ||||
|                 "smarty_internal_compile_rdelim.php"                        => true, | ||||
|                 "smarty_internal_compile_section.php"                       => true, | ||||
|                 "smarty_internal_compile_setfilter.php"                     => true, | ||||
|                 "smarty_internal_compile_while.php"                         => true, | ||||
|                 "smarty_internal_compilebase.php"                           => true, | ||||
|                 "smarty_internal_config.php"                                => true, | ||||
|                 "smarty_internal_config_file_compiler.php"                  => true, | ||||
|                 "smarty_internal_configfilelexer.php"                       => true, | ||||
|                 "smarty_internal_configfileparser.php"                      => true, | ||||
|                 "smarty_internal_data.php"                                  => true, | ||||
|                 "smarty_internal_debug.php"                                 => true, | ||||
|                 "smarty_internal_filter_handler.php"                        => true, | ||||
|                 "smarty_internal_function_call_handler.php"                 => true, | ||||
|                 "smarty_internal_get_include_path.php"                      => true, | ||||
|                 "smarty_internal_nocache_insert.php"                        => true, | ||||
|                 "smarty_internal_parsetree.php"                             => true, | ||||
|                 "smarty_internal_resource_eval.php"                         => true, | ||||
|                 "smarty_internal_resource_extends.php"                      => true, | ||||
|                 "smarty_internal_resource_file.php"                         => true, | ||||
|                 "smarty_internal_resource_registered.php"                   => true, | ||||
|                 "smarty_internal_resource_stream.php"                       => true, | ||||
|                 "smarty_internal_resource_string.php"                       => true, | ||||
|                 "smarty_internal_smartytemplatecompiler.php"                => true, | ||||
|                 "smarty_internal_template.php"                              => true, | ||||
|                 "smarty_internal_templatebase.php"                          => true, | ||||
|                 "smarty_internal_templatecompilerbase.php"                  => true, | ||||
|                 "smarty_internal_templatelexer.php"                         => true, | ||||
|                 "smarty_internal_templateparser.php"                        => true, | ||||
|                 "smarty_internal_utility.php"                               => true, | ||||
|                 "smarty_internal_write_file.php"                            => true, | ||||
|                 "smarty_resource.php"                                       => true, | ||||
|                 "smarty_resource_custom.php"                                => true, | ||||
|                 "smarty_resource_recompiled.php"                            => true, | ||||
|                 "smarty_resource_uncompiled.php"                            => true, | ||||
|                 "smarty_security.php"                                       => true, | ||||
|             ); | ||||
|             $iterator = new DirectoryIterator($source); | ||||
|             foreach ($iterator as $file) { | ||||
|                 if (!$file->isDot()) { | ||||
|                     $filename = $file->getFilename(); | ||||
|                     if (isset($expected[$filename])) { | ||||
|                         unset($expected[$filename]); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($expected) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: files missing from libs/sysplugins: " . join(', ', array_keys($expected)); | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['sysplugins'] = $message; | ||||
|                 } | ||||
|             } elseif ($errors === null) { | ||||
|                 echo "... OK\n"; | ||||
|             } | ||||
|         } else { | ||||
|             $status = false; | ||||
|             $message = "FAILED: " . SMARTY_SYSPLUGINS_DIR . ' is not a directory'; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['sysplugins_dir_constant'] = $message; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Testing plugin files...\n"; | ||||
|         } | ||||
|         // test if core plugins are available | ||||
|         $source = SMARTY_PLUGINS_DIR; | ||||
|         if (is_dir($source)) { | ||||
|             $expected = array( | ||||
|                 "block.textformat.php"                  => true, | ||||
|                 "function.counter.php"                  => true, | ||||
|                 "function.cycle.php"                    => true, | ||||
|                 "function.fetch.php"                    => true, | ||||
|                 "function.html_checkboxes.php"          => true, | ||||
|                 "function.html_image.php"               => true, | ||||
|                 "function.html_options.php"             => true, | ||||
|                 "function.html_radios.php"              => true, | ||||
|                 "function.html_select_date.php"         => true, | ||||
|                 "function.html_select_time.php"         => true, | ||||
|                 "function.html_table.php"               => true, | ||||
|                 "function.mailto.php"                   => true, | ||||
|                 "function.math.php"                     => true, | ||||
|                 "modifier.capitalize.php"               => true, | ||||
|                 "modifier.date_format.php"              => true, | ||||
|                 "modifier.debug_print_var.php"          => true, | ||||
|                 "modifier.escape.php"                   => true, | ||||
|                 "modifier.regex_replace.php"            => true, | ||||
|                 "modifier.replace.php"                  => true, | ||||
|                 "modifier.spacify.php"                  => true, | ||||
|                 "modifier.truncate.php"                 => true, | ||||
|                 "modifiercompiler.cat.php"              => true, | ||||
|                 "modifiercompiler.count_characters.php" => true, | ||||
|                 "modifiercompiler.count_paragraphs.php" => true, | ||||
|                 "modifiercompiler.count_sentences.php"  => true, | ||||
|                 "modifiercompiler.count_words.php"      => true, | ||||
|                 "modifiercompiler.default.php"          => true, | ||||
|                 "modifiercompiler.escape.php"           => true, | ||||
|                 "modifiercompiler.from_charset.php"     => true, | ||||
|                 "modifiercompiler.indent.php"           => true, | ||||
|                 "modifiercompiler.lower.php"            => true, | ||||
|                 "modifiercompiler.noprint.php"          => true, | ||||
|                 "modifiercompiler.string_format.php"    => true, | ||||
|                 "modifiercompiler.strip.php"            => true, | ||||
|                 "modifiercompiler.strip_tags.php"       => true, | ||||
|                 "modifiercompiler.to_charset.php"       => true, | ||||
|                 "modifiercompiler.unescape.php"         => true, | ||||
|                 "modifiercompiler.upper.php"            => true, | ||||
|                 "modifiercompiler.wordwrap.php"         => true, | ||||
|                 "outputfilter.trimwhitespace.php"       => true, | ||||
|                 "shared.escape_special_chars.php"       => true, | ||||
|                 "shared.literal_compiler_param.php"     => true, | ||||
|                 "shared.make_timestamp.php"             => true, | ||||
|                 "shared.mb_str_replace.php"             => true, | ||||
|                 "shared.mb_unicode.php"                 => true, | ||||
|                 "shared.mb_wordwrap.php"                => true, | ||||
|                 "variablefilter.htmlspecialchars.php"   => true, | ||||
|             ); | ||||
|             $iterator = new DirectoryIterator($source); | ||||
|             foreach ($iterator as $file) { | ||||
|                 if (!$file->isDot()) { | ||||
|                     $filename = $file->getFilename(); | ||||
|                     if (isset($expected[$filename])) { | ||||
|                         unset($expected[$filename]); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($expected) { | ||||
|                 $status = false; | ||||
|                 $message = "FAILED: files missing from libs/plugins: " . join(', ', array_keys($expected)); | ||||
|                 if ($errors === null) { | ||||
|                     echo $message . ".\n"; | ||||
|                 } else { | ||||
|                     $errors['plugins'] = $message; | ||||
|                 } | ||||
|             } elseif ($errors === null) { | ||||
|                 echo "... OK\n"; | ||||
|             } | ||||
|         } else { | ||||
|             $status = false; | ||||
|             $message = "FAILED: " . SMARTY_PLUGINS_DIR . ' is not a directory'; | ||||
|             if ($errors === null) { | ||||
|                 echo $message . ".\n"; | ||||
|             } else { | ||||
|                 $errors['plugins_dir_constant'] = $message; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($errors === null) { | ||||
|             echo "Tests complete.\n"; | ||||
|             echo "</PRE>\n"; | ||||
|         } | ||||
|  | ||||
|         return $status; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,86 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty write file plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Monte Ohrt | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Write File Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  */ | ||||
| class Smarty_Internal_Write_File | ||||
| { | ||||
|     /** | ||||
|      * Writes file in a safe way to disk | ||||
|      * | ||||
|      * @param  string $_filepath complete filepath | ||||
|      * @param  string $_contents file content | ||||
|      * @param  Smarty $smarty    smarty instance | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return boolean true | ||||
|      */ | ||||
|     public static function writeFile($_filepath, $_contents, Smarty $smarty) | ||||
|     { | ||||
|         $_error_reporting = error_reporting(); | ||||
|         error_reporting($_error_reporting & ~E_NOTICE & ~E_WARNING); | ||||
|         if ($smarty->_file_perms !== null) { | ||||
|             $old_umask = umask(0); | ||||
|         } | ||||
|  | ||||
|         $_dirpath = dirname($_filepath); | ||||
|         // if subdirs, create dir structure | ||||
|         if ($_dirpath !== '.' && !file_exists($_dirpath)) { | ||||
|             mkdir($_dirpath, $smarty->_dir_perms === null ? 0777 : $smarty->_dir_perms, true); | ||||
|         } | ||||
|  | ||||
|         // write to tmp file, then move to overt file lock race condition | ||||
|         $_tmp_file = $_dirpath . DS . str_replace(array('.', ','), '_', uniqid('wrt', true)); | ||||
|         if (!file_put_contents($_tmp_file, $_contents)) { | ||||
|             error_reporting($_error_reporting); | ||||
|             throw new SmartyException("unable to write file {$_tmp_file}"); | ||||
|        } | ||||
|  | ||||
|         /* | ||||
|          * Windows' rename() fails if the destination exists, | ||||
|          * Linux' rename() properly handles the overwrite. | ||||
|          * Simply unlink()ing a file might cause other processes | ||||
|          * currently reading that file to fail, but linux' rename() | ||||
|          * seems to be smart enough to handle that for us. | ||||
|          */ | ||||
|         if (Smarty::$_IS_WINDOWS) { | ||||
|             // remove original file | ||||
|             @unlink($_filepath); | ||||
|             // rename tmp file | ||||
|             $success = @rename($_tmp_file, $_filepath); | ||||
|         } else { | ||||
|             // rename tmp file | ||||
|             $success = @rename($_tmp_file, $_filepath); | ||||
|             if (!$success) { | ||||
|                 // remove original file | ||||
|                 @unlink($_filepath); | ||||
|                 // rename tmp file | ||||
|                 $success = @rename($_tmp_file, $_filepath); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (!$success) { | ||||
|             error_reporting($_error_reporting); | ||||
|             throw new SmartyException("unable to write file {$_filepath}"); | ||||
|         } | ||||
|  | ||||
|         if ($smarty->_file_perms !== null) { | ||||
|             // set file permissions | ||||
|             chmod($_filepath, $smarty->_file_perms); | ||||
|             umask($old_umask); | ||||
|         } | ||||
|         error_reporting($_error_reporting); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										912
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_resource.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										912
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_resource.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,912 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * Base implementation for resource plugins | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| abstract class Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * cache for Smarty_Template_Source instances | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $sources = array(); | ||||
|     /** | ||||
|      * cache for Smarty_Template_Compiled instances | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $compileds = array(); | ||||
|     /** | ||||
|      * cache for Smarty_Resource instances | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public static $resources = array(); | ||||
|     /** | ||||
|      * resource types provided by the core | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected static $sysplugins = array( | ||||
|         'file'    => true, | ||||
|         'string'  => true, | ||||
|         'extends' => true, | ||||
|         'stream'  => true, | ||||
|         'eval'    => true, | ||||
|         'php'     => true | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * Name of the Class to compile this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler'; | ||||
|  | ||||
|     /** | ||||
|      * Name of the Class to tokenize this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_lexer_class = 'Smarty_Internal_Templatelexer'; | ||||
|  | ||||
|     /** | ||||
|      * Name of the Class to parse this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_parser_class = 'Smarty_Internal_Templateparser'; | ||||
|  | ||||
|     /** | ||||
|      * Load template's source into current template object | ||||
|      * {@internal The loaded source is assigned to $_template->source->content directly.}} | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      * @throws SmartyException        if source cannot be loaded | ||||
|      */ | ||||
|     abstract public function getContent(Smarty_Template_Source $source); | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source   $source    source object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     abstract public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null); | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with timestamp and exists from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object | ||||
|      */ | ||||
|     public function populateTimestamp(Smarty_Template_Source $source) | ||||
|     { | ||||
|         // intentionally left blank | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * modify resource_name according to resource handlers specifications | ||||
|      * | ||||
|      * @param  Smarty  $smarty        Smarty instance | ||||
|      * @param  string  $resource_name resource_name to make unique | ||||
|      * @param  boolean $is_config     flag for config resource | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|     protected function buildUniqueResourceName(Smarty $smarty, $resource_name, $is_config = false) | ||||
|     { | ||||
|         if ($is_config) { | ||||
|             return get_class($this) . '#' . $smarty->joined_config_dir . '#' . $resource_name; | ||||
|         } else { | ||||
|             return get_class($this) . '#' . $smarty->joined_template_dir . '#' . $resource_name; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Compiled Object with compiled filepath | ||||
|      * | ||||
|      * @param Smarty_Template_Compiled $compiled  compiled object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     public function populateCompiledFilepath(Smarty_Template_Compiled $compiled, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null; | ||||
|         $_filepath = $compiled->source->uid; | ||||
|         // if use_sub_dirs, break file into directories | ||||
|         if ($_template->smarty->use_sub_dirs) { | ||||
|             $_filepath = substr($_filepath, 0, 2) . DS | ||||
|                 . substr($_filepath, 2, 2) . DS | ||||
|                 . substr($_filepath, 4, 2) . DS | ||||
|                 . $_filepath; | ||||
|         } | ||||
|         $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^'; | ||||
|         if (isset($_compile_id)) { | ||||
|             $_filepath = $_compile_id . $_compile_dir_sep . $_filepath; | ||||
|         } | ||||
|         // caching token | ||||
|         if ($_template->caching) { | ||||
|             $_cache = '.cache'; | ||||
|         } else { | ||||
|             $_cache = ''; | ||||
|         } | ||||
|         $_compile_dir = $_template->smarty->getCompileDir(); | ||||
|         // set basename if not specified | ||||
|         $_basename = $this->getBasename($compiled->source); | ||||
|         if ($_basename === null) { | ||||
|             $_basename = basename(preg_replace('![^\w\/]+!', '_', $compiled->source->name)); | ||||
|         } | ||||
|         // separate (optional) basename by dot | ||||
|         if ($_basename) { | ||||
|             $_basename = '.' . $_basename; | ||||
|         } | ||||
|  | ||||
|         $compiled->filepath = $_compile_dir . $_filepath . '.' . $compiled->source->type . $_basename . $_cache . '.php'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Normalize Paths "foo/../bar" to "bar" | ||||
|      * | ||||
|      * @param  string  $_path path to normalize | ||||
|      * @param  boolean $ds    respect windows directory separator | ||||
|      * | ||||
|      * @return string  normalized path | ||||
|      */ | ||||
|     protected function normalizePath($_path, $ds = true) | ||||
|     { | ||||
|         if ($ds) { | ||||
|             // don't we all just love windows? | ||||
|             $_path = str_replace('\\', '/', $_path); | ||||
|         } | ||||
|  | ||||
|         $offset = 0; | ||||
|  | ||||
|         // resolve simples | ||||
|         $_path = preg_replace('#/\./(\./)*#', '/', $_path); | ||||
|         // resolve parents | ||||
|         while (true) { | ||||
|             $_parent = strpos($_path, '/../', $offset); | ||||
|             if (!$_parent) { | ||||
|                 break; | ||||
|             } elseif ($_path[$_parent - 1] === '.') { | ||||
|                 $offset = $_parent + 3; | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $_pos = strrpos($_path, '/', $_parent - strlen($_path) - 1); | ||||
|             if ($_pos === false) { | ||||
|                 // don't we all just love windows? | ||||
|                 $_pos = $_parent; | ||||
|             } | ||||
|  | ||||
|             $_path = substr_replace($_path, '', $_pos, $_parent + 3 - $_pos); | ||||
|         } | ||||
|  | ||||
|         if ($ds && DS != '/') { | ||||
|             // don't we all just love windows? | ||||
|             $_path = str_replace('/', '\\', $_path); | ||||
|         } | ||||
|  | ||||
|         return $_path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * build template filepath by traversing the template_dir array | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return string                   fully qualified filepath | ||||
|      * @throws SmartyException          if default template handler is registered but not callable | ||||
|      */ | ||||
|     protected function buildFilepath(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $file = $source->name; | ||||
|         if ($source instanceof Smarty_Config_Source) { | ||||
|             $_directories = $source->smarty->getConfigDir(); | ||||
|             $_default_handler = $source->smarty->default_config_handler_func; | ||||
|         } else { | ||||
|             $_directories = $source->smarty->getTemplateDir(); | ||||
|             $_default_handler = $source->smarty->default_template_handler_func; | ||||
|         } | ||||
|  | ||||
|         // go relative to a given template? | ||||
|         $_file_is_dotted = $file[0] == '.' && ($file[1] == '.' || $file[1] == '/' || $file[1] == "\\"); | ||||
|         if ($_template && $_template->parent instanceof Smarty_Internal_Template && $_file_is_dotted) { | ||||
|             if ($_template->parent->source->type != 'file' && $_template->parent->source->type != 'extends' && !$_template->parent->allow_relative_path) { | ||||
|                 throw new SmartyException("Template '{$file}' cannot be relative to template of resource type '{$_template->parent->source->type}'"); | ||||
|             } | ||||
|             $file = dirname($_template->parent->source->filepath) . DS . $file; | ||||
|             $_file_exact_match = true; | ||||
|             if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) { | ||||
|                 // the path gained from the parent template is relative to the current working directory | ||||
|                 // as expansions (like include_path) have already been done | ||||
|                 $file = getcwd() . DS . $file; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // resolve relative path | ||||
|         if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) { | ||||
|             // don't we all just love windows? | ||||
|             $_path = DS . trim($file, '/'); | ||||
|             $_was_relative = true; | ||||
|         } else { | ||||
|             // don't we all just love windows? | ||||
|             $_path = str_replace('\\', '/', $file); | ||||
|         } | ||||
|         $_path = $this->normalizePath($_path, false); | ||||
|         if (DS != '/') { | ||||
|             // don't we all just love windows? | ||||
|             $_path = str_replace('/', '\\', $_path); | ||||
|         } | ||||
|         // revert to relative | ||||
|         if (isset($_was_relative)) { | ||||
|             $_path = substr($_path, 1); | ||||
|         } | ||||
|  | ||||
|         // this is only required for directories | ||||
|         $file = rtrim($_path, '/\\'); | ||||
|  | ||||
|         // files relative to a template only get one shot | ||||
|         if (isset($_file_exact_match)) { | ||||
|             return $this->fileExists($source, $file) ? $file : false; | ||||
|         } | ||||
|  | ||||
|         // template_dir index? | ||||
|         if (preg_match('#^\[(?P<key>[^\]]+)\](?P<file>.+)$#', $file, $match)) { | ||||
|             $_directory = null; | ||||
|             // try string indexes | ||||
|             if (isset($_directories[$match['key']])) { | ||||
|                 $_directory = $_directories[$match['key']]; | ||||
|             } elseif (is_numeric($match['key'])) { | ||||
|                 // try numeric index | ||||
|                 $match['key'] = (int) $match['key']; | ||||
|                 if (isset($_directories[$match['key']])) { | ||||
|                     $_directory = $_directories[$match['key']]; | ||||
|                 } else { | ||||
|                     // try at location index | ||||
|                     $keys = array_keys($_directories); | ||||
|                     $_directory = $_directories[$keys[$match['key']]]; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if ($_directory) { | ||||
|                 $_file = substr($file, strpos($file, ']') + 1); | ||||
|                 $_filepath = $_directory . $_file; | ||||
|                 if ($this->fileExists($source, $_filepath)) { | ||||
|                     return $_filepath; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $_stream_resolve_include_path = function_exists('stream_resolve_include_path'); | ||||
|  | ||||
|         // relative file name? | ||||
|         if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) { | ||||
|             foreach ($_directories as $_directory) { | ||||
|                 $_filepath = $_directory . $file; | ||||
|                 if ($this->fileExists($source, $_filepath)) { | ||||
|                     return $this->normalizePath($_filepath); | ||||
|                 } | ||||
|                 if ($source->smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_directory)) { | ||||
|                     // try PHP include_path | ||||
|                     if ($_stream_resolve_include_path) { | ||||
|                         $_filepath = stream_resolve_include_path($_filepath); | ||||
|                     } else { | ||||
|                         $_filepath = Smarty_Internal_Get_Include_Path::getIncludePath($_filepath); | ||||
|                     } | ||||
|  | ||||
|                     if ($_filepath !== false) { | ||||
|                         if ($this->fileExists($source, $_filepath)) { | ||||
|                             return $this->normalizePath($_filepath); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // try absolute filepath | ||||
|         if ($this->fileExists($source, $file)) { | ||||
|             return $file; | ||||
|         } | ||||
|  | ||||
|         // no tpl file found | ||||
|         if ($_default_handler) { | ||||
|             if (!is_callable($_default_handler)) { | ||||
|                 if ($source instanceof Smarty_Config_Source) { | ||||
|                     throw new SmartyException("Default config handler not callable"); | ||||
|                 } else { | ||||
|                     throw new SmartyException("Default template handler not callable"); | ||||
|                 } | ||||
|             } | ||||
|             $_return = call_user_func_array($_default_handler, | ||||
|                                             array($source->type, $source->name, &$_content, &$_timestamp, $source->smarty)); | ||||
|             if (is_string($_return)) { | ||||
|                 $source->timestamp = @filemtime($_return); | ||||
|                 $source->exists = !!$source->timestamp; | ||||
|  | ||||
|                 return $_return; | ||||
|             } elseif ($_return === true) { | ||||
|                 $source->content = $_content; | ||||
|                 $source->timestamp = $_timestamp; | ||||
|                 $source->exists = true; | ||||
|  | ||||
|                 return $_filepath; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // give up | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * test is file exists and save timestamp | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * @param  string                 $file   file name | ||||
|      * | ||||
|      * @return bool                   true if file exists | ||||
|      */ | ||||
|     protected function fileExists(Smarty_Template_Source $source, $file) | ||||
|     { | ||||
|         $source->timestamp = is_file($file) ? @filemtime($file) : false; | ||||
|  | ||||
|         return $source->exists = !!$source->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     protected function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load Resource Handler | ||||
|      * | ||||
|      * @param  Smarty $smarty smarty object | ||||
|      * @param  string $type   name of the resource | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return Smarty_Resource Resource Handler | ||||
|      */ | ||||
|     public static function load(Smarty $smarty, $type) | ||||
|     { | ||||
|         // try smarty's cache | ||||
|         if (isset($smarty->_resource_handlers[$type])) { | ||||
|             return $smarty->_resource_handlers[$type]; | ||||
|         } | ||||
|  | ||||
|         // try registered resource | ||||
|         if (isset($smarty->registered_resources[$type])) { | ||||
|             if ($smarty->registered_resources[$type] instanceof Smarty_Resource) { | ||||
|                 $smarty->_resource_handlers[$type] = $smarty->registered_resources[$type]; | ||||
|                 // note registered to smarty is not kept unique! | ||||
|                 return $smarty->_resource_handlers[$type]; | ||||
|             } | ||||
|  | ||||
|             if (!isset(self::$resources['registered'])) { | ||||
|                 self::$resources['registered'] = new Smarty_Internal_Resource_Registered(); | ||||
|             } | ||||
|             if (!isset($smarty->_resource_handlers[$type])) { | ||||
|                 $smarty->_resource_handlers[$type] = self::$resources['registered']; | ||||
|             } | ||||
|  | ||||
|             return $smarty->_resource_handlers[$type]; | ||||
|         } | ||||
|  | ||||
|         // try sysplugins dir | ||||
|         if (isset(self::$sysplugins[$type])) { | ||||
|             if (!isset(self::$resources[$type])) { | ||||
|                 $_resource_class = 'Smarty_Internal_Resource_' . ucfirst($type); | ||||
|                 self::$resources[$type] = new $_resource_class(); | ||||
|             } | ||||
|  | ||||
|             return $smarty->_resource_handlers[$type] = self::$resources[$type]; | ||||
|         } | ||||
|  | ||||
|         // try plugins dir | ||||
|         $_resource_class = 'Smarty_Resource_' . ucfirst($type); | ||||
|         if ($smarty->loadPlugin($_resource_class)) { | ||||
|             if (isset(self::$resources[$type])) { | ||||
|                 return $smarty->_resource_handlers[$type] = self::$resources[$type]; | ||||
|             } | ||||
|  | ||||
|             if (class_exists($_resource_class, false)) { | ||||
|                 self::$resources[$type] = new $_resource_class(); | ||||
|  | ||||
|                 return $smarty->_resource_handlers[$type] = self::$resources[$type]; | ||||
|             } else { | ||||
|                 $smarty->registerResource($type, array( | ||||
|                     "smarty_resource_{$type}_source", | ||||
|                     "smarty_resource_{$type}_timestamp", | ||||
|                     "smarty_resource_{$type}_secure", | ||||
|                     "smarty_resource_{$type}_trusted" | ||||
|                 )); | ||||
|  | ||||
|                 // give it another try, now that the resource is registered properly | ||||
|                 return self::load($smarty, $type); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // try streams | ||||
|         $_known_stream = stream_get_wrappers(); | ||||
|         if (in_array($type, $_known_stream)) { | ||||
|             // is known stream | ||||
|             if (is_object($smarty->security_policy)) { | ||||
|                 $smarty->security_policy->isTrustedStream($type); | ||||
|             } | ||||
|             if (!isset(self::$resources['stream'])) { | ||||
|                 self::$resources['stream'] = new Smarty_Internal_Resource_Stream(); | ||||
|             } | ||||
|  | ||||
|             return $smarty->_resource_handlers[$type] = self::$resources['stream']; | ||||
|         } | ||||
|  | ||||
|         // TODO: try default_(template|config)_handler | ||||
|  | ||||
|         // give up | ||||
|         throw new SmartyException("Unknown resource type '{$type}'"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * extract resource_type and resource_name from template_resource and config_resource | ||||
|      * @note "C:/foo.tpl" was forced to file resource up till Smarty 3.1.3 (including). | ||||
|      * | ||||
|      * @param  string $resource_name    template_resource or config_resource to parse | ||||
|      * @param  string $default_resource the default resource_type defined in $smarty | ||||
|      * @param  string &$name            the parsed resource name | ||||
|      * @param  string &$type            the parsed resource type | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     protected static function parseResourceName($resource_name, $default_resource, &$name, &$type) | ||||
|     { | ||||
|         $parts = explode(':', $resource_name, 2); | ||||
|         if (!isset($parts[1]) || !isset($parts[0][1])) { | ||||
|             // no resource given, use default | ||||
|             // or single character before the colon is not a resource type, but part of the filepath | ||||
|             $type = $default_resource; | ||||
|             $name = $resource_name; | ||||
|         } else { | ||||
|             $type = $parts[0]; | ||||
|             $name = $parts[1]; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * modify resource_name according to resource handlers specifications | ||||
|      * | ||||
|      * @param  Smarty $smarty        Smarty instance | ||||
|      * @param  string $resource_name resource_name to make unique | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|  | ||||
|     /** | ||||
|      * modify template_resource according to resource handlers specifications | ||||
|      * | ||||
|      * @param  Smarty_Internal_template $template          Smarty instance | ||||
|      * @param  string                   $template_resource template_resource to extract resource handler and name of | ||||
|      * | ||||
|      * @return string unique resource name | ||||
|      */ | ||||
|     public static function getUniqueTemplateName($template, $template_resource) | ||||
|     { | ||||
|         self::parseResourceName($template_resource, $template->smarty->default_resource_type, $name, $type); | ||||
|         // TODO: optimize for Smarty's internal resource types | ||||
|         $resource = Smarty_Resource::load($template->smarty, $type); | ||||
|         // go relative to a given template? | ||||
|         $_file_is_dotted = $name[0] == '.' && ($name[1] == '.' || $name[1] == '/' || $name[1] == "\\"); | ||||
|         if ($template instanceof Smarty_Internal_Template && $_file_is_dotted && ($template->source->type == 'file' || $template->parent->source->type == 'extends')) { | ||||
|             $name = dirname($template->source->filepath) . DS . $name; | ||||
|         } | ||||
|         return $resource->buildUniqueResourceName($template->smarty, $name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * initialize Source Object for given resource | ||||
|      * Either [$_template] or [$smarty, $template_resource] must be specified | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template $_template         template object | ||||
|      * @param  Smarty                   $smarty            smarty object | ||||
|      * @param  string                   $template_resource resource identifier | ||||
|      * | ||||
|      * @return Smarty_Template_Source   Source Object | ||||
|      */ | ||||
|     public static function source(Smarty_Internal_Template $_template = null, Smarty $smarty = null, $template_resource = null) | ||||
|     { | ||||
|         if ($_template) { | ||||
|             $smarty = $_template->smarty; | ||||
|             $template_resource = $_template->template_resource; | ||||
|         } | ||||
|  | ||||
|         // parse resource_name, load resource handler, identify unique resource name | ||||
|         self::parseResourceName($template_resource, $smarty->default_resource_type, $name, $type); | ||||
|         $resource = Smarty_Resource::load($smarty, $type); | ||||
|         // go relative to a given template? | ||||
|         $_file_is_dotted = isset($name[0]) && $name[0] == '.' && ($name[1] == '.' || $name[1] == '/' || $name[1] == "\\"); | ||||
|         if ($_file_is_dotted && isset($_template) && $_template->parent instanceof Smarty_Internal_Template && ($_template->parent->source->type == 'file' || $_template->parent->source->type == 'extends')) { | ||||
|             $name2 = dirname($_template->parent->source->filepath) . DS . $name; | ||||
|         } else { | ||||
|             $name2 = $name; | ||||
|         } | ||||
|         $unique_resource_name = $resource->buildUniqueResourceName($smarty, $name2); | ||||
|  | ||||
|         // check runtime cache | ||||
|         $_cache_key = 'template|' . $unique_resource_name; | ||||
|         if ($smarty->compile_id) { | ||||
|             $_cache_key .= '|' . $smarty->compile_id; | ||||
|         } | ||||
|         if (isset(self::$sources[$_cache_key])) { | ||||
|             return self::$sources[$_cache_key]; | ||||
|         } | ||||
|  | ||||
|         // create source | ||||
|         $source = new Smarty_Template_Source($resource, $smarty, $template_resource, $type, $name, $unique_resource_name); | ||||
|         $resource->populate($source, $_template); | ||||
|  | ||||
|         // runtime cache | ||||
|         self::$sources[$_cache_key] = $source; | ||||
|  | ||||
|         return $source; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * initialize Config Source Object for given resource | ||||
|      * | ||||
|      * @param  Smarty_Internal_Config $_config config object | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      * @return Smarty_Config_Source   Source Object | ||||
|      */ | ||||
|     public static function config(Smarty_Internal_Config $_config) | ||||
|     { | ||||
|         static $_incompatible_resources = array('eval' => true, 'string' => true, 'extends' => true, 'php' => true); | ||||
|         $config_resource = $_config->config_resource; | ||||
|         $smarty = $_config->smarty; | ||||
|  | ||||
|         // parse resource_name | ||||
|         self::parseResourceName($config_resource, $smarty->default_config_type, $name, $type); | ||||
|  | ||||
|         // make sure configs are not loaded via anything smarty can't handle | ||||
|         if (isset($_incompatible_resources[$type])) { | ||||
|             throw new SmartyException ("Unable to use resource '{$type}' for config"); | ||||
|         } | ||||
|  | ||||
|         // load resource handler, identify unique resource name | ||||
|         $resource = Smarty_Resource::load($smarty, $type); | ||||
|         $unique_resource_name = $resource->buildUniqueResourceName($smarty, $name, true); | ||||
|  | ||||
|         // check runtime cache | ||||
|         $_cache_key = 'config|' . $unique_resource_name; | ||||
|         if (isset(self::$sources[$_cache_key])) { | ||||
|             return self::$sources[$_cache_key]; | ||||
|         } | ||||
|  | ||||
|         // create source | ||||
|         $source = new Smarty_Config_Source($resource, $smarty, $config_resource, $type, $name, $unique_resource_name); | ||||
|         $resource->populate($source, null); | ||||
|  | ||||
|         // runtime cache | ||||
|         self::$sources[$_cache_key] = $source; | ||||
|  | ||||
|         return $source; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Data Object | ||||
|  * Meta Data Container for Template Files | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  * @property integer $timestamp Source Timestamp | ||||
|  * @property boolean $exists    Source Existence | ||||
|  * @property boolean $template  Extended Template reference | ||||
|  * @property string  $content   Source Content | ||||
|  */ | ||||
| class Smarty_Template_Source | ||||
| { | ||||
|     /** | ||||
|      * Name of the Class to compile this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $compiler_class = null; | ||||
|  | ||||
|     /** | ||||
|      * Name of the Class to tokenize this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_lexer_class = null; | ||||
|  | ||||
|     /** | ||||
|      * Name of the Class to parse this resource's contents with | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_parser_class = null; | ||||
|  | ||||
|     /** | ||||
|      * Unique Template ID | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $uid = null; | ||||
|  | ||||
|     /** | ||||
|      * Template Resource (Smarty_Internal_Template::$template_resource) | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $resource = null; | ||||
|  | ||||
|     /** | ||||
|      * Resource Type | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $type = null; | ||||
|  | ||||
|     /** | ||||
|      * Resource Name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $name = null; | ||||
|  | ||||
|     /** | ||||
|      * Unique Resource Name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $unique_resource = null; | ||||
|  | ||||
|     /** | ||||
|      * Source Filepath | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $filepath = null; | ||||
|  | ||||
|     /** | ||||
|      * Source is bypassing compiler | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $uncompiled = null; | ||||
|  | ||||
|     /** | ||||
|      * Source must be recompiled on every occasion | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $recompiled = null; | ||||
|  | ||||
|     /** | ||||
|      * The Components an extended template is made of | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $components = null; | ||||
|  | ||||
|     /** | ||||
|      * Resource Handler | ||||
|      * | ||||
|      * @var Smarty_Resource | ||||
|      */ | ||||
|     public $handler = null; | ||||
|  | ||||
|     /** | ||||
|      * Smarty instance | ||||
|      * | ||||
|      * @var Smarty | ||||
|      */ | ||||
|     public $smarty = null; | ||||
|  | ||||
|     /** | ||||
|      * create Source Object container | ||||
|      * | ||||
|      * @param Smarty_Resource $handler         Resource Handler this source object communicates with | ||||
|      * @param Smarty          $smarty          Smarty instance this source object belongs to | ||||
|      * @param string          $resource        full template_resource | ||||
|      * @param string          $type            type of resource | ||||
|      * @param string          $name            resource name | ||||
|      * @param string          $unique_resource unique resource name | ||||
|      */ | ||||
|     public function __construct(Smarty_Resource $handler, Smarty $smarty, $resource, $type, $name, $unique_resource) | ||||
|     { | ||||
|         $this->handler = $handler; // Note: prone to circular references | ||||
|  | ||||
|         $this->compiler_class = $handler->compiler_class; | ||||
|         $this->template_lexer_class = $handler->template_lexer_class; | ||||
|         $this->template_parser_class = $handler->template_parser_class; | ||||
|         $this->uncompiled = $this->handler instanceof Smarty_Resource_Uncompiled; | ||||
|         $this->recompiled = $this->handler instanceof Smarty_Resource_Recompiled; | ||||
|  | ||||
|         $this->smarty = $smarty; | ||||
|         $this->resource = $resource; | ||||
|         $this->type = $type; | ||||
|         $this->name = $name; | ||||
|         $this->unique_resource = $unique_resource; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * get a Compiled Object of this source | ||||
|      * | ||||
|      * @param  Smarty_Internal_Template|Smarty_Internal_Config $_template template object | ||||
|      * | ||||
|      * @return Smarty_Template_Compiled compiled object | ||||
|      */ | ||||
|     public function getCompiled($_template) | ||||
|     { | ||||
|         // check runtime cache | ||||
|         $_cache_key = $this->unique_resource . '#' . $_template->compile_id; | ||||
|         if (isset(Smarty_Resource::$compileds[$_cache_key])) { | ||||
|             return Smarty_Resource::$compileds[$_cache_key]; | ||||
|         } | ||||
|  | ||||
|         $compiled = new Smarty_Template_Compiled($this); | ||||
|         $this->handler->populateCompiledFilepath($compiled, $_template); | ||||
|         $compiled->timestamp = @filemtime($compiled->filepath); | ||||
|         $compiled->exists = !!$compiled->timestamp; | ||||
|  | ||||
|         // runtime cache | ||||
|         Smarty_Resource::$compileds[$_cache_key] = $compiled; | ||||
|  | ||||
|         return $compiled; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * render the uncompiled source | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     public function renderUncompiled(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         return $this->handler->renderUncompiled($this, $_template); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * <<magic>> Generic Setter. | ||||
|      * | ||||
|      * @param  string $property_name valid: timestamp, exists, content, template | ||||
|      * @param  mixed  $value         new value (is not checked) | ||||
|      * | ||||
|      * @throws SmartyException if $property_name is not valid | ||||
|      */ | ||||
|     public function __set($property_name, $value) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             // regular attributes | ||||
|             case 'timestamp': | ||||
|             case 'exists': | ||||
|             case 'content': | ||||
|                 // required for extends: only | ||||
|             case 'template': | ||||
|                 $this->$property_name = $value; | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 throw new SmartyException("invalid source property '$property_name'."); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * <<magic>> Generic getter. | ||||
|      * | ||||
|      * @param  string $property_name valid: timestamp, exists, content | ||||
|      * | ||||
|      * @return mixed | ||||
|      * @throws SmartyException if $property_name is not valid | ||||
|      */ | ||||
|     public function __get($property_name) | ||||
|     { | ||||
|         switch ($property_name) { | ||||
|             case 'timestamp': | ||||
|             case 'exists': | ||||
|                 $this->handler->populateTimestamp($this); | ||||
|  | ||||
|                 return $this->$property_name; | ||||
|  | ||||
|             case 'content': | ||||
|                 return $this->content = $this->handler->getContent($this); | ||||
|  | ||||
|             default: | ||||
|                 throw new SmartyException("source property '$property_name' does not exist."); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Data Object | ||||
|  * Meta Data Container for Template Files | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  * @property string $content compiled content | ||||
|  */ | ||||
| class Smarty_Template_Compiled | ||||
| { | ||||
|     /** | ||||
|      * Compiled Filepath | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $filepath = null; | ||||
|  | ||||
|     /** | ||||
|      * Compiled Timestamp | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $timestamp = null; | ||||
|  | ||||
|     /** | ||||
|      * Compiled Existence | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $exists = false; | ||||
|  | ||||
|     /** | ||||
|      * Compiled Content Loaded | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $loaded = false; | ||||
|  | ||||
|     /** | ||||
|      * Template was compiled | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $isCompiled = false; | ||||
|  | ||||
|     /** | ||||
|      * Source Object | ||||
|      * | ||||
|      * @var Smarty_Template_Source | ||||
|      */ | ||||
|     public $source = null; | ||||
|  | ||||
|     /** | ||||
|      * Metadata properties | ||||
|      * populated by Smarty_Internal_Template::decodeProperties() | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $_properties = null; | ||||
|  | ||||
|     /** | ||||
|      * create Compiled Object container | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source source object this compiled object belongs to | ||||
|      */ | ||||
|     public function __construct(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $this->source = $source; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										95
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_resource_custom.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_resource_custom.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,95 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * Wrapper Implementation for custom resource plugins | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| abstract class Smarty_Resource_Custom extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * fetch template and its modification time from data source | ||||
|      * | ||||
|      * @param string  $name    template name | ||||
|      * @param string  &$source template source | ||||
|      * @param integer &$mtime  template modification timestamp (epoch) | ||||
|      */ | ||||
|     abstract protected function fetch($name, &$source, &$mtime); | ||||
|  | ||||
|     /** | ||||
|      * Fetch template's modification timestamp from data source | ||||
|      * {@internal implementing this method is optional. | ||||
|      *  Only implement it if modification times can be accessed faster than loading the complete template source.}} | ||||
|      * | ||||
|      * @param  string $name template name | ||||
|      * | ||||
|      * @return integer|boolean timestamp (epoch) the template was modified, or false if not found | ||||
|      */ | ||||
|     protected function fetchTimestamp($name) | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * populate Source Object with meta data from Resource | ||||
|      * | ||||
|      * @param Smarty_Template_Source   $source    source object | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      */ | ||||
|     public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null) | ||||
|     { | ||||
|         $source->filepath = $source->type . ':' . $source->name; | ||||
|         $source->uid = sha1($source->type . ':' . $source->name); | ||||
|  | ||||
|         $mtime = $this->fetchTimestamp($source->name); | ||||
|         if ($mtime !== null) { | ||||
|             $source->timestamp = $mtime; | ||||
|         } else { | ||||
|             $this->fetch($source->name, $content, $timestamp); | ||||
|             $source->timestamp = isset($timestamp) ? $timestamp : false; | ||||
|             if (isset($content)) { | ||||
|                 $source->content = $content; | ||||
|             } | ||||
|         } | ||||
|         $source->exists = !!$source->timestamp; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Load template's source into current template object | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 template source | ||||
|      * @throws SmartyException        if source cannot be loaded | ||||
|      */ | ||||
|     public function getContent(Smarty_Template_Source $source) | ||||
|     { | ||||
|         $this->fetch($source->name, $content, $timestamp); | ||||
|         if (isset($content)) { | ||||
|             return $content; | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("Unable to read template {$source->type} '{$source->name}'"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Determine basename for compiled filename | ||||
|      * | ||||
|      * @param  Smarty_Template_Source $source source object | ||||
|      * | ||||
|      * @return string                 resource's basename | ||||
|      */ | ||||
|     protected function getBasename(Smarty_Template_Source $source) | ||||
|     { | ||||
|         return basename($source->name); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,33 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * Base implementation for resource plugins that don't compile cache | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| abstract class Smarty_Resource_Recompiled extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * populate Compiled Object with compiled filepath | ||||
|      * | ||||
|      * @param  Smarty_Template_Compiled $compiled  compiled object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function populateCompiledFilepath(Smarty_Template_Compiled $compiled, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $compiled->filepath = false; | ||||
|         $compiled->timestamp = false; | ||||
|         $compiled->exists = false; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Resource Plugin | ||||
|  * Base implementation for resource plugins that don't use the compiler | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage TemplateResources | ||||
|  */ | ||||
| abstract class Smarty_Resource_Uncompiled extends Smarty_Resource | ||||
| { | ||||
|     /** | ||||
|      * Render and output the template (without using the compiler) | ||||
|      * | ||||
|      * @param  Smarty_Template_Source   $source    source object | ||||
|      * @param  Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @throws SmartyException          on failure | ||||
|      */ | ||||
|     abstract public function renderUncompiled(Smarty_Template_Source $source, Smarty_Internal_Template $_template); | ||||
|  | ||||
|     /** | ||||
|      * populate compiled object with compiled filepath | ||||
|      * | ||||
|      * @param Smarty_Template_Compiled $compiled  compiled object | ||||
|      * @param Smarty_Internal_Template $_template template object (is ignored) | ||||
|      */ | ||||
|     public function populateCompiledFilepath(Smarty_Template_Compiled $compiled, Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $compiled->filepath = false; | ||||
|         $compiled->timestamp = false; | ||||
|         $compiled->exists = false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										480
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_security.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										480
									
								
								lib/old/smarty_3/libs/sysplugins/smarty_security.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,480 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Security | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * FIXME: Smarty_Security API | ||||
|  *      - getter and setter instead of public properties would allow cultivating an internal cache properly | ||||
|  *      - current implementation of isTrustedResourceDir() assumes that Smarty::$template_dir and Smarty::$config_dir are immutable | ||||
|  *        the cache is killed every time either of the variables change. That means that two distinct Smarty objects with differing | ||||
|  *        $template_dir or $config_dir should NOT share the same Smarty_Security instance, | ||||
|  *        as this would lead to (severe) performance penalty! how should this be handled? | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * This class does contain the security settings | ||||
|  */ | ||||
| class Smarty_Security | ||||
| { | ||||
|     /** | ||||
|      * This determines how Smarty handles "<?php ... ?>" tags in templates. | ||||
|      * possible values: | ||||
|      * <ul> | ||||
|      *   <li>Smarty::PHP_PASSTHRU -> echo PHP tags as they are</li> | ||||
|      *   <li>Smarty::PHP_QUOTE    -> escape tags as entities</li> | ||||
|      *   <li>Smarty::PHP_REMOVE   -> remove php tags</li> | ||||
|      *   <li>Smarty::PHP_ALLOW    -> execute php tags</li> | ||||
|      * </ul> | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $php_handling = Smarty::PHP_PASSTHRU; | ||||
|     /** | ||||
|      * This is the list of template directories that are considered secure. | ||||
|      * $template_dir is in this list implicitly. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $secure_dir = array(); | ||||
|     /** | ||||
|      * This is an array of directories where trusted php scripts reside. | ||||
|      * {@link $security} is disabled during their inclusion/execution. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $trusted_dir = array(); | ||||
|     /** | ||||
|      * List of regular expressions (PCRE) that include trusted URIs | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $trusted_uri = array(); | ||||
|     /** | ||||
|      * This is an array of trusted static classes. | ||||
|      * If empty access to all static classes is allowed. | ||||
|      * If set to 'none' none is allowed. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $static_classes = array(); | ||||
|     /** | ||||
|      * This is an array of trusted PHP functions. | ||||
|      * If empty all functions are allowed. | ||||
|      * To disable all PHP functions set $php_functions = null. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $php_functions = array( | ||||
|         'isset', 'empty', | ||||
|         'count', 'sizeof', | ||||
|         'in_array', 'is_array', | ||||
|         'time', | ||||
|         'nl2br', | ||||
|     ); | ||||
|     /** | ||||
|      * This is an array of trusted PHP modifiers. | ||||
|      * If empty all modifiers are allowed. | ||||
|      * To disable all modifier set $modifiers = null. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $php_modifiers = array( | ||||
|         'escape', | ||||
|         'count' | ||||
|     ); | ||||
|     /** | ||||
|      * This is an array of allowed tags. | ||||
|      * If empty no restriction by allowed_tags. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $allowed_tags = array(); | ||||
|     /** | ||||
|      * This is an array of disabled tags. | ||||
|      * If empty no restriction by disabled_tags. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $disabled_tags = array(); | ||||
|     /** | ||||
|      * This is an array of allowed modifier plugins. | ||||
|      * If empty no restriction by allowed_modifiers. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $allowed_modifiers = array(); | ||||
|     /** | ||||
|      * This is an array of disabled modifier plugins. | ||||
|      * If empty no restriction by disabled_modifiers. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $disabled_modifiers = array(); | ||||
|     /** | ||||
|      * This is an array of trusted streams. | ||||
|      * If empty all streams are allowed. | ||||
|      * To disable all streams set $streams = null. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $streams = array('file'); | ||||
|     /** | ||||
|      * + flag if constants can be accessed from template | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $allow_constants = true; | ||||
|     /** | ||||
|      * + flag if super globals can be accessed from template | ||||
|      * | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $allow_super_globals = true; | ||||
|  | ||||
|     /** | ||||
|      * Cache for $resource_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_resource_dir = null; | ||||
|     /** | ||||
|      * Cache for $template_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_template_dir = null; | ||||
|     /** | ||||
|      * Cache for $config_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_config_dir = null; | ||||
|     /** | ||||
|      * Cache for $secure_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_secure_dir = null; | ||||
|     /** | ||||
|      * Cache for $php_resource_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_php_resource_dir = null; | ||||
|     /** | ||||
|      * Cache for $trusted_dir lookup | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_trusted_dir = null; | ||||
|  | ||||
|     /** | ||||
|      * @param Smarty $smarty | ||||
|      */ | ||||
|     public function __construct($smarty) | ||||
|     { | ||||
|         $this->smarty = $smarty; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if PHP function is trusted. | ||||
|      * | ||||
|      * @param  string $function_name | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean                 true if function is trusted | ||||
|      * @throws SmartyCompilerException if php function is not trusted | ||||
|      */ | ||||
|     public function isTrustedPhpFunction($function_name, $compiler) | ||||
|     { | ||||
|         if (isset($this->php_functions) && (empty($this->php_functions) || in_array($function_name, $this->php_functions))) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         $compiler->trigger_template_error("PHP function '{$function_name}' not allowed by security setting"); | ||||
|  | ||||
|         return false; // should not, but who knows what happens to the compiler in the future? | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if static class is trusted. | ||||
|      * | ||||
|      * @param  string $class_name | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean                 true if class is trusted | ||||
|      * @throws SmartyCompilerException if static class is not trusted | ||||
|      */ | ||||
|     public function isTrustedStaticClass($class_name, $compiler) | ||||
|     { | ||||
|         if (isset($this->static_classes) && (empty($this->static_classes) || in_array($class_name, $this->static_classes))) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         $compiler->trigger_template_error("access to static class '{$class_name}' not allowed by security setting"); | ||||
|  | ||||
|         return false; // should not, but who knows what happens to the compiler in the future? | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if PHP modifier is trusted. | ||||
|      * | ||||
|      * @param  string $modifier_name | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean                 true if modifier is trusted | ||||
|      * @throws SmartyCompilerException if modifier is not trusted | ||||
|      */ | ||||
|     public function isTrustedPhpModifier($modifier_name, $compiler) | ||||
|     { | ||||
|         if (isset($this->php_modifiers) && (empty($this->php_modifiers) || in_array($modifier_name, $this->php_modifiers))) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         $compiler->trigger_template_error("modifier '{$modifier_name}' not allowed by security setting"); | ||||
|  | ||||
|         return false; // should not, but who knows what happens to the compiler in the future? | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if tag is trusted. | ||||
|      * | ||||
|      * @param  string $tag_name | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean                 true if tag is trusted | ||||
|      * @throws SmartyCompilerException if modifier is not trusted | ||||
|      */ | ||||
|     public function isTrustedTag($tag_name, $compiler) | ||||
|     { | ||||
|         // check for internal always required tags | ||||
|         if (in_array($tag_name, array('assign', 'call', 'private_filter', 'private_block_plugin', 'private_function_plugin', 'private_object_block_function', | ||||
|                                       'private_object_function', 'private_registered_function', 'private_registered_block', 'private_special_variable', 'private_print_expression', 'private_modifier')) | ||||
|         ) { | ||||
|             return true; | ||||
|         } | ||||
|         // check security settings | ||||
|         if (empty($this->allowed_tags)) { | ||||
|             if (empty($this->disabled_tags) || !in_array($tag_name, $this->disabled_tags)) { | ||||
|                 return true; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error("tag '{$tag_name}' disabled by security setting", $compiler->lex->taglineno); | ||||
|             } | ||||
|         } elseif (in_array($tag_name, $this->allowed_tags) && !in_array($tag_name, $this->disabled_tags)) { | ||||
|             return true; | ||||
|         } else { | ||||
|             $compiler->trigger_template_error("tag '{$tag_name}' not allowed by security setting", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         return false; // should not, but who knows what happens to the compiler in the future? | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if modifier plugin is trusted. | ||||
|      * | ||||
|      * @param  string $modifier_name | ||||
|      * @param  object $compiler compiler object | ||||
|      * | ||||
|      * @return boolean                 true if tag is trusted | ||||
|      * @throws SmartyCompilerException if modifier is not trusted | ||||
|      */ | ||||
|     public function isTrustedModifier($modifier_name, $compiler) | ||||
|     { | ||||
|         // check for internal always allowed modifier | ||||
|         if (in_array($modifier_name, array('default'))) { | ||||
|             return true; | ||||
|         } | ||||
|         // check security settings | ||||
|         if (empty($this->allowed_modifiers)) { | ||||
|             if (empty($this->disabled_modifiers) || !in_array($modifier_name, $this->disabled_modifiers)) { | ||||
|                 return true; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error("modifier '{$modifier_name}' disabled by security setting", $compiler->lex->taglineno); | ||||
|             } | ||||
|         } elseif (in_array($modifier_name, $this->allowed_modifiers) && !in_array($modifier_name, $this->disabled_modifiers)) { | ||||
|             return true; | ||||
|         } else { | ||||
|             $compiler->trigger_template_error("modifier '{$modifier_name}' not allowed by security setting", $compiler->lex->taglineno); | ||||
|         } | ||||
|  | ||||
|         return false; // should not, but who knows what happens to the compiler in the future? | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if stream is trusted. | ||||
|      * | ||||
|      * @param  string $stream_name | ||||
|      * | ||||
|      * @return boolean         true if stream is trusted | ||||
|      * @throws SmartyException if stream is not trusted | ||||
|      */ | ||||
|     public function isTrustedStream($stream_name) | ||||
|     { | ||||
|         if (isset($this->streams) && (empty($this->streams) || in_array($stream_name, $this->streams))) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("stream '{$stream_name}' not allowed by security setting"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if directory of file resource is trusted. | ||||
|      * | ||||
|      * @param  string $filepath | ||||
|      * | ||||
|      * @return boolean         true if directory is trusted | ||||
|      * @throws SmartyException if directory is not trusted | ||||
|      */ | ||||
|     public function isTrustedResourceDir($filepath) | ||||
|     { | ||||
|         $_template = false; | ||||
|         $_config = false; | ||||
|         $_secure = false; | ||||
|  | ||||
|         $_template_dir = $this->smarty->getTemplateDir(); | ||||
|         $_config_dir = $this->smarty->getConfigDir(); | ||||
|  | ||||
|         // check if index is outdated | ||||
|         if ((!$this->_template_dir || $this->_template_dir !== $_template_dir) | ||||
|             || (!$this->_config_dir || $this->_config_dir !== $_config_dir) | ||||
|             || (!empty($this->secure_dir) && (!$this->_secure_dir || $this->_secure_dir !== $this->secure_dir)) | ||||
|         ) { | ||||
|             $this->_resource_dir = array(); | ||||
|             $_template = true; | ||||
|             $_config = true; | ||||
|             $_secure = !empty($this->secure_dir); | ||||
|         } | ||||
|  | ||||
|         // rebuild template dir index | ||||
|         if ($_template) { | ||||
|             $this->_template_dir = $_template_dir; | ||||
|             foreach ($_template_dir as $directory) { | ||||
|                 $directory = realpath($directory); | ||||
|                 $this->_resource_dir[$directory] = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // rebuild config dir index | ||||
|         if ($_config) { | ||||
|             $this->_config_dir = $_config_dir; | ||||
|             foreach ($_config_dir as $directory) { | ||||
|                 $directory = realpath($directory); | ||||
|                 $this->_resource_dir[$directory] = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // rebuild secure dir index | ||||
|         if ($_secure) { | ||||
|             $this->_secure_dir = $this->secure_dir; | ||||
|             foreach ((array) $this->secure_dir as $directory) { | ||||
|                 $directory = realpath($directory); | ||||
|                 $this->_resource_dir[$directory] = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $_filepath = realpath($filepath); | ||||
|         $directory = dirname($_filepath); | ||||
|         $_directory = array(); | ||||
|         while (true) { | ||||
|             // remember the directory to add it to _resource_dir in case we're successful | ||||
|             $_directory[$directory] = true; | ||||
|             // test if the directory is trusted | ||||
|             if (isset($this->_resource_dir[$directory])) { | ||||
|                 // merge sub directories of current $directory into _resource_dir to speed up subsequent lookup | ||||
|                 $this->_resource_dir = array_merge($this->_resource_dir, $_directory); | ||||
|  | ||||
|                 return true; | ||||
|             } | ||||
|             // abort if we've reached root | ||||
|             if (($pos = strrpos($directory, DS)) === false || !isset($directory[1])) { | ||||
|                 break; | ||||
|             } | ||||
|             // bubble up one level | ||||
|             $directory = substr($directory, 0, $pos); | ||||
|         } | ||||
|  | ||||
|         // give up | ||||
|         throw new SmartyException("directory '{$_filepath}' not allowed by security setting"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if URI (e.g. {fetch} or {html_image}) is trusted | ||||
|      * To simplify things, isTrustedUri() resolves all input to "{$PROTOCOL}://{$HOSTNAME}". | ||||
|      * So "http://username:password@hello.world.example.org:8080/some-path?some=query-string" | ||||
|      * is reduced to "http://hello.world.example.org" prior to applying the patters from {@link $trusted_uri}. | ||||
|      * | ||||
|      * @param  string $uri | ||||
|      * | ||||
|      * @return boolean         true if URI is trusted | ||||
|      * @throws SmartyException if URI is not trusted | ||||
|      * @uses $trusted_uri for list of patterns to match against $uri | ||||
|      */ | ||||
|     public function isTrustedUri($uri) | ||||
|     { | ||||
|         $_uri = parse_url($uri); | ||||
|         if (!empty($_uri['scheme']) && !empty($_uri['host'])) { | ||||
|             $_uri = $_uri['scheme'] . '://' . $_uri['host']; | ||||
|             foreach ($this->trusted_uri as $pattern) { | ||||
|                 if (preg_match($pattern, $_uri)) { | ||||
|                     return true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("URI '{$uri}' not allowed by security setting"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if directory of file resource is trusted. | ||||
|      * | ||||
|      * @param  string $filepath | ||||
|      * | ||||
|      * @return boolean         true if directory is trusted | ||||
|      * @throws SmartyException if PHP directory is not trusted | ||||
|      */ | ||||
|     public function isTrustedPHPDir($filepath) | ||||
|     { | ||||
|         if (empty($this->trusted_dir)) { | ||||
|             throw new SmartyException("directory '{$filepath}' not allowed by security setting (no trusted_dir specified)"); | ||||
|         } | ||||
|  | ||||
|         // check if index is outdated | ||||
|         if (!$this->_trusted_dir || $this->_trusted_dir !== $this->trusted_dir) { | ||||
|             $this->_php_resource_dir = array(); | ||||
|  | ||||
|             $this->_trusted_dir = $this->trusted_dir; | ||||
|             foreach ((array) $this->trusted_dir as $directory) { | ||||
|                 $directory = realpath($directory); | ||||
|                 $this->_php_resource_dir[$directory] = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $_filepath = realpath($filepath); | ||||
|         $directory = dirname($_filepath); | ||||
|         $_directory = array(); | ||||
|         while (true) { | ||||
|             // remember the directory to add it to _resource_dir in case we're successful | ||||
|             $_directory[] = $directory; | ||||
|             // test if the directory is trusted | ||||
|             if (isset($this->_php_resource_dir[$directory])) { | ||||
|                 // merge sub directories of current $directory into _resource_dir to speed up subsequent lookup | ||||
|                 $this->_php_resource_dir = array_merge($this->_php_resource_dir, $_directory); | ||||
|  | ||||
|                 return true; | ||||
|             } | ||||
|             // abort if we've reached root | ||||
|             if (($pos = strrpos($directory, DS)) === false || !isset($directory[2])) { | ||||
|                 break; | ||||
|             } | ||||
|             // bubble up one level | ||||
|             $directory = substr($directory, 0, $pos); | ||||
|         } | ||||
|  | ||||
|         throw new SmartyException("directory '{$_filepath}' not allowed by security setting"); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user