Initial commit
This commit is contained in:
		
							
								
								
									
										219
									
								
								lib/smarty/libs/sysplugins/smarty_cacheresource.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										219
									
								
								lib/smarty/libs/sysplugins/smarty_cacheresource.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,219 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Cache Handler API | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Cacher | ||||
|  * @author     Rodney Rehm | ||||
|  */ | ||||
| abstract class Smarty_CacheResource | ||||
| { | ||||
|     /** | ||||
|      * resource types provided by the core | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected static $sysplugins = array('file' => 'smarty_internal_cacheresource_file.php',); | ||||
|  | ||||
|     /** | ||||
|      * 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 | ||||
|      * @param boolean                  $update    flag if called because cache update | ||||
|      * | ||||
|      * @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, | ||||
|         $update = false | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * 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); | ||||
|  | ||||
|     /** | ||||
|      * Read cached template from cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return string  content | ||||
|      */ | ||||
|     abstract public function readCachedContent(Smarty_Internal_Template $_template); | ||||
|  | ||||
|     /** | ||||
|      * 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(); | ||||
|             $unifunc = $_template->cached->unifunc; | ||||
|             $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->_cache[ 'cacheresource_handlers' ][ $type ])) { | ||||
|             return $smarty->_cache[ '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->_cache[ 'cacheresource_handlers' ][ $type ] = $smarty->registered_cache_resources[ $type ]; | ||||
|         } | ||||
|         // try sysplugins dir | ||||
|         if (isset(self::$sysplugins[ $type ])) { | ||||
|             $cache_resource_class = 'Smarty_Internal_CacheResource_' . ucfirst($type); | ||||
|             return $smarty->_cache[ 'cacheresource_handlers' ][ $type ] = new $cache_resource_class(); | ||||
|         } | ||||
|         // try plugins dir | ||||
|         $cache_resource_class = 'Smarty_CacheResource_' . ucfirst($type); | ||||
|         if ($smarty->loadPlugin($cache_resource_class)) { | ||||
|             return $smarty->_cache[ 'cacheresource_handlers' ][ $type ] = new $cache_resource_class(); | ||||
|         } | ||||
|         // give up | ||||
|         throw new SmartyException("Unable to load cache resource '{$type}'"); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										297
									
								
								lib/smarty/libs/sysplugins/smarty_cacheresource_custom.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										297
									
								
								lib/smarty/libs/sysplugins/smarty_cacheresource_custom.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,297 @@ | ||||
| <?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 false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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|null  $name       template name | ||||
|      * @param string|null  $cache_id   cache id | ||||
|      * @param string|null  $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; | ||||
|         $path = $cached->source->uid . $_cache_id . $_compile_id; | ||||
|         $cached->filepath = sha1($path); | ||||
|         if ($_template->smarty->cache_locking) { | ||||
|             $cached->lock_id = sha1('lock.' . $path); | ||||
|         } | ||||
|         $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 $_smarty_tpl do not change variable name, is used by compiled template | ||||
|      * @param Smarty_Template_Cached    $cached      cached object | ||||
|      * @param boolean                   $update      flag if called because cache update | ||||
|      * | ||||
|      * @return boolean                 true or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process( | ||||
|         Smarty_Internal_Template $_smarty_tpl, | ||||
|         Smarty_Template_Cached $cached = null, | ||||
|         $update = false | ||||
|     ) { | ||||
|         if (!$cached) { | ||||
|             $cached = $_smarty_tpl->cached; | ||||
|         } | ||||
|         $content = $cached->content ? $cached->content : null; | ||||
|         $timestamp = $cached->timestamp ? $cached->timestamp : null; | ||||
|         if ($content === null || !$timestamp) { | ||||
|             $this->fetch( | ||||
|                 $_smarty_tpl->cached->filepath, | ||||
|                 $_smarty_tpl->source->name, | ||||
|                 $_smarty_tpl->cache_id, | ||||
|                 $_smarty_tpl->compile_id, | ||||
|                 $content, | ||||
|                 $timestamp | ||||
|             ); | ||||
|         } | ||||
|         if (isset($content)) { | ||||
|             eval('?>' . $content); | ||||
|             $cached->content = null; | ||||
|             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->cache_lifetime, | ||||
|             $content | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read cached template from cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return string|boolean  content | ||||
|      */ | ||||
|     public function readCachedContent(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $content = $_template->cached->content ? $_template->cached->content : null; | ||||
|         $timestamp = null; | ||||
|         if ($content === null) { | ||||
|             $timestamp = null; | ||||
|             $this->fetch( | ||||
|                 $_template->cached->filepath, | ||||
|                 $_template->source->name, | ||||
|                 $_template->cache_id, | ||||
|                 $_template->compile_id, | ||||
|                 $content, | ||||
|                 $timestamp | ||||
|             ); | ||||
|         } | ||||
|         if (isset($content)) { | ||||
|             return $content; | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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) | ||||
|     { | ||||
|         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 int number of cache files deleted | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time) | ||||
|     { | ||||
|         $cache_name = null; | ||||
|         if (isset($resource_name)) { | ||||
|             $source = Smarty_Template_Source::load(null, $smarty, $resource_name); | ||||
|             if ($source->exists) { | ||||
|                 $cache_name = $source->name; | ||||
|             } else { | ||||
|                 return 0; | ||||
|             } | ||||
|         } | ||||
|         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->lock_id; | ||||
|         $name = $cached->source->name . '.lock'; | ||||
|         $mtime = $this->fetchTimestamp($id, $name, $cached->cache_id, $cached->compile_id); | ||||
|         if ($mtime === null) { | ||||
|             $this->fetch($id, $name, $cached->cache_id, $cached->compile_id, $content, $mtime); | ||||
|         } | ||||
|         return $mtime && ($t = 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->lock_id; | ||||
|         $name = $cached->source->name . '.lock'; | ||||
|         $this->save($id, $name, $cached->cache_id, $cached->compile_id, $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, $cached->cache_id, $cached->compile_id, null); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,538 @@ | ||||
| <?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 $_smarty_tpl do not change variable name, is used by compiled template | ||||
|      * @param Smarty_Template_Cached    $cached      cached object | ||||
|      * @param boolean                   $update      flag if called because cache update | ||||
|      * | ||||
|      * @return boolean                 true or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process( | ||||
|         Smarty_Internal_Template $_smarty_tpl, | ||||
|         Smarty_Template_Cached $cached = null, | ||||
|         $update = false | ||||
|     ) { | ||||
|         if (!$cached) { | ||||
|             $cached = $_smarty_tpl->cached; | ||||
|         } | ||||
|         $content = $cached->content ? $cached->content : null; | ||||
|         $timestamp = $cached->timestamp ? $cached->timestamp : null; | ||||
|         if ($content === null || !$timestamp) { | ||||
|             if (!$this->fetch( | ||||
|                 $_smarty_tpl->cached->filepath, | ||||
|                 $_smarty_tpl->source->name, | ||||
|                 $_smarty_tpl->cache_id, | ||||
|                 $_smarty_tpl->compile_id, | ||||
|                 $content, | ||||
|                 $timestamp, | ||||
|                 $_smarty_tpl->source->uid | ||||
|             ) | ||||
|             ) { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         if (isset($content)) { | ||||
|             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->cache_lifetime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read cached template from cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return string|false  content | ||||
|      */ | ||||
|     public function readCachedContent(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         $content = $_template->cached->content ? $_template->cached->content : null; | ||||
|         $timestamp = null; | ||||
|         if ($content === null) { | ||||
|             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)) { | ||||
|             return $content; | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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 int number of cache files deleted [always -1] | ||||
|      * @throws \SmartyException | ||||
|      * @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); | ||||
|         $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 | ||||
|      * | ||||
|      * @return string filepath of cache file | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     protected function getTemplateUid(Smarty $smarty, $resource_name) | ||||
|     { | ||||
|         if (isset($resource_name)) { | ||||
|             $source = Smarty_Template_Source::load(null, $smarty, $resource_name); | ||||
|             if ($source->exists) { | ||||
|                 return $source->uid; | ||||
|             } | ||||
|         } | ||||
|         return ''; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sanitize CacheID components | ||||
|      * | ||||
|      * @param string $string CacheID component to sanitize | ||||
|      * | ||||
|      * @return string sanitized CacheID component | ||||
|      */ | ||||
|     protected function sanitize($string) | ||||
|     { | ||||
|         $string = trim($string, '|'); | ||||
|         if (!$string) { | ||||
|             return ''; | ||||
|         } | ||||
|         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) | ||||
|     { | ||||
|         extract(unpack('N1s/N1m/a*content', $content)); | ||||
|         /** | ||||
|          * @var  int $s | ||||
|          * @var  int $m | ||||
|          */ | ||||
|         return $s + ($m / 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 .= '#'; | ||||
|         $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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										68
									
								
								lib/smarty/libs/sysplugins/smarty_data.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								lib/smarty/libs/sysplugins/smarty_data.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Plugin Data | ||||
|  * This file contains the data object | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Template | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * 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 | ||||
| { | ||||
|     /** | ||||
|      * Counter | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public static $count = 0; | ||||
|  | ||||
|     /** | ||||
|      * Data block name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $dataObjectName = ''; | ||||
|  | ||||
|     /** | ||||
|      * 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 | ||||
|      * @param string                          $name    optional data block name | ||||
|      * | ||||
|      * @throws SmartyException | ||||
|      */ | ||||
|     public function __construct($_parent = null, $smarty = null, $name = null) | ||||
|     { | ||||
|         parent::__construct(); | ||||
|         self::$count++; | ||||
|         $this->dataObjectName = 'Data_object ' . (isset($name) ? "'{$name}'" : self::$count); | ||||
|         $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'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										90
									
								
								lib/smarty/libs/sysplugins/smarty_internal_block.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								lib/smarty/libs/sysplugins/smarty_internal_block.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty {block} tag class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Block | ||||
| { | ||||
|     /** | ||||
|      * Block name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $name = ''; | ||||
|  | ||||
|     /** | ||||
|      * Hide attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $hide = false; | ||||
|  | ||||
|     /** | ||||
|      * Append attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $append = false; | ||||
|  | ||||
|     /** | ||||
|      * prepend attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $prepend = false; | ||||
|  | ||||
|     /** | ||||
|      * Block calls $smarty.block.child | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $callsChild = false; | ||||
|  | ||||
|     /** | ||||
|      * Inheritance child block | ||||
|      * | ||||
|      * @var Smarty_Internal_Block|null | ||||
|      */ | ||||
|     public $child = null; | ||||
|  | ||||
|     /** | ||||
|      * Inheritance calling parent block | ||||
|      * | ||||
|      * @var Smarty_Internal_Block|null | ||||
|      */ | ||||
|     public $parent = null; | ||||
|  | ||||
|     /** | ||||
|      * Inheritance Template index | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $tplIndex = 0; | ||||
|  | ||||
|     /** | ||||
|      * Smarty_Internal_Block constructor. | ||||
|      * - if outer level {block} of child template ($state === 1) save it as child root block | ||||
|      * - otherwise process inheritance and render | ||||
|      * | ||||
|      * @param string   $name     block name | ||||
|      * @param int|null $tplIndex index of outer level {block} if nested | ||||
|      */ | ||||
|     public function __construct($name, $tplIndex) | ||||
|     { | ||||
|         $this->name = $name; | ||||
|         $this->tplIndex = $tplIndex; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiled block code overloaded by {block} class | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $tpl | ||||
|      */ | ||||
|     public function callBlock(Smarty_Internal_Template $tpl) | ||||
|     { | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,239 @@ | ||||
| <?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 = &$_template->source; | ||||
|         $smarty = &$_template->smarty; | ||||
|         $_compile_dir_sep = $smarty->use_sub_dirs ? DIRECTORY_SEPARATOR : '^'; | ||||
|         $_filepath = sha1($source->uid . $smarty->_joined_template_dir); | ||||
|         $cached->filepath = $smarty->getCacheDir(); | ||||
|         if (isset($_template->cache_id)) { | ||||
|             $cached->filepath .= preg_replace( | ||||
|                                      array( | ||||
|                                          '![^\w|]+!', | ||||
|                                          '![|]+!' | ||||
|                                      ), | ||||
|                                      array( | ||||
|                                          '_', | ||||
|                                          $_compile_dir_sep | ||||
|                                      ), | ||||
|                                      $_template->cache_id | ||||
|                                  ) . $_compile_dir_sep; | ||||
|         } | ||||
|         if (isset($_template->compile_id)) { | ||||
|             $cached->filepath .= preg_replace('![^\w]+!', '_', $_template->compile_id) . $_compile_dir_sep; | ||||
|         } | ||||
|         // if use_sub_dirs, break file into directories | ||||
|         if ($smarty->use_sub_dirs) { | ||||
|             $cached->filepath .= $_filepath[ 0 ] . $_filepath[ 1 ] . DIRECTORY_SEPARATOR . $_filepath[ 2 ] . | ||||
|                                  $_filepath[ 3 ] . | ||||
|                                  DIRECTORY_SEPARATOR . | ||||
|                                  $_filepath[ 4 ] . $_filepath[ 5 ] . DIRECTORY_SEPARATOR; | ||||
|         } | ||||
|         $cached->filepath .= $_filepath; | ||||
|         $basename = $source->handler->getBasename($source); | ||||
|         if (!empty($basename)) { | ||||
|             $cached->filepath .= '.' . $basename; | ||||
|         } | ||||
|         if ($smarty->cache_locking) { | ||||
|             $cached->lock_id = $cached->filepath . '.lock'; | ||||
|         } | ||||
|         $cached->filepath .= '.php'; | ||||
|         $cached->timestamp = $cached->exists = is_file($cached->filepath); | ||||
|         if ($cached->exists) { | ||||
|             $cached->timestamp = filemtime($cached->filepath); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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 = $cached->exists = is_file($cached->filepath); | ||||
|         if ($cached->exists) { | ||||
|             $cached->timestamp = filemtime($cached->filepath); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read the cached template and process its header | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $_smarty_tpl do not change variable name, is used by compiled template | ||||
|      * @param Smarty_Template_Cached    $cached      cached object | ||||
|      * @param bool                      $update      flag if called because cache update | ||||
|      * | ||||
|      * @return boolean true or false if the cached content does not exist | ||||
|      */ | ||||
|     public function process( | ||||
|         Smarty_Internal_Template $_smarty_tpl, | ||||
|         Smarty_Template_Cached $cached = null, | ||||
|         $update = false | ||||
|     ) { | ||||
|         $_smarty_tpl->cached->valid = false; | ||||
|         if ($update && defined('HHVM_VERSION')) { | ||||
|             eval('?>' . file_get_contents($_smarty_tpl->cached->filepath)); | ||||
|             return true; | ||||
|         } else { | ||||
|             return @include $_smarty_tpl->cached->filepath; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Write the rendered template output to cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * @param string                   $content   content to cache | ||||
|      * | ||||
|      * @return bool success | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function writeCachedContent(Smarty_Internal_Template $_template, $content) | ||||
|     { | ||||
|         if ($_template->smarty->ext->_writeFile->writeFile( | ||||
|                 $_template->cached->filepath, | ||||
|                 $content, | ||||
|                 $_template->smarty | ||||
|             ) === true | ||||
|         ) { | ||||
|             if (function_exists('opcache_invalidate') | ||||
|                 && (!function_exists('ini_get') || strlen(ini_get('opcache.restrict_api'))) < 1 | ||||
|             ) { | ||||
|                 opcache_invalidate($_template->cached->filepath, true); | ||||
|             } elseif (function_exists('apc_compile_file')) { | ||||
|                 apc_compile_file($_template->cached->filepath); | ||||
|             } | ||||
|             $cached = $_template->cached; | ||||
|             $cached->timestamp = $cached->exists = is_file($cached->filepath); | ||||
|             if ($cached->exists) { | ||||
|                 $cached->timestamp = filemtime($cached->filepath); | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Read cached template from cache | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $_template template object | ||||
|      * | ||||
|      * @return string  content | ||||
|      */ | ||||
|     public function readCachedContent(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         if (is_file($_template->cached->filepath)) { | ||||
|             return file_get_contents($_template->cached->filepath); | ||||
|         } | ||||
|         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 $smarty->ext->_cacheResourceFile->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) | ||||
|     { | ||||
|         return $smarty->ext->_cacheResourceFile->clear($smarty, $resource_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) | ||||
|     { | ||||
|         if (version_compare(PHP_VERSION, '5.3.0', '>=')) { | ||||
|             clearstatcache(true, $cached->lock_id); | ||||
|         } else { | ||||
|             clearstatcache(); | ||||
|         } | ||||
|         if (is_file($cached->lock_id)) { | ||||
|             $t = filemtime($cached->lock_id); | ||||
|             return $t && (time() - $t < $smarty->locking_timeout); | ||||
|         } else { | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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,52 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $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'); | ||||
|         $this->mapCache = array(); | ||||
|         // 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,96 @@ | ||||
| <?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 | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array('nocache', 'noscope'); | ||||
|  | ||||
|     /** | ||||
|      * Valid scope names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $valid_scopes = array( | ||||
|         'local'    => Smarty::SCOPE_LOCAL, 'parent' => Smarty::SCOPE_PARENT, | ||||
|         'root'     => Smarty::SCOPE_ROOT, 'global' => Smarty::SCOPE_GLOBAL, | ||||
|         'tpl_root' => Smarty::SCOPE_TPL_ROOT, 'smarty' => Smarty::SCOPE_SMARTY | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {assign} tag | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $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'); | ||||
|         $this->mapCache = array(); | ||||
|         $_nocache = false; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // nocache ? | ||||
|         if ($_var = $compiler->getId($_attr[ 'var' ])) { | ||||
|             $_var = "'{$_var}'"; | ||||
|         } else { | ||||
|             $_var = $_attr[ 'var' ]; | ||||
|         } | ||||
|         if ($compiler->tag_nocache || $compiler->nocache) { | ||||
|             $_nocache = true; | ||||
|             // create nocache var to make it know for further compiling | ||||
|             $compiler->setNocacheInVariable($_attr[ 'var' ]); | ||||
|         } | ||||
|         // scope setup | ||||
|         if ($_attr[ 'noscope' ]) { | ||||
|             $_scope = -1; | ||||
|         } else { | ||||
|             $_scope = $compiler->convertScope($_attr, $this->valid_scopes); | ||||
|         } | ||||
|         // optional parameter | ||||
|         $_params = ''; | ||||
|         if ($_nocache || $_scope) { | ||||
|             $_params .= ' ,' . var_export($_nocache, true); | ||||
|         } | ||||
|         if ($_scope) { | ||||
|             $_params .= ' ,' . $_scope; | ||||
|         } | ||||
|         if (isset($parameter[ 'smarty_internal_index' ])) { | ||||
|             $output = | ||||
|                 "<?php \$_tmp_array = isset(\$_smarty_tpl->tpl_vars[{$_var}]) ? \$_smarty_tpl->tpl_vars[{$_var}]->value : array();\n"; | ||||
|             $output .= "if (!(is_array(\$_tmp_array) || \$_tmp_array instanceof ArrayAccess)) {\n"; | ||||
|             $output .= "settype(\$_tmp_array, 'array');\n"; | ||||
|             $output .= "}\n"; | ||||
|             $output .= "\$_tmp_array{$parameter['smarty_internal_index']} = {$_attr['value']};\n"; | ||||
|             $output .= "\$_smarty_tpl->_assignInScope({$_var}, \$_tmp_array{$_params});?>"; | ||||
|         } else { | ||||
|             $output = "<?php \$_smarty_tpl->_assignInScope({$_var}, {$_attr['value']}{$_params});?>"; | ||||
|         } | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										189
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_block.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										189
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_block.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,189 @@ | ||||
| <?php | ||||
| /** | ||||
|  * This file is part of Smarty. | ||||
|  * | ||||
|  * (c) 2015 Uwe Tews | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Class | ||||
|  * | ||||
|  * @author Uwe Tews <uwe.tews@googlemail.com> | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Block extends Smarty_Internal_Compile_Shared_Inheritance | ||||
| { | ||||
|     /** | ||||
|      * 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', 'nocache'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('assign'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {block} tag | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         if (!isset($compiler->_cache[ 'blockNesting' ])) { | ||||
|             $compiler->_cache[ 'blockNesting' ] = 0; | ||||
|         } | ||||
|         if ($compiler->_cache[ 'blockNesting' ] === 0) { | ||||
|             // make sure that inheritance gets initialized in template code | ||||
|             $this->registerInit($compiler); | ||||
|             $this->option_flags = array('hide', 'nocache', 'append', 'prepend'); | ||||
|         } else { | ||||
|             $this->option_flags = array('hide', 'nocache'); | ||||
|         } | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         ++$compiler->_cache[ 'blockNesting' ]; | ||||
|         $_className = 'Block_' . preg_replace('![^\w]+!', '_', uniqid(mt_rand(), true)); | ||||
|         $compiler->_cache[ 'blockName' ][ $compiler->_cache[ 'blockNesting' ] ] = $_attr[ 'name' ]; | ||||
|         $compiler->_cache[ 'blockClass' ][ $compiler->_cache[ 'blockNesting' ] ] = $_className; | ||||
|         $compiler->_cache[ 'blockParams' ][ $compiler->_cache[ 'blockNesting' ] ] = array(); | ||||
|         $compiler->_cache[ 'blockParams' ][ 1 ][ 'subBlocks' ][ trim($_attr[ 'name' ], '"\'') ][] = $_className; | ||||
|         $this->openTag( | ||||
|             $compiler, | ||||
|             'block', | ||||
|             array( | ||||
|                 $_attr, $compiler->nocache, $compiler->parser->current_buffer, | ||||
|                 $compiler->template->compiled->has_nocache_code, | ||||
|                 $compiler->template->caching | ||||
|             ) | ||||
|         ); | ||||
|         $compiler->saveRequiredPlugins(true); | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         $compiler->parser->current_buffer = new Smarty_Internal_ParseTree_Template(); | ||||
|         $compiler->template->compiled->has_nocache_code = false; | ||||
|         $compiler->suppressNocacheProcessing = true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile BlockClose Class | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Blockclose extends Smarty_Internal_Compile_Shared_Inheritance | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {/block} tag | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return bool true | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         list($_attr, $_nocache, $_buffer, $_has_nocache_code, $_caching) = $this->closeTag($compiler, array('block')); | ||||
|         // init block parameter | ||||
|         $_block = $compiler->_cache[ 'blockParams' ][ $compiler->_cache[ 'blockNesting' ] ]; | ||||
|         unset($compiler->_cache[ 'blockParams' ][ $compiler->_cache[ 'blockNesting' ] ]); | ||||
|         $_name = $_attr[ 'name' ]; | ||||
|         $_assign = isset($_attr[ 'assign' ]) ? $_attr[ 'assign' ] : null; | ||||
|         unset($_attr[ 'assign' ], $_attr[ 'name' ]); | ||||
|         foreach ($_attr as $name => $stat) { | ||||
|             if ((is_bool($stat) && $stat !== false) || (!is_bool($stat) && $stat !== 'false')) { | ||||
|                 $_block[ $name ] = 'true'; | ||||
|             } | ||||
|         } | ||||
|         $_className = $compiler->_cache[ 'blockClass' ][ $compiler->_cache[ 'blockNesting' ] ]; | ||||
|         // get compiled block code | ||||
|         $_functionCode = $compiler->parser->current_buffer; | ||||
|         // setup buffer for template function code | ||||
|         $compiler->parser->current_buffer = new Smarty_Internal_ParseTree_Template(); | ||||
|         $output = "<?php\n"; | ||||
|         $output .= "/* {block {$_name}} */\n"; | ||||
|         $output .= "class {$_className} extends Smarty_Internal_Block\n"; | ||||
|         $output .= "{\n"; | ||||
|         foreach ($_block as $property => $value) { | ||||
|             $output .= "public \${$property} = " . var_export($value, true) . ";\n"; | ||||
|         } | ||||
|         $output .= "public function callBlock(Smarty_Internal_Template \$_smarty_tpl) {\n"; | ||||
|         $output .= $compiler->compileRequiredPlugins(); | ||||
|         $compiler->restoreRequiredPlugins(); | ||||
|         if ($compiler->template->compiled->has_nocache_code) { | ||||
|             $output .= "\$_smarty_tpl->cached->hashes['{$compiler->template->compiled->nocache_hash}'] = true;\n"; | ||||
|         } | ||||
|         if (isset($_assign)) { | ||||
|             $output .= "ob_start();\n"; | ||||
|         } | ||||
|         $output .= "?>\n"; | ||||
|         $compiler->parser->current_buffer->append_subtree( | ||||
|             $compiler->parser, | ||||
|             new Smarty_Internal_ParseTree_Tag( | ||||
|                 $compiler->parser, | ||||
|                 $output | ||||
|             ) | ||||
|         ); | ||||
|         $compiler->parser->current_buffer->append_subtree($compiler->parser, $_functionCode); | ||||
|         $output = "<?php\n"; | ||||
|         if (isset($_assign)) { | ||||
|             $output .= "\$_smarty_tpl->assign({$_assign}, ob_get_clean());\n"; | ||||
|         } | ||||
|         $output .= "}\n"; | ||||
|         $output .= "}\n"; | ||||
|         $output .= "/* {/block {$_name}} */\n\n"; | ||||
|         $output .= "?>\n"; | ||||
|         $compiler->parser->current_buffer->append_subtree( | ||||
|             $compiler->parser, | ||||
|             new Smarty_Internal_ParseTree_Tag( | ||||
|                 $compiler->parser, | ||||
|                 $output | ||||
|             ) | ||||
|         ); | ||||
|         $compiler->blockOrFunctionCode .= $compiler->parser->current_buffer->to_smarty_php($compiler->parser); | ||||
|         $compiler->parser->current_buffer = new Smarty_Internal_ParseTree_Template(); | ||||
|         // restore old status | ||||
|         $compiler->template->compiled->has_nocache_code = $_has_nocache_code; | ||||
|         $compiler->tag_nocache = $compiler->nocache; | ||||
|         $compiler->nocache = $_nocache; | ||||
|         $compiler->parser->current_buffer = $_buffer; | ||||
|         $output = "<?php \n"; | ||||
|         if ($compiler->_cache[ 'blockNesting' ] === 1) { | ||||
|             $output .= "\$_smarty_tpl->inheritance->instanceBlock(\$_smarty_tpl, '$_className', $_name);\n"; | ||||
|         } else { | ||||
|             $output .= "\$_smarty_tpl->inheritance->instanceBlock(\$_smarty_tpl, '$_className', $_name, \$this->tplIndex);\n"; | ||||
|         } | ||||
|         $output .= "?>\n"; | ||||
|         --$compiler->_cache[ 'blockNesting' ]; | ||||
|         if ($compiler->_cache[ 'blockNesting' ] === 0) { | ||||
|             unset($compiler->_cache[ 'blockNesting' ]); | ||||
|         } | ||||
|         $compiler->has_code = true; | ||||
|         $compiler->suppressNocacheProcessing = true; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,24 @@ | ||||
| <?php | ||||
| /** | ||||
|  * This file is part of Smarty. | ||||
|  * | ||||
|  * (c) 2015 Uwe Tews | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Child Class | ||||
|  * | ||||
|  * @author Uwe Tews <uwe.tews@googlemail.com> | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Block_Child extends Smarty_Internal_Compile_Child | ||||
| { | ||||
|     /** | ||||
|      * Tag name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'block_child'; | ||||
| } | ||||
| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /** | ||||
|  * This file is part of Smarty. | ||||
|  * | ||||
|  * (c) 2015 Uwe Tews | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Block Parent Class | ||||
|  * | ||||
|  * @author Uwe Tews <uwe.tews@googlemail.com> | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Block_Parent extends Smarty_Internal_Compile_Child | ||||
| { | ||||
|     /** | ||||
|      * Tag name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'block_parent'; | ||||
|  | ||||
|     /** | ||||
|      * Block type | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $blockType = 'Parent'; | ||||
| } | ||||
							
								
								
									
										117
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_break.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_break.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,117 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Break | ||||
|  * Compiles the {break} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Break Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Break 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'); | ||||
|  | ||||
|     /** | ||||
|      * Tag name may be overloaded by Smarty_Internal_Compile_Continue | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'break'; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {break} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         list($levels, $foreachLevels) = $this->checkLevels($args, $compiler); | ||||
|         $output = "<?php "; | ||||
|         if ($foreachLevels > 0 && $this->tag === 'continue') { | ||||
|             $foreachLevels--; | ||||
|         } | ||||
|         if ($foreachLevels > 0) { | ||||
|             /* @var Smarty_Internal_Compile_Foreach $foreachCompiler */ | ||||
|             $foreachCompiler = $compiler->getTagCompiler('foreach'); | ||||
|             $output .= $foreachCompiler->compileRestore($foreachLevels); | ||||
|         } | ||||
|         $output .= "{$this->tag} {$levels};?>"; | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * check attributes and return array of break and foreach levels | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return array | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function checkLevels($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         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', null, true); | ||||
|         } | ||||
|         if (isset($_attr[ 'levels' ])) { | ||||
|             if (!is_numeric($_attr[ 'levels' ])) { | ||||
|                 $compiler->trigger_template_error('level attribute must be a numeric constant', null, true); | ||||
|             } | ||||
|             $levels = $_attr[ 'levels' ]; | ||||
|         } else { | ||||
|             $levels = 1; | ||||
|         } | ||||
|         $level_count = $levels; | ||||
|         $stack_count = count($compiler->_tag_stack) - 1; | ||||
|         $foreachLevels = 0; | ||||
|         $lastTag = ''; | ||||
|         while ($level_count > 0 && $stack_count >= 0) { | ||||
|             if (isset($_is_loopy[ $compiler->_tag_stack[ $stack_count ][ 0 ] ])) { | ||||
|                 $lastTag = $compiler->_tag_stack[ $stack_count ][ 0 ]; | ||||
|                 if ($level_count === 0) { | ||||
|                     break; | ||||
|                 } | ||||
|                 $level_count--; | ||||
|                 if ($compiler->_tag_stack[ $stack_count ][ 0 ] === 'foreach') { | ||||
|                     $foreachLevels++; | ||||
|                 } | ||||
|             } | ||||
|             $stack_count--; | ||||
|         } | ||||
|         if ($level_count !== 0) { | ||||
|             $compiler->trigger_template_error("cannot {$this->tag} {$levels} level(s)", null, true); | ||||
|         } | ||||
|         if ($lastTag === 'foreach' && $this->tag === 'break' && $foreachLevels > 0) { | ||||
|             $foreachLevels--; | ||||
|         } | ||||
|         return array($levels, $foreachLevels); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										89
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_call.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_call.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| <?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 = trim($_attr['name'], "''"); | ||||
|         $_name = $_attr[ 'name' ]; | ||||
|         unset($_attr[ 'name' ], $_attr[ 'assign' ], $_attr[ 'nocache' ]); | ||||
|         // set flag (compiled code of {function} must be included in cache file | ||||
|         if (!$compiler->template->caching || $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"; | ||||
|             } | ||||
|         } | ||||
|         $_params = 'array(' . implode(',', $_paramsArray) . ')'; | ||||
|         //$compiler->suppressNocacheProcessing = true; | ||||
|         // was there an assign attribute | ||||
|         if (isset($_assign)) { | ||||
|             $_output = | ||||
|                 "<?php ob_start();\n\$_smarty_tpl->smarty->ext->_tplFunction->callTemplateFunction(\$_smarty_tpl, {$_name}, {$_params}, {$_nocache});\n\$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n"; | ||||
|         } else { | ||||
|             $_output = | ||||
|                 "<?php \$_smarty_tpl->smarty->ext->_tplFunction->callTemplateFunction(\$_smarty_tpl, {$_name}, {$_params}, {$_nocache});?>\n"; | ||||
|         } | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										105
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_capture.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_capture.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,105 @@ | ||||
| <?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 {$smarty.capture.xxx} | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public static function compileSpecialVariable( | ||||
|         $args, | ||||
|         Smarty_Internal_TemplateCompilerBase $compiler, | ||||
|         $parameter = null | ||||
|     ) { | ||||
|         return '$_smarty_tpl->smarty->ext->_capture->getBuffer($_smarty_tpl' . | ||||
|                (isset($parameter[ 1 ]) ? ", {$parameter[ 1 ]})" : ')'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {capture} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * @param null                                  $parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter = null) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args, $parameter, 'capture'); | ||||
|         $buffer = isset($_attr[ 'name' ]) ? $_attr[ 'name' ] : "'default'"; | ||||
|         $assign = isset($_attr[ 'assign' ]) ? $_attr[ 'assign' ] : 'null'; | ||||
|         $append = isset($_attr[ 'append' ]) ? $_attr[ 'append' ] : 'null'; | ||||
|         $compiler->_cache[ 'capture_stack' ][] = array($compiler->nocache); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         $_output = "<?php \$_smarty_tpl->smarty->ext->_capture->open(\$_smarty_tpl, $buffer, $assign, $append);?>"; | ||||
|         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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * @param null                                  $parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args, $parameter, '/capture'); | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         list($compiler->nocache) = array_pop($compiler->_cache[ 'capture_stack' ]); | ||||
|         return "<?php \$_smarty_tpl->smarty->ext->_capture->close(\$_smarty_tpl);?>"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										79
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_child.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_child.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| <?php | ||||
| /** | ||||
|  * This file is part of Smarty. | ||||
|  * | ||||
|  * (c) 2015 Uwe Tews | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Child Class | ||||
|  * | ||||
|  * @author Uwe Tews <uwe.tews@googlemail.com> | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Child extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $optional_attributes = array('assign'); | ||||
|  | ||||
|     /** | ||||
|      * Tag name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'child'; | ||||
|  | ||||
|     /** | ||||
|      * Block type | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $blockType = 'Child'; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {child} tag | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $tag = isset($parameter[ 0 ]) ? "'{$parameter[0]}'" : "'{{$this->tag}}'"; | ||||
|         if (!isset($compiler->_cache[ 'blockNesting' ])) { | ||||
|             $compiler->trigger_template_error( | ||||
|                 "{$tag} used outside {block} tags ", | ||||
|                 $compiler->parser->lex->taglineno | ||||
|             ); | ||||
|         } | ||||
|         $compiler->has_code = true; | ||||
|         $compiler->suppressNocacheProcessing = true; | ||||
|         if ($this->blockType === 'Child') { | ||||
|             $compiler->_cache[ 'blockParams' ][ $compiler->_cache[ 'blockNesting' ] ][ 'callsChild' ] = 'true'; | ||||
|         } | ||||
|         $_assign = isset($_attr[ 'assign' ]) ? $_attr[ 'assign' ] : null; | ||||
|         $output = "<?php \n"; | ||||
|         if (isset($_assign)) { | ||||
|             $output .= "ob_start();\n"; | ||||
|         } | ||||
|         $output .= '$_smarty_tpl->inheritance->call' . $this->blockType . '($_smarty_tpl, $this' . | ||||
|                    ($this->blockType === 'Child' ? '' : ", {$tag}") . ");\n"; | ||||
|         if (isset($_assign)) { | ||||
|             $output .= "\$_smarty_tpl->assign({$_assign}, ob_get_clean());\n"; | ||||
|         } | ||||
|         $output .= "?>\n"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,96 @@ | ||||
| <?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'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array('nocache', 'noscope'); | ||||
|  | ||||
|     /** | ||||
|      * Valid scope names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $valid_scopes = array( | ||||
|         'local'  => Smarty::SCOPE_LOCAL, 'parent' => Smarty::SCOPE_PARENT, | ||||
|         'root'   => Smarty::SCOPE_ROOT, 'tpl_root' => Smarty::SCOPE_TPL_ROOT, | ||||
|         'smarty' => Smarty::SCOPE_SMARTY, 'global' => Smarty::SCOPE_SMARTY | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {config_load} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr[ 'nocache' ] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', null, true); | ||||
|         } | ||||
|         // save possible attributes | ||||
|         $conf_file = $_attr[ 'file' ]; | ||||
|         if (isset($_attr[ 'section' ])) { | ||||
|             $section = $_attr[ 'section' ]; | ||||
|         } else { | ||||
|             $section = 'null'; | ||||
|         } | ||||
|         // scope setup | ||||
|         if ($_attr[ 'noscope' ]) { | ||||
|             $_scope = -1; | ||||
|         } else { | ||||
|             $_scope = $compiler->convertScope($_attr, $this->valid_scopes); | ||||
|         } | ||||
|         // create config object | ||||
|         $_output = | ||||
|             "<?php\n\$_smarty_tpl->smarty->ext->configLoad->_loadConfigFile(\$_smarty_tpl, {$conf_file}, {$section}, {$_scope});\n?>\n"; | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,25 @@ | ||||
| <?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_Compile_Break | ||||
| { | ||||
|     /** | ||||
|      * Tag name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'continue'; | ||||
| } | ||||
							
								
								
									
										40
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_debug.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_debug.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| <?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_debug = new Smarty_Internal_Debug;\n \$_smarty_debug->display_debug(\$_smarty_tpl);\n"; | ||||
|         $_output .= "unset(\$_smarty_debug);\n?>"; | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										70
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_eval.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_eval.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| <?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) | ||||
|     { | ||||
|         // 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 ?>"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										158
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_extends.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_extends.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <?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_Compile_Shared_Inheritance | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('file'); | ||||
|  | ||||
|     /** | ||||
|      * 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('extends_resource'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('file'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {extends} tag extends: resource | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr[ 'nocache' ] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', $compiler->parser->lex->line - 1); | ||||
|         } | ||||
|         if (strpos($_attr[ 'file' ], '$_tmp') !== false) { | ||||
|             $compiler->trigger_template_error('illegal value for file attribute', $compiler->parser->lex->line - 1); | ||||
|         } | ||||
|         // add code to initialize inheritance | ||||
|         $this->registerInit($compiler, true); | ||||
|         $file = trim($_attr[ 'file' ], '\'"'); | ||||
|         if (strlen($file) > 8 && substr($file, 0, 8) === 'extends:') { | ||||
|             // generate code for each template | ||||
|             $files = array_reverse(explode('|', substr($file, 8))); | ||||
|             $i = 0; | ||||
|             foreach ($files as $file) { | ||||
|                 if ($file[ 0 ] === '"') { | ||||
|                     $file = trim($file, '".'); | ||||
|                 } else { | ||||
|                     $file = "'{$file}'"; | ||||
|                 } | ||||
|                 $i++; | ||||
|                 if ($i === count($files) && isset($_attr[ 'extends_resource' ])) { | ||||
|                     $this->compileEndChild($compiler); | ||||
|                 } | ||||
|                 $this->compileInclude($compiler, $file); | ||||
|             } | ||||
|             if (!isset($_attr[ 'extends_resource' ])) { | ||||
|                 $this->compileEndChild($compiler); | ||||
|             } | ||||
|         } else { | ||||
|             $this->compileEndChild($compiler, $_attr[ 'file' ]); | ||||
|         } | ||||
|         $compiler->has_code = false; | ||||
|         return ''; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add code for inheritance endChild() method to end of template | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param null|string                           $template optional inheritance parent template | ||||
|      * | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     private function compileEndChild(Smarty_Internal_TemplateCompilerBase $compiler, $template = null) | ||||
|     { | ||||
|         $inlineUids = ''; | ||||
|         if (isset($template) && $compiler->smarty->merge_compiled_includes) { | ||||
|             $code = $compiler->compileTag('include', array($template, array('scope' => 'parent'))); | ||||
|             if (preg_match('/([,][\s]*[\'][a-z0-9]+[\'][,][\s]*[\']content.*[\'])[)]/', $code, $match)) { | ||||
|                 $inlineUids = $match[ 1 ]; | ||||
|             } | ||||
|         } | ||||
|         $compiler->parser->template_postfix[] = new Smarty_Internal_ParseTree_Tag( | ||||
|             $compiler->parser, | ||||
|             '<?php $_smarty_tpl->inheritance->endChild($_smarty_tpl' . | ||||
|             (isset($template) ? | ||||
|                 ", {$template}{$inlineUids}" : | ||||
|                 '') . ");\n?>" | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add code for including subtemplate to end of template | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param string                                $template subtemplate name | ||||
|      * | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     private function compileInclude(Smarty_Internal_TemplateCompilerBase $compiler, $template) | ||||
|     { | ||||
|         $compiler->parser->template_postfix[] = new Smarty_Internal_ParseTree_Tag( | ||||
|             $compiler->parser, | ||||
|             $compiler->compileTag( | ||||
|                 'include', | ||||
|                 array( | ||||
|                     $template, | ||||
|                     array('scope' => 'parent') | ||||
|                 ) | ||||
|             ) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create source code for {extends} from source components array | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public static function extendsSourceArrayCode(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $resources = array(); | ||||
|         foreach ($template->source->components as $source) { | ||||
|             $resources[] = $source->resource; | ||||
|         } | ||||
|         return $template->smarty->left_delimiter . 'extends file=\'extends:' . join('|', $resources) . | ||||
|                '\' extends_resource=true' . $template->smarty->right_delimiter; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										164
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,164 @@ | ||||
| <?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) | ||||
|     { | ||||
|         $compiler->loopNesting++; | ||||
|         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(); | ||||
|         } | ||||
|         $this->mapCache = array(); | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $output = "<?php\n"; | ||||
|         if ($parameter === 1) { | ||||
|             foreach ($_attr[ 'start' ] as $_statement) { | ||||
|                 if (is_array($_statement[ 'var' ])) { | ||||
|                     $var = $_statement[ 'var' ][ 'var' ]; | ||||
|                     $index = $_statement[ 'var' ][ 'smarty_internal_index' ]; | ||||
|                 } else { | ||||
|                     $var = $_statement[ 'var' ]; | ||||
|                     $index = ''; | ||||
|                 } | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var] = new Smarty_Variable(null, \$_smarty_tpl->isRenderingCache);\n"; | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var]->value{$index} = {$_statement['value']};\n"; | ||||
|             } | ||||
|             if (is_array($_attr[ 'var' ])) { | ||||
|                 $var = $_attr[ 'var' ][ 'var' ]; | ||||
|                 $index = $_attr[ 'var' ][ 'smarty_internal_index' ]; | ||||
|             } else { | ||||
|                 $var = $_attr[ 'var' ]; | ||||
|                 $index = ''; | ||||
|             } | ||||
|             $output .= "if ($_attr[ifexp]) {\nfor (\$_foo=true;$_attr[ifexp]; \$_smarty_tpl->tpl_vars[$var]->value{$index}$_attr[step]) {\n"; | ||||
|         } else { | ||||
|             $_statement = $_attr[ 'start' ]; | ||||
|             if (is_array($_statement[ 'var' ])) { | ||||
|                 $var = $_statement[ 'var' ][ 'var' ]; | ||||
|                 $index = $_statement[ 'var' ][ 'smarty_internal_index' ]; | ||||
|             } else { | ||||
|                 $var = $_statement[ 'var' ]; | ||||
|                 $index = ''; | ||||
|             } | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$var] = new Smarty_Variable(null, \$_smarty_tpl->isRenderingCache);"; | ||||
|             if (isset($_attr[ 'step' ])) { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var]->step = $_attr[step];"; | ||||
|             } else { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var]->step = 1;"; | ||||
|             } | ||||
|             if (isset($_attr[ 'max' ])) { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var]->total = (int) min(ceil((\$_smarty_tpl->tpl_vars[$var]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$var]->step)),$_attr[max]);\n"; | ||||
|             } else { | ||||
|                 $output .= "\$_smarty_tpl->tpl_vars[$var]->total = (int) ceil((\$_smarty_tpl->tpl_vars[$var]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$var]->step));\n"; | ||||
|             } | ||||
|             $output .= "if (\$_smarty_tpl->tpl_vars[$var]->total > 0) {\n"; | ||||
|             $output .= "for (\$_smarty_tpl->tpl_vars[$var]->value{$index} = $_statement[value], \$_smarty_tpl->tpl_vars[$var]->iteration = 1;\$_smarty_tpl->tpl_vars[$var]->iteration <= \$_smarty_tpl->tpl_vars[$var]->total;\$_smarty_tpl->tpl_vars[$var]->value{$index} += \$_smarty_tpl->tpl_vars[$var]->step, \$_smarty_tpl->tpl_vars[$var]->iteration++) {\n"; | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$var]->first = \$_smarty_tpl->tpl_vars[$var]->iteration === 1;"; | ||||
|             $output .= "\$_smarty_tpl->tpl_vars[$var]->last = \$_smarty_tpl->tpl_vars[$var]->iteration === \$_smarty_tpl->tpl_vars[$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) | ||||
|     { | ||||
|         $compiler->loopNesting--; | ||||
|         // 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')); | ||||
|         $output = "<?php }\n"; | ||||
|         if ($openTag !== 'forelse') { | ||||
|             $output .= "}\n"; | ||||
|         } | ||||
|         $output .= "?>"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										343
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_foreach.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										343
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_foreach.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,343 @@ | ||||
| <?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_Compile_Private_ForeachSection | ||||
| { | ||||
|     /** | ||||
|      * 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', 'properties'); | ||||
|  | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $shorttag_order = array('from', 'item', 'key', 'name'); | ||||
|  | ||||
|     /** | ||||
|      * counter | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $counter = 0; | ||||
|  | ||||
|     /** | ||||
|      * Name of this tag | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tagName = 'foreach'; | ||||
|  | ||||
|     /** | ||||
|      * Valid properties of $smarty.foreach.name.xxx variable | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $nameProperties = array('first', 'last', 'index', 'iteration', 'show', 'total'); | ||||
|  | ||||
|     /** | ||||
|      * Valid properties of $item@xxx variable | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $itemProperties = array('first', 'last', 'index', 'iteration', 'show', 'total', 'key'); | ||||
|  | ||||
|     /** | ||||
|      * Flag if tag had name attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $isNamed = false; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {foreach} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $compiler->loopNesting++; | ||||
|         // init | ||||
|         $this->isNamed = false; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $from = $_attr[ 'from' ]; | ||||
|         $item = $compiler->getId($_attr[ 'item' ]); | ||||
|         if ($item === false) { | ||||
|             $item = $compiler->getVariableName($_attr[ 'item' ]); | ||||
|         } | ||||
|         $key = $name = null; | ||||
|         $attributes = array('item' => $item); | ||||
|         if (isset($_attr[ 'key' ])) { | ||||
|             $key = $compiler->getId($_attr[ 'key' ]); | ||||
|             if ($key === false) { | ||||
|                 $key = $compiler->getVariableName($_attr[ 'key' ]); | ||||
|             } | ||||
|             $attributes[ 'key' ] = $key; | ||||
|         } | ||||
|         if (isset($_attr[ 'name' ])) { | ||||
|             $this->isNamed = true; | ||||
|             $name = $attributes[ 'name' ] = $compiler->getId($_attr[ 'name' ]); | ||||
|         } | ||||
|         foreach ($attributes as $a => $v) { | ||||
|             if ($v === false) { | ||||
|                 $compiler->trigger_template_error("'{$a}' attribute/variable has illegal value", null, true); | ||||
|             } | ||||
|         } | ||||
|         $fromName = $compiler->getVariableName($_attr[ 'from' ]); | ||||
|         if ($fromName) { | ||||
|             foreach (array('item', 'key') as $a) { | ||||
|                 if (isset($attributes[ $a ]) && $attributes[ $a ] === $fromName) { | ||||
|                     $compiler->trigger_template_error( | ||||
|                         "'{$a}' and 'from' may not have same variable name '{$fromName}'", | ||||
|                         null, | ||||
|                         true | ||||
|                     ); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $itemVar = "\$_smarty_tpl->tpl_vars['{$item}']"; | ||||
|         $local = '$__foreach_' . $attributes[ 'item' ] . '_' . $this->counter++ . '_'; | ||||
|         // search for used tag attributes | ||||
|         $itemAttr = array(); | ||||
|         $namedAttr = array(); | ||||
|         $this->scanForProperties($attributes, $compiler); | ||||
|         if (!empty($this->matchResults[ 'item' ])) { | ||||
|             $itemAttr = $this->matchResults[ 'item' ]; | ||||
|         } | ||||
|         if (!empty($this->matchResults[ 'named' ])) { | ||||
|             $namedAttr = $this->matchResults[ 'named' ]; | ||||
|         } | ||||
|         if (isset($_attr[ 'properties' ]) && preg_match_all('/[\'](.*?)[\']/', $_attr[ 'properties' ], $match)) { | ||||
|             foreach ($match[ 1 ] as $prop) { | ||||
|                 if (in_array($prop, $this->itemProperties)) { | ||||
|                     $itemAttr[ $prop ] = true; | ||||
|                 } else { | ||||
|                     $compiler->trigger_template_error("Invalid property '{$prop}'", null, true); | ||||
|                 } | ||||
|             } | ||||
|             if ($this->isNamed) { | ||||
|                 foreach ($match[ 1 ] as $prop) { | ||||
|                     if (in_array($prop, $this->nameProperties)) { | ||||
|                         $nameAttr[ $prop ] = true; | ||||
|                     } else { | ||||
|                         $compiler->trigger_template_error("Invalid property '{$prop}'", null, true); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (isset($itemAttr[ 'first' ])) { | ||||
|             $itemAttr[ 'index' ] = true; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'first' ])) { | ||||
|             $namedAttr[ 'index' ] = true; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'last' ])) { | ||||
|             $namedAttr[ 'iteration' ] = true; | ||||
|             $namedAttr[ 'total' ] = true; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'last' ])) { | ||||
|             $itemAttr[ 'iteration' ] = true; | ||||
|             $itemAttr[ 'total' ] = true; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'show' ])) { | ||||
|             $namedAttr[ 'total' ] = true; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'show' ])) { | ||||
|             $itemAttr[ 'total' ] = true; | ||||
|         } | ||||
|         $keyTerm = ''; | ||||
|         if (isset($attributes[ 'key' ])) { | ||||
|             $keyTerm = "\$_smarty_tpl->tpl_vars['{$key}']->value => "; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'key' ])) { | ||||
|             $keyTerm = "{$itemVar}->key => "; | ||||
|         } | ||||
|         if ($this->isNamed) { | ||||
|             $foreachVar = "\$_smarty_tpl->tpl_vars['__smarty_foreach_{$attributes['name']}']"; | ||||
|         } | ||||
|         $needTotal = isset($itemAttr[ 'total' ]); | ||||
|         // Register tag | ||||
|         $this->openTag( | ||||
|             $compiler, | ||||
|             'foreach', | ||||
|             array('foreach', $compiler->nocache, $local, $itemVar, empty($itemAttr) ? 1 : 2) | ||||
|         ); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         // generate output code | ||||
|         $output = "<?php\n"; | ||||
|         $output .= "\$_from = \$_smarty_tpl->smarty->ext->_foreach->init(\$_smarty_tpl, $from, " . | ||||
|                    var_export($item, true); | ||||
|         if ($name || $needTotal || $key) { | ||||
|             $output .= ', ' . var_export($needTotal, true); | ||||
|         } | ||||
|         if ($name || $key) { | ||||
|             $output .= ', ' . var_export($key, true); | ||||
|         } | ||||
|         if ($name) { | ||||
|             $output .= ', ' . var_export($name, true) . ', ' . var_export($namedAttr, true); | ||||
|         } | ||||
|         $output .= ");\n"; | ||||
|         if (isset($itemAttr[ 'show' ])) { | ||||
|             $output .= "{$itemVar}->show = ({$itemVar}->total > 0);\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'iteration' ])) { | ||||
|             $output .= "{$itemVar}->iteration = 0;\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'index' ])) { | ||||
|             $output .= "{$itemVar}->index = -1;\n"; | ||||
|         } | ||||
| 	    $output .= "{$itemVar}->do_else = true;\n"; | ||||
|         $output .= "if (\$_from !== null) foreach (\$_from as {$keyTerm}{$itemVar}->value) {\n"; | ||||
| 	    $output .= "{$itemVar}->do_else = false;\n"; | ||||
|         if (isset($attributes[ 'key' ]) && isset($itemAttr[ 'key' ])) { | ||||
|             $output .= "\$_smarty_tpl->tpl_vars['{$key}']->value = {$itemVar}->key;\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'iteration' ])) { | ||||
|             $output .= "{$itemVar}->iteration++;\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'index' ])) { | ||||
|             $output .= "{$itemVar}->index++;\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'first' ])) { | ||||
|             $output .= "{$itemVar}->first = !{$itemVar}->index;\n"; | ||||
|         } | ||||
|         if (isset($itemAttr[ 'last' ])) { | ||||
|             $output .= "{$itemVar}->last = {$itemVar}->iteration === {$itemVar}->total;\n"; | ||||
|         } | ||||
|         if (isset($foreachVar)) { | ||||
|             if (isset($namedAttr[ 'iteration' ])) { | ||||
|                 $output .= "{$foreachVar}->value['iteration']++;\n"; | ||||
|             } | ||||
|             if (isset($namedAttr[ 'index' ])) { | ||||
|                 $output .= "{$foreachVar}->value['index']++;\n"; | ||||
|             } | ||||
|             if (isset($namedAttr[ 'first' ])) { | ||||
|                 $output .= "{$foreachVar}->value['first'] = !{$foreachVar}->value['index'];\n"; | ||||
|             } | ||||
|             if (isset($namedAttr[ 'last' ])) { | ||||
|                 $output .= "{$foreachVar}->value['last'] = {$foreachVar}->value['iteration'] === {$foreachVar}->value['total'];\n"; | ||||
|             } | ||||
|         } | ||||
|         if (!empty($itemAttr)) { | ||||
|             $output .= "{$local}saved = {$itemVar};\n"; | ||||
|         } | ||||
|         $output .= '?>'; | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for to restore saved template variables | ||||
|      * | ||||
|      * @param int $levels number of levels to restore | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compileRestore($levels) | ||||
|     { | ||||
|         return "\$_smarty_tpl->smarty->ext->_foreach->restore(\$_smarty_tpl, {$levels});"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         list($openTag, $nocache, $local, $itemVar, $restore) = $this->closeTag($compiler, array('foreach')); | ||||
|         $this->openTag($compiler, 'foreachelse', array('foreachelse', $nocache, $local, $itemVar, 0)); | ||||
|         $output = "<?php\n"; | ||||
|         if ($restore === 2) { | ||||
|             $output .= "{$itemVar} = {$local}saved;\n"; | ||||
|         } | ||||
|         $output .= "}\nif ({$itemVar}->do_else) {\n?>"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $compiler->loopNesting--; | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         list( | ||||
|             $openTag, $compiler->nocache, $local, $itemVar, $restore | ||||
|             ) = $this->closeTag($compiler, array('foreach', 'foreachelse')); | ||||
|         $output = "<?php\n"; | ||||
|         if ($restore === 2) { | ||||
|             $output .= "{$itemVar} = {$local}saved;\n"; | ||||
|         } | ||||
|         $output .= "}\n"; | ||||
|         /* @var Smarty_Internal_Compile_Foreach $foreachCompiler */ | ||||
|         $foreachCompiler = $compiler->getTagCompiler('foreach'); | ||||
|         $output .= $foreachCompiler->compileRestore(1); | ||||
|         $output .= "?>"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										236
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_function.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										236
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_function.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,236 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return bool true | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr[ 'nocache' ] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', null, true); | ||||
|         } | ||||
|         unset($_attr[ 'nocache' ]); | ||||
|         $_name = trim($_attr[ 'name' ], '\'"'); | ||||
|  | ||||
|         if (!preg_match('/^[a-zA-Z0-9_\x80-\xff]+$/', $_name)) { | ||||
| 	        $compiler->trigger_template_error("Function name contains invalid characters: {$_name}", null, true); | ||||
|         } | ||||
|  | ||||
|         $compiler->parent_compiler->tpl_function[ $_name ] = array(); | ||||
|         $save = array( | ||||
|             $_attr, $compiler->parser->current_buffer, $compiler->template->compiled->has_nocache_code, | ||||
|             $compiler->template->caching | ||||
|         ); | ||||
|         $this->openTag($compiler, 'function', $save); | ||||
|         // Init temporary context | ||||
|         $compiler->parser->current_buffer = new Smarty_Internal_ParseTree_Template(); | ||||
|         $compiler->template->compiled->has_nocache_code = false; | ||||
|         $compiler->saveRequiredPlugins(true); | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Functionclose Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Functionclose extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compiler object | ||||
|      * | ||||
|      * @var object | ||||
|      */ | ||||
|     private $compiler = null; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {/function} tag | ||||
|      * | ||||
|      * @param array                                        $args     array with attributes from parser | ||||
|      * @param object|\Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return bool true | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $this->compiler = $compiler; | ||||
|         $saved_data = $this->closeTag($compiler, array('function')); | ||||
|         $_attr = $saved_data[ 0 ]; | ||||
|         $_name = trim($_attr[ 'name' ], '\'"'); | ||||
|         $compiler->parent_compiler->tpl_function[ $_name ][ 'compiled_filepath' ] = | ||||
|             $compiler->parent_compiler->template->compiled->filepath; | ||||
|         $compiler->parent_compiler->tpl_function[ $_name ][ 'uid' ] = $compiler->template->source->uid; | ||||
|         $_parameter = $_attr; | ||||
|         unset($_parameter[ 'name' ]); | ||||
|         // default parameter | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_parameter as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         if (!empty($_paramsArray)) { | ||||
|             $_params = 'array(' . implode(',', $_paramsArray) . ')'; | ||||
|             $_paramsCode = "\$params = array_merge($_params, \$params);\n"; | ||||
|         } else { | ||||
|             $_paramsCode = ''; | ||||
|         } | ||||
|         $_functionCode = $compiler->parser->current_buffer; | ||||
|         // setup buffer for template function code | ||||
|         $compiler->parser->current_buffer = new Smarty_Internal_ParseTree_Template(); | ||||
|         $_funcName = "smarty_template_function_{$_name}_{$compiler->template->compiled->nocache_hash}"; | ||||
|         $_funcNameCaching = $_funcName . '_nocache'; | ||||
|         if ($compiler->template->compiled->has_nocache_code) { | ||||
|             $compiler->parent_compiler->tpl_function[ $_name ][ 'call_name_caching' ] = $_funcNameCaching; | ||||
|             $output = "<?php\n"; | ||||
|             $output .= "/* {$_funcNameCaching} */\n"; | ||||
|             $output .= "if (!function_exists('{$_funcNameCaching}')) {\n"; | ||||
|             $output .= "function {$_funcNameCaching} (Smarty_Internal_Template \$_smarty_tpl,\$params) {\n"; | ||||
|             $output .= "ob_start();\n"; | ||||
|             $output .= $compiler->compileRequiredPlugins(); | ||||
|             $output .= "\$_smarty_tpl->compiled->has_nocache_code = true;\n"; | ||||
|             $output .= $_paramsCode; | ||||
|             $output .= "foreach (\$params as \$key => \$value) {\n\$_smarty_tpl->tpl_vars[\$key] = new Smarty_Variable(\$value, \$_smarty_tpl->isRenderingCache);\n}\n"; | ||||
|             $output .= "\$params = var_export(\$params, true);\n"; | ||||
|             $output .= "echo \"/*%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%*/<?php "; | ||||
|             $output .= "\\\$_smarty_tpl->smarty->ext->_tplFunction->saveTemplateVariables(\\\$_smarty_tpl, '{$_name}');\nforeach (\$params as \\\$key => \\\$value) {\n\\\$_smarty_tpl->tpl_vars[\\\$key] = new Smarty_Variable(\\\$value, \\\$_smarty_tpl->isRenderingCache);\n}\n?>"; | ||||
|             $output .= "/*/%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%*/\";?>"; | ||||
|             $compiler->parser->current_buffer->append_subtree( | ||||
|                 $compiler->parser, | ||||
|                 new Smarty_Internal_ParseTree_Tag( | ||||
|                     $compiler->parser, | ||||
|                     $output | ||||
|                 ) | ||||
|             ); | ||||
|             $compiler->parser->current_buffer->append_subtree($compiler->parser, $_functionCode); | ||||
|             $output = "<?php echo \"/*%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%*/<?php "; | ||||
|             $output .= "\\\$_smarty_tpl->smarty->ext->_tplFunction->restoreTemplateVariables(\\\$_smarty_tpl, '{$_name}');?>\n"; | ||||
|             $output .= "/*/%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%*/\";\n?>"; | ||||
|             $output .= "<?php echo str_replace('{$compiler->template->compiled->nocache_hash}', \$_smarty_tpl->compiled->nocache_hash, ob_get_clean());\n"; | ||||
|             $output .= "}\n}\n"; | ||||
|             $output .= "/*/ {$_funcName}_nocache */\n\n"; | ||||
|             $output .= "?>\n"; | ||||
|             $compiler->parser->current_buffer->append_subtree( | ||||
|                 $compiler->parser, | ||||
|                 new Smarty_Internal_ParseTree_Tag( | ||||
|                     $compiler->parser, | ||||
|                     $output | ||||
|                 ) | ||||
|             ); | ||||
|             $_functionCode = new Smarty_Internal_ParseTree_Tag( | ||||
|                 $compiler->parser, | ||||
|                 preg_replace_callback( | ||||
|                     "/((<\?php )?echo '\/\*%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%\*\/([\S\s]*?)\/\*\/%%SmartyNocache:{$compiler->template->compiled->nocache_hash}%%\*\/';(\?>\n)?)/", | ||||
|                     array($this, 'removeNocache'), | ||||
|                     $_functionCode->to_smarty_php($compiler->parser) | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|         $compiler->parent_compiler->tpl_function[ $_name ][ 'call_name' ] = $_funcName; | ||||
|         $output = "<?php\n"; | ||||
|         $output .= "/* {$_funcName} */\n"; | ||||
|         $output .= "if (!function_exists('{$_funcName}')) {\n"; | ||||
|         $output .= "function {$_funcName}(Smarty_Internal_Template \$_smarty_tpl,\$params) {\n"; | ||||
|         $output .= $_paramsCode; | ||||
|         $output .= "foreach (\$params as \$key => \$value) {\n\$_smarty_tpl->tpl_vars[\$key] = new Smarty_Variable(\$value, \$_smarty_tpl->isRenderingCache);\n}\n"; | ||||
|         $output .= $compiler->compileCheckPlugins(array_merge($compiler->required_plugins[ 'compiled' ], | ||||
|             $compiler->required_plugins[ 'nocache' ])); | ||||
|         $output .= "?>\n"; | ||||
|         $compiler->parser->current_buffer->append_subtree( | ||||
|             $compiler->parser, | ||||
|             new Smarty_Internal_ParseTree_Tag( | ||||
|                 $compiler->parser, | ||||
|                 $output | ||||
|             ) | ||||
|         ); | ||||
|         $compiler->parser->current_buffer->append_subtree($compiler->parser, $_functionCode); | ||||
|         $output = "<?php\n}}\n"; | ||||
|         $output .= "/*/ {$_funcName} */\n\n"; | ||||
|         $output .= "?>\n"; | ||||
|         $compiler->parser->current_buffer->append_subtree( | ||||
|             $compiler->parser, | ||||
|             new Smarty_Internal_ParseTree_Tag( | ||||
|                 $compiler->parser, | ||||
|                 $output | ||||
|             ) | ||||
|         ); | ||||
|         $compiler->parent_compiler->blockOrFunctionCode .= $compiler->parser->current_buffer->to_smarty_php($compiler->parser); | ||||
|         // restore old buffer | ||||
|         $compiler->parser->current_buffer = $saved_data[ 1 ]; | ||||
|         // restore old status | ||||
|         $compiler->restoreRequiredPlugins(); | ||||
|         $compiler->template->compiled->has_nocache_code = $saved_data[ 2 ]; | ||||
|         $compiler->template->caching = $saved_data[ 3 ]; | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Remove nocache code | ||||
|      * | ||||
|      * @param $match | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function removeNocache($match) | ||||
|     { | ||||
|         $code = | ||||
|             preg_replace( | ||||
|                 "/((<\?php )?echo '\/\*%%SmartyNocache:{$this->compiler->template->compiled->nocache_hash}%%\*\/)|(\/\*\/%%SmartyNocache:{$this->compiler->template->compiled->nocache_hash}%%\*\/';(\?>\n)?)/", | ||||
|                 '', | ||||
|                 $match[ 0 ] | ||||
|             ); | ||||
|         $code = str_replace(array('\\\'', '\\\\\''), array('\'', '\\\''), $code); | ||||
|         return $code; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										207
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,207 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $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 (!isset($parameter[ 'if condition' ])) { | ||||
|             $compiler->trigger_template_error('missing if condition', null, true); | ||||
|         } | ||||
|         if (is_array($parameter[ 'if condition' ])) { | ||||
|             if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                 $var = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|             } else { | ||||
|                 $var = $parameter[ 'if condition' ][ 'var' ]; | ||||
|             } | ||||
|             if ($compiler->nocache) { | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 $compiler->setNocacheInVariable($var); | ||||
|             } | ||||
|             $prefixVar = $compiler->getNewPrefixVariable(); | ||||
|             $_output = "<?php {$prefixVar} = {$parameter[ 'if condition' ][ 'value' ]};?>\n"; | ||||
|             $assignAttr = array(); | ||||
|             $assignAttr[][ 'value' ] = $prefixVar; | ||||
|             $assignCompiler = new Smarty_Internal_Compile_Assign(); | ||||
|             if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|                 $_output .= $assignCompiler->compile( | ||||
|                     $assignAttr, | ||||
|                     $compiler, | ||||
|                     array('smarty_internal_index' => $parameter[ 'if condition' ][ 'var' ][ 'smarty_internal_index' ]) | ||||
|                 ); | ||||
|             } else { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ]; | ||||
|                 $_output .= $assignCompiler->compile($assignAttr, $compiler, array()); | ||||
|             } | ||||
|             $_output .= "<?php if ({$prefixVar}) {?>"; | ||||
|             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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         list($nesting, $compiler->tag_nocache) = $this->closeTag($compiler, array('if', 'elseif')); | ||||
|         if (!isset($parameter[ 'if condition' ])) { | ||||
|             $compiler->trigger_template_error('missing elseif condition', null, true); | ||||
|         } | ||||
|         $assignCode = ''; | ||||
|         $var = ''; | ||||
|         if (is_array($parameter[ 'if condition' ])) { | ||||
|             $condition_by_assign = true; | ||||
|             if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                 $var = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|             } else { | ||||
|                 $var = $parameter[ 'if condition' ][ 'var' ]; | ||||
|             } | ||||
|             if ($compiler->nocache) { | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 $compiler->setNocacheInVariable($var); | ||||
|             } | ||||
|             $prefixVar = $compiler->getNewPrefixVariable(); | ||||
|             $assignCode = "<?php {$prefixVar} = {$parameter[ 'if condition' ][ 'value' ]};?>\n"; | ||||
|             $assignCompiler = new Smarty_Internal_Compile_Assign(); | ||||
|             $assignAttr = array(); | ||||
|             $assignAttr[][ 'value' ] = $prefixVar; | ||||
|             if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|                 $assignCode .= $assignCompiler->compile( | ||||
|                     $assignAttr, | ||||
|                     $compiler, | ||||
|                     array('smarty_internal_index' => $parameter[ 'if condition' ][ 'var' ][ 'smarty_internal_index' ]) | ||||
|                 ); | ||||
|             } else { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ]; | ||||
|                 $assignCode .= $assignCompiler->compile($assignAttr, $compiler, array()); | ||||
|             } | ||||
|         } else { | ||||
|             $condition_by_assign = false; | ||||
|         } | ||||
|         $prefixCode = $compiler->getPrefixCode(); | ||||
|         if (empty($prefixCode)) { | ||||
|             if ($condition_by_assign) { | ||||
|                 $this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache)); | ||||
|                 $_output = $compiler->appendCode("<?php } else {\n?>", $assignCode); | ||||
|                 return $compiler->appendCode($_output, "<?php if ({$prefixVar}) {?>"); | ||||
|             } else { | ||||
|                 $this->openTag($compiler, 'elseif', array($nesting, $compiler->tag_nocache)); | ||||
|                 return "<?php } elseif ({$parameter['if condition']}) {?>"; | ||||
|             } | ||||
|         } else { | ||||
|             $_output = $compiler->appendCode("<?php } else {\n?>", $prefixCode); | ||||
|             $this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache)); | ||||
|             if ($condition_by_assign) { | ||||
|                 $_output = $compiler->appendCode($_output, $assignCode); | ||||
|                 return $compiler->appendCode($_output, "<?php if ({$prefixVar}) {?>"); | ||||
|             } else { | ||||
|                 return $compiler->appendCode($_output, "<?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // 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}?>"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										347
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_include.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										347
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_include.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,347 @@ | ||||
| <?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'); | ||||
|  | ||||
|     /** | ||||
|      * Valid scope names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $valid_scopes = array( | ||||
|         'parent' => Smarty::SCOPE_PARENT, 'root' => Smarty::SCOPE_ROOT, | ||||
|         'global' => Smarty::SCOPE_GLOBAL, 'tpl_root' => Smarty::SCOPE_TPL_ROOT, | ||||
|         'smarty' => Smarty::SCOPE_SMARTY | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {include} tag | ||||
|      * | ||||
|      * @param array                                  $args     array with attributes from parser | ||||
|      * @param Smarty_Internal_SmartyTemplateCompiler $compiler compiler object | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws \Exception | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_SmartyTemplateCompiler $compiler) | ||||
|     { | ||||
|         $uid = $t_hash = null; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $fullResourceName = $source_resource = $_attr[ 'file' ]; | ||||
|         $variable_template = false; | ||||
|         $cache_tpl = false; | ||||
|         // parse resource_name | ||||
|         if (preg_match('/^([\'"])(([A-Za-z0-9_\-]{2,})[:])?(([^$()]+)|(.+))\1$/', $source_resource, $match)) { | ||||
|             $type = !empty($match[ 3 ]) ? $match[ 3 ] : $compiler->template->smarty->default_resource_type; | ||||
|             $name = !empty($match[ 5 ]) ? $match[ 5 ] : $match[ 6 ]; | ||||
|             $handler = Smarty_Resource::load($compiler->smarty, $type); | ||||
|             if ($handler->recompiled || $handler->uncompiled) { | ||||
|                 $variable_template = true; | ||||
|             } | ||||
|             if (!$variable_template) { | ||||
|                 if ($type !== 'string') { | ||||
|                     $fullResourceName = "{$type}:{$name}"; | ||||
|                     $compiled = $compiler->parent_compiler->template->compiled; | ||||
|                     if (isset($compiled->includes[ $fullResourceName ])) { | ||||
|                         $compiled->includes[ $fullResourceName ]++; | ||||
|                         $cache_tpl = true; | ||||
|                     } else { | ||||
|                         if ("{$compiler->template->source->type}:{$compiler->template->source->name}" == | ||||
|                             $fullResourceName | ||||
|                         ) { | ||||
|                             // recursive call of current template | ||||
|                             $compiled->includes[ $fullResourceName ] = 2; | ||||
|                             $cache_tpl = true; | ||||
|                         } else { | ||||
|                             $compiled->includes[ $fullResourceName ] = 1; | ||||
|                         } | ||||
|                     } | ||||
|                     $fullResourceName = $match[ 1 ] . $fullResourceName . $match[ 1 ]; | ||||
|                 } | ||||
|             } | ||||
|             if (empty($match[ 5 ])) { | ||||
|                 $variable_template = true; | ||||
|             } | ||||
|         } else { | ||||
|             $variable_template = true; | ||||
|         } | ||||
|         // scope setup | ||||
|         $_scope = $compiler->convertScope($_attr, $this->valid_scopes); | ||||
|         // set flag to cache subtemplate object when called within loop or template name is variable. | ||||
|         if ($cache_tpl || $variable_template || $compiler->loopNesting > 0) { | ||||
|             $_cache_tpl = 'true'; | ||||
|         } else { | ||||
|             $_cache_tpl = 'false'; | ||||
|         } | ||||
|         // assume caching is off | ||||
|         $_caching = Smarty::CACHING_OFF; | ||||
|         $call_nocache = $compiler->tag_nocache || $compiler->nocache; | ||||
|         // caching was on and {include} is not in nocache mode | ||||
|         if ($compiler->template->caching && !$compiler->nocache && !$compiler->tag_nocache) { | ||||
|             $_caching = self::CACHING_NOCACHE_CODE; | ||||
|         } | ||||
|         // flag if included template code should be merged into caller | ||||
|         $merge_compiled_includes = ($compiler->smarty->merge_compiled_includes || $_attr[ 'inline' ] === true) && | ||||
|                                    !$compiler->template->source->handler->recompiled; | ||||
|         if ($merge_compiled_includes) { | ||||
|             // variable template name ? | ||||
|             if ($variable_template) { | ||||
|                 $merge_compiled_includes = false; | ||||
|             } | ||||
|             // variable compile_id? | ||||
|             if (isset($_attr[ 'compile_id' ]) && $compiler->isVariable($_attr[ 'compile_id' ])) { | ||||
|                 $merge_compiled_includes = false; | ||||
|             } | ||||
|         } | ||||
|         /* | ||||
|         * if the {include} tag provides individual parameter for caching or compile_id | ||||
|         * the subtemplate must not be included into the common cache file and is treated like | ||||
|         * a call in nocache mode. | ||||
|         * | ||||
|         */ | ||||
|         if ($_attr[ 'nocache' ] !== true && $_attr[ 'caching' ]) { | ||||
|             $_caching = $_new_caching = (int)$_attr[ 'caching' ]; | ||||
|             $call_nocache = true; | ||||
|         } else { | ||||
|             $_new_caching = Smarty::CACHING_LIFETIME_CURRENT; | ||||
|         } | ||||
|         if (isset($_attr[ 'cache_lifetime' ])) { | ||||
|             $_cache_lifetime = $_attr[ 'cache_lifetime' ]; | ||||
|             $call_nocache = true; | ||||
|             $_caching = $_new_caching; | ||||
|         } else { | ||||
|             $_cache_lifetime = '$_smarty_tpl->cache_lifetime'; | ||||
|         } | ||||
|         if (isset($_attr[ 'cache_id' ])) { | ||||
|             $_cache_id = $_attr[ 'cache_id' ]; | ||||
|             $call_nocache = true; | ||||
|             $_caching = $_new_caching; | ||||
|         } 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 subtemplate will be called in nocache mode do not merge | ||||
|         if ($compiler->template->caching && $call_nocache) { | ||||
|             $merge_compiled_includes = false; | ||||
|         } | ||||
|         // assign attribute | ||||
|         if (isset($_attr[ 'assign' ])) { | ||||
|             // output will be stored in a smarty variable instead of being displayed | ||||
|             if ($_assign = $compiler->getId($_attr[ 'assign' ])) { | ||||
|                 $_assign = "'{$_assign}'"; | ||||
|                 if ($compiler->tag_nocache || $compiler->nocache || $call_nocache) { | ||||
|                     // create nocache var to make it know for further compiling | ||||
|                     $compiler->setNocacheInVariable($_attr[ 'assign' ]); | ||||
|                 } | ||||
|             } else { | ||||
|                 $_assign = $_attr[ 'assign' ]; | ||||
|             } | ||||
|         } | ||||
|         $has_compiled_template = false; | ||||
|         if ($merge_compiled_includes) { | ||||
|             $c_id = isset($_attr[ 'compile_id' ]) ? $_attr[ 'compile_id' ] : $compiler->template->compile_id; | ||||
|             // we must observe different compile_id and caching | ||||
|             $t_hash = sha1($c_id . ($_caching ? '--caching' : '--nocaching')); | ||||
|             $compiler->smarty->allow_ambiguous_resources = true; | ||||
|             /* @var Smarty_Internal_Template $tpl */ | ||||
|             $tpl = new $compiler->smarty->template_class( | ||||
|                 trim($fullResourceName, '"\''), | ||||
|                 $compiler->smarty, | ||||
|                 $compiler->template, | ||||
|                 $compiler->template->cache_id, | ||||
|                 $c_id, | ||||
|                 $_caching | ||||
|             ); | ||||
|             $uid = $tpl->source->type . $tpl->source->uid; | ||||
|             if (!isset($compiler->parent_compiler->mergedSubTemplatesData[ $uid ][ $t_hash ])) { | ||||
|                 $has_compiled_template = $this->compileInlineTemplate($compiler, $tpl, $t_hash); | ||||
|             } else { | ||||
|                 $has_compiled_template = true; | ||||
|             } | ||||
|             unset($tpl); | ||||
|         } | ||||
|         // 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 | ||||
|         $_vars = 'array()'; | ||||
|         if (!empty($_attr)) { | ||||
|             $_pairs = array(); | ||||
|             // create variables | ||||
|             foreach ($_attr as $key => $value) { | ||||
|                 $_pairs[] = "'$key'=>$value"; | ||||
|             } | ||||
|             $_vars = 'array(' . join(',', $_pairs) . ')'; | ||||
|         } | ||||
|         $update_compile_id = $compiler->template->caching && !$compiler->tag_nocache && !$compiler->nocache && | ||||
|                              $_compile_id !== '$_smarty_tpl->compile_id'; | ||||
|         if ($has_compiled_template && !$call_nocache) { | ||||
|             $_output = "<?php\n"; | ||||
|             if ($update_compile_id) { | ||||
|                 $_output .= $compiler->makeNocacheCode("\$_compile_id_save[] = \$_smarty_tpl->compile_id;\n\$_smarty_tpl->compile_id = {$_compile_id};\n"); | ||||
|             } | ||||
|             if (!empty($_attr) && $_caching === 9999 && $compiler->template->caching) { | ||||
|                 $_vars_nc = "foreach ($_vars as \$ik => \$iv) {\n"; | ||||
|                 $_vars_nc .= "\$_smarty_tpl->tpl_vars[\$ik] =  new Smarty_Variable(\$iv);\n"; | ||||
|                 $_vars_nc .= "}\n"; | ||||
|                 $_output .= substr($compiler->processNocacheCode('<?php ' . $_vars_nc . "?>\n", true), 6, -3); | ||||
|             } | ||||
|             if (isset($_assign)) { | ||||
|                 $_output .= "ob_start();\n"; | ||||
|             } | ||||
|             $_output .= "\$_smarty_tpl->_subTemplateRender({$fullResourceName}, {$_cache_id}, {$_compile_id}, {$_caching}, {$_cache_lifetime}, {$_vars}, {$_scope}, {$_cache_tpl}, '{$compiler->parent_compiler->mergedSubTemplatesData[$uid][$t_hash]['uid']}', '{$compiler->parent_compiler->mergedSubTemplatesData[$uid][$t_hash]['func']}');\n"; | ||||
|             if (isset($_assign)) { | ||||
|                 $_output .= "\$_smarty_tpl->assign({$_assign}, ob_get_clean());\n"; | ||||
|             } | ||||
|             if ($update_compile_id) { | ||||
|                 $_output .= $compiler->makeNocacheCode("\$_smarty_tpl->compile_id = array_pop(\$_compile_id_save);\n"); | ||||
|             } | ||||
|             $_output .= "?>"; | ||||
|             return $_output; | ||||
|         } | ||||
|         if ($call_nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $_output = "<?php "; | ||||
|         if ($update_compile_id) { | ||||
|             $_output .= "\$_compile_id_save[] = \$_smarty_tpl->compile_id;\n\$_smarty_tpl->compile_id = {$_compile_id};\n"; | ||||
|         } | ||||
|         // was there an assign attribute | ||||
|         if (isset($_assign)) { | ||||
|             $_output .= "ob_start();\n"; | ||||
|         } | ||||
|         $_output .= "\$_smarty_tpl->_subTemplateRender({$fullResourceName}, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_scope, {$_cache_tpl});\n"; | ||||
|         if (isset($_assign)) { | ||||
|             $_output .= "\$_smarty_tpl->assign({$_assign}, ob_get_clean());\n"; | ||||
|         } | ||||
|         if ($update_compile_id) { | ||||
|             $_output .= "\$_smarty_tpl->compile_id = array_pop(\$_compile_id_save);\n"; | ||||
|         } | ||||
|         $_output .= "?>"; | ||||
|         return $_output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile inline sub template | ||||
|      * | ||||
|      * @param \Smarty_Internal_SmartyTemplateCompiler $compiler | ||||
|      * @param \Smarty_Internal_Template               $tpl | ||||
|      * @param string                                  $t_hash | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws \Exception | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compileInlineTemplate( | ||||
|         Smarty_Internal_SmartyTemplateCompiler $compiler, | ||||
|         Smarty_Internal_Template $tpl, | ||||
|         $t_hash | ||||
|     ) { | ||||
|         $uid = $tpl->source->type . $tpl->source->uid; | ||||
|         if (!($tpl->source->handler->uncompiled) && $tpl->source->exists) { | ||||
|             $compiler->parent_compiler->mergedSubTemplatesData[ $uid ][ $t_hash ][ 'uid' ] = $tpl->source->uid; | ||||
|             if (isset($compiler->template->inheritance)) { | ||||
|                 $tpl->inheritance = clone $compiler->template->inheritance; | ||||
|             } | ||||
|             $tpl->compiled = new Smarty_Template_Compiled(); | ||||
|             $tpl->compiled->nocache_hash = $compiler->parent_compiler->template->compiled->nocache_hash; | ||||
|             $tpl->loadCompiler(); | ||||
|             // save unique function name | ||||
|             $compiler->parent_compiler->mergedSubTemplatesData[ $uid ][ $t_hash ][ 'func' ] = | ||||
|             $tpl->compiled->unifunc = 'content_' . str_replace(array('.', ','), '_', uniqid('', true)); | ||||
|             // make sure whole chain gets compiled | ||||
|             $tpl->mustCompile = true; | ||||
|             $compiler->parent_compiler->mergedSubTemplatesData[ $uid ][ $t_hash ][ 'nocache_hash' ] = | ||||
|                 $tpl->compiled->nocache_hash; | ||||
|             if ($tpl->source->type === 'file') { | ||||
|                 $sourceInfo = $tpl->source->filepath; | ||||
|             } else { | ||||
|                 $basename = $tpl->source->handler->getBasename($tpl->source); | ||||
|                 $sourceInfo = $tpl->source->type . ':' . | ||||
|                               ($basename ? $basename : $tpl->source->name); | ||||
|             } | ||||
|             // get compiled code | ||||
|             $compiled_code = "<?php\n\n"; | ||||
|             $compiled_code .= "/* Start inline template \"{$sourceInfo}\" =============================*/\n"; | ||||
|             $compiled_code .= "function {$tpl->compiled->unifunc} (Smarty_Internal_Template \$_smarty_tpl) {\n"; | ||||
|             $compiled_code .= "?>\n" . $tpl->compiler->compileTemplateSource($tpl, null, $compiler->parent_compiler); | ||||
|             $compiled_code .= "<?php\n"; | ||||
|             $compiled_code .= "}\n?>\n"; | ||||
|             $compiled_code .= $tpl->compiler->postFilter($tpl->compiler->blockOrFunctionCode); | ||||
|             $compiled_code .= "<?php\n\n"; | ||||
|             $compiled_code .= "/* End inline template \"{$sourceInfo}\" =============================*/\n"; | ||||
|             $compiled_code .= '?>'; | ||||
|             unset($tpl->compiler); | ||||
|             if ($tpl->compiled->has_nocache_code) { | ||||
|                 // replace nocache_hash | ||||
|                 $compiled_code = | ||||
|                     str_replace( | ||||
|                         "{$tpl->compiled->nocache_hash}", | ||||
|                         $compiler->template->compiled->nocache_hash, | ||||
|                         $compiled_code | ||||
|                     ); | ||||
|                 $compiler->template->compiled->has_nocache_code = true; | ||||
|             } | ||||
|             $compiler->parent_compiler->mergedSubTemplatesCode[ $tpl->compiled->unifunc ] = $compiled_code; | ||||
|             return true; | ||||
|         } else { | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,110 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $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; | ||||
|         $_file = null; | ||||
|         eval('$_file = @' . $_attr[ 'file' ] . ';'); | ||||
|         if (!isset($compiler->smarty->security_policy) && file_exists($_file)) { | ||||
|             $_filepath = $compiler->smarty->_realpath($_file, true); | ||||
|         } 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) { | ||||
|                     $_path = $compiler->smarty->_realpath($_script_dir . DIRECTORY_SEPARATOR . $_file, true); | ||||
|                     if (file_exists($_path)) { | ||||
|                         $_filepath = $_path; | ||||
|                         break; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($_filepath === false) { | ||||
|             $compiler->trigger_template_error("{include_php} file '{$_file}' is not readable", null, true); | ||||
|         } | ||||
|         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();\ninclude{$_once} ('{$_filepath}');\n\$_smarty_tpl->assign({$_assign},ob_get_clean());\n?>"; | ||||
|         } else { | ||||
|             return "<?php include{$_once} ('{$_filepath}');?>\n"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										157
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_insert.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_insert.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $nocacheParam = $compiler->template->caching && ($compiler->tag_nocache || $compiler->nocache); | ||||
|         if (!$nocacheParam) { | ||||
|             // do not 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 | ||||
|             $var = trim($_attr[ 'assign' ], '\''); | ||||
|             if (isset($compiler->template->tpl_vars[ $var ])) { | ||||
|                 $compiler->template->tpl_vars[ $var ]->nocache = true; | ||||
|             } else { | ||||
|                 $compiler->template->tpl_vars[ $var ] = 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 instanceof SmartyBC ? $compiler->smarty->trusted_dir : null; | ||||
|                 } | ||||
|                 if (!empty($_dir)) { | ||||
|                     foreach ((array)$_dir as $_script_dir) { | ||||
|                         $_script_dir = rtrim($_script_dir, '/\\') . DIRECTORY_SEPARATOR; | ||||
|                         if (file_exists($_script_dir . $_script)) { | ||||
|                             $_filepath = $_script_dir . $_script; | ||||
|                             break; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($_filepath === false) { | ||||
|                 $compiler->trigger_template_error("{insert} missing script file '{$_script}'", null, true); | ||||
|             } | ||||
|             // code for script file loading | ||||
|             $_output .= "require_once '{$_filepath}' ;"; | ||||
|             include_once $_filepath; | ||||
|             if (!is_callable($_function)) { | ||||
|                 $compiler->trigger_template_error( | ||||
|                     " {insert} function '{$_function}' is not callable in script file '{$_script}'", | ||||
|                     null, | ||||
|                     true | ||||
|                 ); | ||||
|             } | ||||
|         } 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}'", | ||||
|                         null, | ||||
|                         true | ||||
|                     ); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // 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 && !$nocacheParam) { | ||||
|                 $_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 { | ||||
|             if ($_smarty_tpl->caching && !$nocacheParam) { | ||||
|                 $_output .= "echo Smarty_Internal_Nocache_Insert::compile ('{$_function}',{$_params}, \$_smarty_tpl, '{$_filepath}');?>"; | ||||
|             } else { | ||||
|                 $_output .= "echo {$_function}({$_params},\$_smarty_tpl);?>"; | ||||
|             } | ||||
|         } | ||||
|         $compiler->template->compiled->has_nocache_code = true; | ||||
|         return $_output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,37 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($_attr[ 'nocache' ] === true) { | ||||
|             $compiler->trigger_template_error('nocache option not allowed', null, true); | ||||
|         } | ||||
|         return $compiler->smarty->left_delimiter; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,62 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Make_Nocache | ||||
|  * Compiles the {make_nocache} tag | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Make_Nocache Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Make_Nocache extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $option_flags = array(); | ||||
|  | ||||
|     /** | ||||
|      * Array of names of required attribute required by tag | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $required_attributes = array('var'); | ||||
|  | ||||
|     /** | ||||
|      * Shorttag attribute order defined by its names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $shorttag_order = array('var'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {make_nocache} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         if ($compiler->template->caching) { | ||||
|             $output = "<?php \$_smarty_tpl->smarty->ext->_make_nocache->save(\$_smarty_tpl, {$_attr[ 'var' ]});\n?>\n"; | ||||
|             $compiler->template->compiled->has_nocache_code = true; | ||||
|             $compiler->suppressNocacheProcessing = true; | ||||
|             return $output; | ||||
|         } else { | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,73 @@ | ||||
| <?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 | ||||
| { | ||||
|     /** | ||||
|      * Array of names of valid option flags | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $option_flags = array(); | ||||
|  | ||||
|     /** | ||||
|      * 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $this->openTag($compiler, 'nocache', array($compiler->nocache)); | ||||
|         // 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // leave nocache mode | ||||
|         list($compiler->nocache) = $this->closeTag($compiler, array('nocache')); | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /** | ||||
|  * This file is part of Smarty. | ||||
|  * | ||||
|  * (c) 2015 Uwe Tews | ||||
|  * | ||||
|  * For the full copyright and license information, please view the LICENSE | ||||
|  * file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Parent Class | ||||
|  * | ||||
|  * @author Uwe Tews <uwe.tews@googlemail.com> | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Parent extends Smarty_Internal_Compile_Child | ||||
| { | ||||
|     /** | ||||
|      * Tag name | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tag = 'parent'; | ||||
|  | ||||
|     /** | ||||
|      * Block type | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $blockType = 'Parent'; | ||||
| } | ||||
| @@ -0,0 +1,124 @@ | ||||
| <?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'); | ||||
|  | ||||
|     /** | ||||
|      * nesting level | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $nesting = 0; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the execution of block plugin | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $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 | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter, $tag, $function = null) | ||||
|     { | ||||
|         if (!isset($tag[ 5 ]) || substr($tag, -5) !== 'close') { | ||||
|             // opening tag of block plugin | ||||
|             // check and get attributes | ||||
|             $_attr = $this->getAttributes($compiler, $args); | ||||
|             $this->nesting++; | ||||
|             unset($_attr[ 'nocache' ]); | ||||
|             list($callback, $_paramsArray, $callable) = $this->setup($compiler, $_attr, $tag, $function); | ||||
|             $_params = 'array(' . implode(',', $_paramsArray) . ')'; | ||||
|             // compile code | ||||
|             $output = "<?php "; | ||||
|             if (is_array($callback)) { | ||||
|                 $output .= "\$_block_plugin{$this->nesting} = isset({$callback[0]}) ? {$callback[0]} : null;\n"; | ||||
|                 $callback = "\$_block_plugin{$this->nesting}{$callback[1]}"; | ||||
|             } | ||||
|             if (isset($callable)) { | ||||
|                 $output .= "if (!is_callable({$callable})) {\nthrow new SmartyException('block tag \'{$tag}\' not callable or registered');\n}\n"; | ||||
|             } | ||||
|             $output .= "\$_smarty_tpl->smarty->_cache['_tag_stack'][] = array('{$tag}', {$_params});\n"; | ||||
|             $output .= "\$_block_repeat=true;\necho {$callback}({$_params}, null, \$_smarty_tpl, \$_block_repeat);\nwhile (\$_block_repeat) {\nob_start();?>"; | ||||
|             $this->openTag($compiler, $tag, array($_params, $compiler->nocache, $callback)); | ||||
|             // maybe nocache because of nocache variables or nocache plugin | ||||
|             $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         } else { | ||||
|             // must endblock be nocache? | ||||
|             if ($compiler->nocache) { | ||||
|                 $compiler->tag_nocache = true; | ||||
|             } | ||||
|             // closing tag of block plugin, restore nocache | ||||
|             list($_params, $compiler->nocache, $callback) = $this->closeTag($compiler, substr($tag, 0, -5)); | ||||
|             // compile code | ||||
|             if (!isset($parameter[ 'modifier_list' ])) { | ||||
|                 $mod_pre = $mod_post = $mod_content = ''; | ||||
|                 $mod_content2 = 'ob_get_clean()'; | ||||
|             } else { | ||||
|                 $mod_content2 = "\$_block_content{$this->nesting}"; | ||||
|                 $mod_content = "\$_block_content{$this->nesting} = ob_get_clean();\n"; | ||||
|                 $mod_pre = "ob_start();\n"; | ||||
|                 $mod_post = 'echo ' . $compiler->compileTag( | ||||
|                         'private_modifier', | ||||
|                         array(), | ||||
|                         array( | ||||
|                             'modifierlist' => $parameter[ 'modifier_list' ], | ||||
|                             'value'        => 'ob_get_clean()' | ||||
|                         ) | ||||
|                     ) . ";\n"; | ||||
|             } | ||||
|             $output = | ||||
|                 "<?php {$mod_content}\$_block_repeat=false;\n{$mod_pre}echo {$callback}({$_params}, {$mod_content2}, \$_smarty_tpl, \$_block_repeat);\n{$mod_post}}\n"; | ||||
|             $output .= 'array_pop($_smarty_tpl->smarty->_cache[\'_tag_stack\']);?>'; | ||||
|         } | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Setup callback and parameter array | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param array                                 $_attr attributes | ||||
|      * @param string                                $tag | ||||
|      * @param string                                $function | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function setup(Smarty_Internal_TemplateCompilerBase $compiler, $_attr, $tag, $function) | ||||
|     { | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         return array($function, $_paramsArray, null); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,228 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile ForeachSection | ||||
|  * Shared methods for {foreach} {section} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile ForeachSection Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_ForeachSection extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Name of this tag | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tagName = ''; | ||||
|  | ||||
|     /** | ||||
|      * Valid properties of $smarty.xxx variable | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $nameProperties = array(); | ||||
|  | ||||
|     /** | ||||
|      * {section} tag has no item properties | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $itemProperties = null; | ||||
|  | ||||
|     /** | ||||
|      * {section} tag has always name attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $isNamed = true; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     public $matchResults = array(); | ||||
|  | ||||
|     /** | ||||
|      * Preg search pattern | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $propertyPreg = ''; | ||||
|  | ||||
|     /** | ||||
|      * Offsets in preg match result | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $resultOffsets = array(); | ||||
|  | ||||
|     /** | ||||
|      * Start offset | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     private $startOffset = 0; | ||||
|  | ||||
|     /** | ||||
|      * Scan sources for used tag attributes | ||||
|      * | ||||
|      * @param array                                 $attributes | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function scanForProperties($attributes, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $this->propertyPreg = '~('; | ||||
|         $this->startOffset = 1; | ||||
|         $this->resultOffsets = array(); | ||||
|         $this->matchResults = array('named' => array(), 'item' => array()); | ||||
|         if (isset($attributes[ 'name' ])) { | ||||
|             $this->buildPropertyPreg(true, $attributes); | ||||
|         } | ||||
|         if (isset($this->itemProperties)) { | ||||
|             if ($this->isNamed) { | ||||
|                 $this->propertyPreg .= '|'; | ||||
|             } | ||||
|             $this->buildPropertyPreg(false, $attributes); | ||||
|         } | ||||
|         $this->propertyPreg .= ')\W~i'; | ||||
|         // Template source | ||||
|         $this->matchTemplateSource($compiler); | ||||
|         // Parent template source | ||||
|         $this->matchParentTemplateSource($compiler); | ||||
|         // {block} source | ||||
|         $this->matchBlockSource($compiler); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Build property preg string | ||||
|      * | ||||
|      * @param bool  $named | ||||
|      * @param array $attributes | ||||
|      */ | ||||
|     public function buildPropertyPreg($named, $attributes) | ||||
|     { | ||||
|         if ($named) { | ||||
|             $this->resultOffsets[ 'named' ] = $this->startOffset = $this->startOffset + 3; | ||||
|             $this->propertyPreg .= "(([\$]smarty[.]{$this->tagName}[.]" . | ||||
|                                    ($this->tagName === 'section' ? "|[\[]\s*" : '') . | ||||
|                                    "){$attributes['name']}[.]("; | ||||
|             $properties = $this->nameProperties; | ||||
|         } else { | ||||
|             $this->resultOffsets[ 'item' ] = $this->startOffset = $this->startOffset + 2; | ||||
|             $this->propertyPreg .= "([\$]{$attributes['item']}[@]("; | ||||
|             $properties = $this->itemProperties; | ||||
|         } | ||||
|         $propName = reset($properties); | ||||
|         while ($propName) { | ||||
|             $this->propertyPreg .= "{$propName}"; | ||||
|             $propName = next($properties); | ||||
|             if ($propName) { | ||||
|                 $this->propertyPreg .= '|'; | ||||
|             } | ||||
|         } | ||||
|         $this->propertyPreg .= '))'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Find matches in source string | ||||
|      * | ||||
|      * @param string $source | ||||
|      */ | ||||
|     public function matchProperty($source) | ||||
|     { | ||||
|         preg_match_all($this->propertyPreg, $source, $match); | ||||
|         foreach ($this->resultOffsets as $key => $offset) { | ||||
|             foreach ($match[ $offset ] as $m) { | ||||
|                 if (!empty($m)) { | ||||
|                     $this->matchResults[ $key ][ strtolower($m) ] = true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Find matches in template source | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      */ | ||||
|     public function matchTemplateSource(Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $this->matchProperty($compiler->parser->lex->data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Find matches in all parent template source | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function matchParentTemplateSource(Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // search parent compiler template source | ||||
|         $nextCompiler = $compiler; | ||||
|         while ($nextCompiler !== $nextCompiler->parent_compiler) { | ||||
|             $nextCompiler = $nextCompiler->parent_compiler; | ||||
|             if ($compiler !== $nextCompiler) { | ||||
|                 // get template source | ||||
|                 $_content = $nextCompiler->template->source->getContent(); | ||||
|                 if ($_content !== '') { | ||||
|                     // run pre filter if required | ||||
|                     if ((isset($nextCompiler->smarty->autoload_filters[ 'pre' ]) || | ||||
|                          isset($nextCompiler->smarty->registered_filters[ 'pre' ])) | ||||
|                     ) { | ||||
|                         $_content = $nextCompiler->smarty->ext->_filterHandler->runFilter( | ||||
|                             'pre', | ||||
|                             $_content, | ||||
|                             $nextCompiler->template | ||||
|                         ); | ||||
|                     } | ||||
|                     $this->matchProperty($_content); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Find matches in {block} tag source | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      */ | ||||
|     public function matchBlockSource(Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {$smarty.foreach.xxx} or {$smarty.section.xxx}tag | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compileSpecialVariable($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         $tag = strtolower(trim($parameter[ 0 ], '"\'')); | ||||
|         $name = isset($parameter[ 1 ]) ? $compiler->getId($parameter[ 1 ]) : false; | ||||
|         if (!$name) { | ||||
|             $compiler->trigger_template_error("missing or illegal \$smarty.{$tag} name attribute", null, true); | ||||
|         } | ||||
|         $property = isset($parameter[ 2 ]) ? strtolower($compiler->getId($parameter[ 2 ])) : false; | ||||
|         if (!$property || !in_array($property, $this->nameProperties)) { | ||||
|             $compiler->trigger_template_error("missing or illegal \$smarty.{$tag} property attribute", null, true); | ||||
|         } | ||||
|         $tagVar = "'__smarty_{$tag}_{$name}'"; | ||||
|         return "(isset(\$_smarty_tpl->tpl_vars[{$tagVar}]->value['{$property}']) ? \$_smarty_tpl->tpl_vars[{$tagVar}]->value['{$property}'] : null)"; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,78 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $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 | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter, $tag, $function) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         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 = "{$function}({$_params},\$_smarty_tpl)"; | ||||
|         if (!empty($parameter[ 'modifierlist' ])) { | ||||
|             $output = $compiler->compileTag( | ||||
|                 'private_modifier', | ||||
|                 array(), | ||||
|                 array( | ||||
|                     'modifierlist' => $parameter[ 'modifierlist' ], | ||||
|                     'value'        => $output | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|         $output = "<?php echo {$output};?>\n"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,158 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $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) { | ||||
|             /* @var string $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 ])) { | ||||
|                             if (is_callable($compiler->smarty->registered_plugins[ Smarty::PLUGIN_MODIFIER ][ $modifier ][ 0 ])) { | ||||
|                                 $output = | ||||
|                                     sprintf( | ||||
|                                         'call_user_func_array($_smarty_tpl->registered_plugins[ \'%s\' ][ %s ][ 0 ], array( %s ))', | ||||
|                                         Smarty::PLUGIN_MODIFIER, | ||||
|                                         var_export($modifier, true), | ||||
|                                         $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 = $function[ 0 ] . '->' . $function[ 1 ] . '(' . $params . ')'; | ||||
|                                     } else { | ||||
|                                         $output = $function[ 0 ] . '::' . $function[ 1 ] . '(' . $params . ')'; | ||||
|                                     } | ||||
|                                 } | ||||
|                             } | ||||
|                             if (isset($compiler->required_plugins[ 'nocache' ][ $modifier ][ Smarty::PLUGIN_MODIFIER ][ 'file' ]) | ||||
|                                 || | ||||
|                                 isset($compiler->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}'", null, true); | ||||
|             } | ||||
|         } | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,42 @@ | ||||
| <?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_Compile_Private_Block_Plugin | ||||
| { | ||||
|     /** | ||||
|      * Setup callback and parameter array | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param array                                 $_attr attributes | ||||
|      * @param string                                $tag | ||||
|      * @param string                                $method | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function setup(Smarty_Internal_TemplateCompilerBase $compiler, $_attr, $tag, $method) | ||||
|     { | ||||
|         $_paramsArray = array(); | ||||
|         foreach ($_attr as $_key => $_value) { | ||||
|             if (is_int($_key)) { | ||||
|                 $_paramsArray[] = "$_key=>$_value"; | ||||
|             } else { | ||||
|                 $_paramsArray[] = "'$_key'=>$_value"; | ||||
|             } | ||||
|         } | ||||
|         $callback = array("\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]", "->{$method}"); | ||||
|         return array($callback, $_paramsArray, "array(\$_block_plugin{$this->nesting}, '{$method}')"); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,85 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $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 | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter, $tag, $method) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         unset($_attr[ 'nocache' ]); | ||||
|         $_assign = null; | ||||
|         if (isset($_attr[ 'assign' ])) { | ||||
|             $_assign = $_attr[ 'assign' ]; | ||||
|             unset($_attr[ 'assign' ]); | ||||
|         } | ||||
|         // method or property ? | ||||
|         if (is_callable(array($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) . ')'; | ||||
|                 $output = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params},\$_smarty_tpl)"; | ||||
|             } else { | ||||
|                 $_params = implode(',', $_attr); | ||||
|                 $output = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params})"; | ||||
|             } | ||||
|         } else { | ||||
|             // object property | ||||
|             $output = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}"; | ||||
|         } | ||||
|         if (!empty($parameter[ 'modifierlist' ])) { | ||||
|             $output = $compiler->compileTag( | ||||
|                 'private_modifier', | ||||
|                 array(), | ||||
|                 array('modifierlist' => $parameter[ 'modifierlist' ], 'value' => $output) | ||||
|             ); | ||||
|         } | ||||
|         if (empty($_assign)) { | ||||
|             return "<?php echo {$output};?>\n"; | ||||
|         } else { | ||||
|             return "<?php \$_smarty_tpl->assign({$_assign},{$output});?>\n"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,253 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile PHP Expression | ||||
|  * Compiles any tag which will output an expression or variable | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile PHP Expression Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Private_Php extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Attribute definition: Overwrites base class. | ||||
|      * | ||||
|      * @var array | ||||
|      * @see Smarty_Internal_CompileBase | ||||
|      */ | ||||
|     public $required_attributes = array('code', 'type'); | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for generating output from any expression | ||||
|      * | ||||
|      * @param array                                 $args      array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $compiler->has_code = false; | ||||
|         if ($_attr[ 'type' ] === 'xml') { | ||||
|             $compiler->tag_nocache = true; | ||||
|             $output = addcslashes($_attr[ 'code' ], "'\\"); | ||||
|             $compiler->parser->current_buffer->append_subtree( | ||||
|                 $compiler->parser, | ||||
|                 new Smarty_Internal_ParseTree_Tag( | ||||
|                     $compiler->parser, | ||||
|                     $compiler->processNocacheCode( | ||||
|                         "<?php echo '{$output}';?>\n", | ||||
|                         true | ||||
|                     ) | ||||
|                 ) | ||||
|             ); | ||||
|             return ''; | ||||
|         } | ||||
|         if ($_attr[ 'type' ] !== 'tag') { | ||||
|             if ($compiler->php_handling === Smarty::PHP_REMOVE) { | ||||
|                 return ''; | ||||
|             } elseif ($compiler->php_handling === Smarty::PHP_QUOTE) { | ||||
|                 $output = | ||||
|                     preg_replace_callback( | ||||
|                         '#(<\?(?:php|=)?)|(<%)|(<script\s+language\s*=\s*["\']?\s*php\s*["\']?\s*>)|(\?>)|(%>)|(<\/script>)#i', | ||||
|                         array($this, 'quote'), | ||||
|                         $_attr[ 'code' ] | ||||
|                     ); | ||||
|                 $compiler->parser->current_buffer->append_subtree( | ||||
|                     $compiler->parser, | ||||
|                     new Smarty_Internal_ParseTree_Text($output) | ||||
|                 ); | ||||
|                 return ''; | ||||
|             } elseif ($compiler->php_handling === Smarty::PHP_PASSTHRU || $_attr[ 'type' ] === 'unmatched') { | ||||
|                 $compiler->tag_nocache = true; | ||||
|                 $output = addcslashes($_attr[ 'code' ], "'\\"); | ||||
|                 $compiler->parser->current_buffer->append_subtree( | ||||
|                     $compiler->parser, | ||||
|                     new Smarty_Internal_ParseTree_Tag( | ||||
|                         $compiler->parser, | ||||
|                         $compiler->processNocacheCode( | ||||
|                             "<?php echo '{$output}';?>\n", | ||||
|                             true | ||||
|                         ) | ||||
|                     ) | ||||
|                 ); | ||||
|                 return ''; | ||||
|             } elseif ($compiler->php_handling === Smarty::PHP_ALLOW) { | ||||
|                 if (!($compiler->smarty instanceof SmartyBC)) { | ||||
|                     $compiler->trigger_template_error( | ||||
|                         '$smarty->php_handling PHP_ALLOW not allowed. Use SmartyBC to enable it', | ||||
|                         null, | ||||
|                         true | ||||
|                     ); | ||||
|                 } | ||||
|                 $compiler->has_code = true; | ||||
|                 return $_attr[ 'code' ]; | ||||
|             } else { | ||||
|                 $compiler->trigger_template_error('Illegal $smarty->php_handling value', null, true); | ||||
|             } | ||||
|         } else { | ||||
|             $compiler->has_code = true; | ||||
|             if (!($compiler->smarty instanceof SmartyBC)) { | ||||
|                 $compiler->trigger_template_error( | ||||
|                     '{php}{/php} tags not allowed. Use SmartyBC to enable them', | ||||
|                     null, | ||||
|                     true | ||||
|                 ); | ||||
|             } | ||||
|             $ldel = preg_quote($compiler->smarty->left_delimiter, '#'); | ||||
|             $rdel = preg_quote($compiler->smarty->right_delimiter, '#'); | ||||
|             preg_match("#^({$ldel}php\\s*)((.)*?)({$rdel})#", $_attr[ 'code' ], $match); | ||||
|             if (!empty($match[ 2 ])) { | ||||
|                 if ('nocache' === trim($match[ 2 ])) { | ||||
|                     $compiler->tag_nocache = true; | ||||
|                 } else { | ||||
|                     $compiler->trigger_template_error("illegal value of option flag '{$match[2]}'", null, true); | ||||
|                 } | ||||
|             } | ||||
|             return preg_replace( | ||||
|                 array("#^{$ldel}\\s*php\\s*(.)*?{$rdel}#", "#{$ldel}\\s*/\\s*php\\s*{$rdel}$#"), | ||||
|                 array('<?php ', '?>'), | ||||
|                 $_attr[ 'code' ] | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Lexer code for PHP tags | ||||
|      * | ||||
|      * This code has been moved from lexer here fo easier debugging and maintenance | ||||
|      * | ||||
|      * @param Smarty_Internal_Templatelexer $lex | ||||
|      * | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function parsePhp(Smarty_Internal_Templatelexer $lex) | ||||
|     { | ||||
|         $lex->token = Smarty_Internal_Templateparser::TP_PHP; | ||||
|         $close = 0; | ||||
|         $lex->taglineno = $lex->line; | ||||
|         $closeTag = '?>'; | ||||
|         if (strpos($lex->value, '<?xml') === 0) { | ||||
|             $lex->is_xml = true; | ||||
|             $lex->phpType = 'xml'; | ||||
|             return; | ||||
|         } elseif (strpos($lex->value, '<?') === 0) { | ||||
|             $lex->phpType = 'php'; | ||||
|         } elseif (strpos($lex->value, '<%') === 0) { | ||||
|             $lex->phpType = 'asp'; | ||||
|             $closeTag = '%>'; | ||||
|         } elseif (strpos($lex->value, '%>') === 0) { | ||||
|             $lex->phpType = 'unmatched'; | ||||
|         } elseif (strpos($lex->value, '?>') === 0) { | ||||
|             if ($lex->is_xml) { | ||||
|                 $lex->is_xml = false; | ||||
|                 $lex->phpType = 'xml'; | ||||
|                 return; | ||||
|             } | ||||
|             $lex->phpType = 'unmatched'; | ||||
|         } elseif (strpos($lex->value, '<s') === 0) { | ||||
|             $lex->phpType = 'script'; | ||||
|             $closeTag = '</script>'; | ||||
|         } elseif (strpos($lex->value, $lex->smarty->left_delimiter) === 0) { | ||||
|             if ($lex->isAutoLiteral()) { | ||||
|                 $lex->token = Smarty_Internal_Templateparser::TP_TEXT; | ||||
|                 return; | ||||
|             } | ||||
|             $closeTag = "{$lex->smarty->left_delimiter}/php{$lex->smarty->right_delimiter}"; | ||||
|             if ($lex->value === $closeTag) { | ||||
|                 $lex->compiler->trigger_template_error("unexpected closing tag '{$closeTag}'"); | ||||
|             } | ||||
|             $lex->phpType = 'tag'; | ||||
|         } | ||||
|         if ($lex->phpType === 'unmatched') { | ||||
|             return; | ||||
|         } | ||||
|         if (($lex->phpType === 'php' || $lex->phpType === 'asp') | ||||
|             && | ||||
|             ($lex->compiler->php_handling === Smarty::PHP_PASSTHRU || | ||||
|              $lex->compiler->php_handling === Smarty::PHP_QUOTE) | ||||
|         ) { | ||||
|             return; | ||||
|         } | ||||
|         $start = $lex->counter + strlen($lex->value); | ||||
|         $body = true; | ||||
|         if (preg_match('~' . preg_quote($closeTag, '~') . '~i', $lex->data, $match, PREG_OFFSET_CAPTURE, $start)) { | ||||
|             $close = $match[ 0 ][ 1 ]; | ||||
|         } else { | ||||
|             $lex->compiler->trigger_template_error("missing closing tag '{$closeTag}'"); | ||||
|         } | ||||
|         while ($body) { | ||||
|             if (preg_match( | ||||
|                 '~([/][*])|([/][/][^\n]*)|(\'[^\'\\\\]*(?:\\.[^\'\\\\]*)*\')|("[^"\\\\]*(?:\\.[^"\\\\]*)*")~', | ||||
|                 $lex->data, | ||||
|                 $match, | ||||
|                 PREG_OFFSET_CAPTURE, | ||||
|                 $start | ||||
|             ) | ||||
|             ) { | ||||
|                 $value = $match[ 0 ][ 0 ]; | ||||
|                 $from = $pos = $match[ 0 ][ 1 ]; | ||||
|                 if ($pos > $close) { | ||||
|                     $body = false; | ||||
|                 } else { | ||||
|                     $start = $pos + strlen($value); | ||||
|                     $phpCommentStart = $value === '/*'; | ||||
|                     if ($phpCommentStart) { | ||||
|                         $phpCommentEnd = preg_match('~([*][/])~', $lex->data, $match, PREG_OFFSET_CAPTURE, $start); | ||||
|                         if ($phpCommentEnd) { | ||||
|                             $pos2 = $match[ 0 ][ 1 ]; | ||||
|                             $start = $pos2 + strlen($match[ 0 ][ 0 ]); | ||||
|                         } | ||||
|                     } | ||||
|                     while ($close > $pos && $close < $start) { | ||||
|                         if (preg_match( | ||||
|                             '~' . preg_quote($closeTag, '~') . '~i', | ||||
|                             $lex->data, | ||||
|                             $match, | ||||
|                             PREG_OFFSET_CAPTURE, | ||||
|                             $from | ||||
|                         ) | ||||
|                         ) { | ||||
|                             $close = $match[ 0 ][ 1 ]; | ||||
|                             $from = $close + strlen($match[ 0 ][ 0 ]); | ||||
|                         } else { | ||||
|                             $lex->compiler->trigger_template_error("missing closing tag '{$closeTag}'"); | ||||
|                         } | ||||
|                     } | ||||
|                     if ($phpCommentStart && (!$phpCommentEnd || $pos2 > $close)) { | ||||
|                         $lex->taglineno = $lex->line + substr_count(substr($lex->data, $lex->counter, $start), "\n"); | ||||
|                         $lex->compiler->trigger_template_error("missing PHP comment closing tag '*/'"); | ||||
|                     } | ||||
|                 } | ||||
|             } else { | ||||
|                 $body = false; | ||||
|             } | ||||
|         } | ||||
|         $lex->value = substr($lex->data, $lex->counter, $close + strlen($closeTag) - $lex->counter); | ||||
|     } | ||||
|  | ||||
|     /* | ||||
|      * Call back function for $php_handling = PHP_QUOTE | ||||
|      * | ||||
|      */ | ||||
|     /** | ||||
|      * @param $match | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function quote($match) | ||||
|     { | ||||
|         return htmlspecialchars($match[ 0 ], ENT_QUOTES); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,161 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $output = $parameter[ 'value' ]; | ||||
|         // tag modifier | ||||
|         if (!empty($parameter[ 'modifierlist' ])) { | ||||
|             $output = $compiler->compileTag( | ||||
|                 'private_modifier', | ||||
|                 array(), | ||||
|                 array( | ||||
|                     'modifierlist' => $parameter[ 'modifierlist' ], | ||||
|                     'value'        => $output | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|         if (isset($_attr[ 'assign' ])) { | ||||
|             // assign output to variable | ||||
|             return "<?php \$_smarty_tpl->assign({$_attr['assign']},{$output});?>"; | ||||
|         } else { | ||||
|             // display value | ||||
|             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_variable_filter($compiler, $name, $output); | ||||
|                         if ($result !== false) { | ||||
|                             $output = $result; | ||||
|                         } else { | ||||
|                             // not found, throw exception | ||||
|                             throw new SmartyException("Unable to load variable filter '{$name}'"); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 foreach ($compiler->variable_filters as $filter) { | ||||
|                     if (count($filter) === 1 | ||||
|                         && ($result = $this->compile_variable_filter($compiler, $filter[ 0 ], $output)) !== false | ||||
|                     ) { | ||||
|                         $output = $result; | ||||
|                     } else { | ||||
|                         $output = $compiler->compileTag( | ||||
|                             'private_modifier', | ||||
|                             array(), | ||||
|                             array('modifierlist' => array($filter), 'value' => $output) | ||||
|                         ); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             $output = "<?php echo {$output};?>\n"; | ||||
|         } | ||||
|         return $output; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * @param string                                $name     name of variable filter | ||||
|      * @param string                                $output   embedded output | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     private function compile_variable_filter(Smarty_Internal_TemplateCompilerBase $compiler, $name, $output) | ||||
|     { | ||||
|         $function = $compiler->getPlugin($name, 'variablefilter'); | ||||
|         if ($function) { | ||||
|             return "{$function}({$output},\$_smarty_tpl)"; | ||||
|         } else { | ||||
|             // not found | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,72 @@ | ||||
| <?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_Compile_Private_Block_Plugin | ||||
| { | ||||
|     /** | ||||
|      * Setup callback, parameter array and nocache mode | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param array                                 $_attr attributes | ||||
|      * @param string                                $tag | ||||
|      * @param null                                  $function | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function setup(Smarty_Internal_TemplateCompilerBase $compiler, $_attr, $tag, $function) | ||||
|     { | ||||
|         if (isset($compiler->smarty->registered_plugins[ Smarty::PLUGIN_BLOCK ][ $tag ])) { | ||||
|             $tag_info = $compiler->smarty->registered_plugins[ Smarty::PLUGIN_BLOCK ][ $tag ]; | ||||
|             $callback = $tag_info[ 0 ]; | ||||
|             if (is_array($callback)) { | ||||
|                 if (is_object($callback[ 0 ])) { | ||||
|                     $callable = "array(\$_block_plugin{$this->nesting}, '{$callback[1]}')"; | ||||
|                     $callback = | ||||
|                         array("\$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0][0]", "->{$callback[1]}"); | ||||
|                 } else { | ||||
|                     $callable = "array(\$_block_plugin{$this->nesting}, '{$callback[1]}')"; | ||||
|                     $callback = | ||||
|                         array("\$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0][0]", "::{$callback[1]}"); | ||||
|                 } | ||||
|             } else { | ||||
|                 $callable = "\$_block_plugin{$this->nesting}"; | ||||
|                 $callback = array("\$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0]", ''); | ||||
|             } | ||||
|         } else { | ||||
|             $tag_info = $compiler->default_handler_plugins[ Smarty::PLUGIN_BLOCK ][ $tag ]; | ||||
|             $callback = $tag_info[ 0 ]; | ||||
|             if (is_array($callback)) { | ||||
|                 $callable = "array('{$callback[0]}', '{$callback[1]}')"; | ||||
|                 $callback = "{$callback[1]}::{$callback[1]}"; | ||||
|             } else { | ||||
|                 $callable = null; | ||||
|             } | ||||
|         } | ||||
|         $compiler->tag_nocache = !$tag_info[ 1 ] | $compiler->tag_nocache; | ||||
|         $_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"; | ||||
|             } | ||||
|         } | ||||
|         return array($callback, $_paramsArray, $callable); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,91 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * @param string                                $tag       name of function | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter, $tag) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         unset($_attr[ 'nocache' ]); | ||||
|         if (isset($compiler->smarty->registered_plugins[ Smarty::PLUGIN_FUNCTION ][ $tag ])) { | ||||
|             $tag_info = $compiler->smarty->registered_plugins[ Smarty::PLUGIN_FUNCTION ][ $tag ]; | ||||
|             $is_registered = true; | ||||
|         } else { | ||||
|             $tag_info = $compiler->default_handler_plugins[ Smarty::PLUGIN_FUNCTION ][ $tag ]; | ||||
|             $is_registered = false; | ||||
|         } | ||||
|         // not cacheable? | ||||
|         $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) . ')'; | ||||
|         // compile code | ||||
|         if ($is_registered) { | ||||
|             $output = | ||||
|                 "call_user_func_array( \$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION]['{$tag}'][0], array( {$_params},\$_smarty_tpl ) )"; | ||||
|         } else { | ||||
|             $function = $tag_info[ 0 ]; | ||||
|             if (!is_array($function)) { | ||||
|                 $output = "{$function}({$_params},\$_smarty_tpl)"; | ||||
|             } else { | ||||
|                 $output = "{$function[0]}::{$function[1]}({$_params},\$_smarty_tpl)"; | ||||
|             } | ||||
|         } | ||||
|         if (!empty($parameter[ 'modifierlist' ])) { | ||||
|             $output = $compiler->compileTag( | ||||
|                 'private_modifier', | ||||
|                 array(), | ||||
|                 array( | ||||
|                     'modifierlist' => $parameter[ 'modifierlist' ], | ||||
|                     'value'        => $output | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|         $output = "<?php echo {$output};?>\n"; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,130 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * @param                                       $parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         $_index = preg_split("/\]\[/", substr($parameter, 1, strlen($parameter) - 2)); | ||||
|         $variable = strtolower($compiler->getId($_index[ 0 ])); | ||||
|         if ($variable === false) { | ||||
|             $compiler->trigger_template_error("special \$Smarty variable name index can not be variable", null, true); | ||||
|         } | ||||
|         if (!isset($compiler->smarty->security_policy) | ||||
|             || $compiler->smarty->security_policy->isTrustedSpecialSmartyVar($variable, $compiler) | ||||
|         ) { | ||||
|             switch ($variable) { | ||||
|                 case 'foreach': | ||||
|                 case 'section': | ||||
|                     if (!isset(Smarty_Internal_TemplateCompilerBase::$_tag_objects[ $variable ])) { | ||||
|                         $class = 'Smarty_Internal_Compile_' . ucfirst($variable); | ||||
|                         Smarty_Internal_TemplateCompilerBase::$_tag_objects[ $variable ] = new $class; | ||||
|                     } | ||||
|                     return Smarty_Internal_TemplateCompilerBase::$_tag_objects[ $variable ]->compileSpecialVariable( | ||||
|                         array(), | ||||
|                         $compiler, | ||||
|                         $_index | ||||
|                     ); | ||||
|                 case 'capture': | ||||
|                     if (class_exists('Smarty_Internal_Compile_Capture')) { | ||||
|                         return Smarty_Internal_Compile_Capture::compileSpecialVariable(array(), $compiler, $_index); | ||||
|                     } | ||||
|                     return ''; | ||||
|                 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': | ||||
|                     if (isset($compiler->smarty->security_policy)) { | ||||
|                         $compiler->trigger_template_error("(secure mode) template_object not permitted"); | ||||
|                         break; | ||||
|                     } | ||||
|                     return '$_smarty_tpl'; | ||||
|                 case 'current_dir': | ||||
|                     return 'dirname($_smarty_tpl->source->filepath)'; | ||||
|                 case 'version': | ||||
|                     return "Smarty::SMARTY_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; | ||||
|                     } | ||||
|                     if (strpos($_index[ 1 ], '$') === false && strpos($_index[ 1 ], '\'') === false) { | ||||
|                         return "(defined('{$_index[1]}') ? constant('{$_index[1]}') : null)"; | ||||
|                     } else { | ||||
|                         return "(defined({$_index[1]}) ? constant({$_index[1]}) : null)"; | ||||
|                     } | ||||
|                 // no break | ||||
|                 case 'config': | ||||
|                     if (isset($_index[ 2 ])) { | ||||
|                         return "(is_array(\$tmp = \$_smarty_tpl->smarty->ext->configload->_getConfigVariable(\$_smarty_tpl, $_index[1])) ? \$tmp[$_index[2]] : null)"; | ||||
|                     } else { | ||||
|                         return "\$_smarty_tpl->smarty->ext->configload->_getConfigVariable(\$_smarty_tpl, $_index[1])"; | ||||
|                     } | ||||
|                 // no break | ||||
|                 case 'ldelim': | ||||
|                     return "\$_smarty_tpl->smarty->left_delimiter"; | ||||
|                 case 'rdelim': | ||||
|                     return "\$_smarty_tpl->smarty->right_delimiter"; | ||||
|                 default: | ||||
|                     $compiler->trigger_template_error('$smarty.' . trim($_index[ 0 ], "'") . ' is not defined'); | ||||
|                     break; | ||||
|             } | ||||
|             if (isset($_index[ 1 ])) { | ||||
|                 array_shift($_index); | ||||
|                 foreach ($_index as $_ind) { | ||||
|                     $compiled_ref = $compiled_ref . "[$_ind]"; | ||||
|                 } | ||||
|             } | ||||
|             return $compiled_ref; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,34 @@ | ||||
| <?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_Compile_Ldelim | ||||
| { | ||||
|     /** | ||||
|      * Compiles code for the {rdelim} tag | ||||
|      * This tag does output the right delimiter. | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         parent::compile($args, $compiler); | ||||
|         return $compiler->smarty->right_delimiter; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										462
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_section.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										462
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_section.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,462 @@ | ||||
| <?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_Compile_Private_ForeachSection | ||||
| { | ||||
|     /** | ||||
|      * 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', 'properties'); | ||||
|  | ||||
|     /** | ||||
|      * counter | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $counter = 0; | ||||
|  | ||||
|     /** | ||||
|      * Name of this tag | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $tagName = 'section'; | ||||
|  | ||||
|     /** | ||||
|      * Valid properties of $smarty.section.name.xxx variable | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $nameProperties = array( | ||||
|         'first', 'last', 'index', 'iteration', 'show', 'total', 'rownum', 'index_prev', | ||||
|         'index_next', 'loop' | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * {section} tag has no item properties | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $itemProperties = null; | ||||
|  | ||||
|     /** | ||||
|      * {section} tag has always name attribute | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $isNamed = true; | ||||
|  | ||||
|     /** | ||||
|      * Compiles code for the {section} tag | ||||
|      * | ||||
|      * @param array                                 $args     array with attributes from parser | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $compiler->loopNesting++; | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         $attributes = array('name' => $compiler->getId($_attr[ 'name' ])); | ||||
|         unset($_attr[ 'name' ]); | ||||
|         foreach ($attributes as $a => $v) { | ||||
|             if ($v === false) { | ||||
|                 $compiler->trigger_template_error("'{$a}' attribute/variable has illegal value", null, true); | ||||
|             } | ||||
|         } | ||||
|         $local = "\$__section_{$attributes['name']}_" . $this->counter++ . '_'; | ||||
|         $sectionVar = "\$_smarty_tpl->tpl_vars['__smarty_section_{$attributes['name']}']"; | ||||
|         $this->openTag($compiler, 'section', array('section', $compiler->nocache, $local, $sectionVar)); | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         $initLocal = array(); | ||||
|         $initNamedProperty = array(); | ||||
|         $initFor = array(); | ||||
|         $incFor = array(); | ||||
|         $cmpFor = array(); | ||||
|         $propValue = array( | ||||
|             'index'     => "{$sectionVar}->value['index']", 'show' => 'true', 'step' => 1, | ||||
|             'iteration' => "{$local}iteration", | ||||
|         ); | ||||
|         $propType = array('index' => 2, 'iteration' => 2, 'show' => 0, 'step' => 0,); | ||||
|         // search for used tag attributes | ||||
|         $this->scanForProperties($attributes, $compiler); | ||||
|         if (!empty($this->matchResults[ 'named' ])) { | ||||
|             $namedAttr = $this->matchResults[ 'named' ]; | ||||
|         } | ||||
|         if (isset($_attr[ 'properties' ]) && preg_match_all("/['](.*?)[']/", $_attr[ 'properties' ], $match)) { | ||||
|             foreach ($match[ 1 ] as $prop) { | ||||
|                 if (in_array($prop, $this->nameProperties)) { | ||||
|                     $namedAttr[ $prop ] = true; | ||||
|                 } else { | ||||
|                     $compiler->trigger_template_error("Invalid property '{$prop}'", null, true); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $namedAttr[ 'index' ] = true; | ||||
|         $output = "<?php\n"; | ||||
|         foreach ($_attr as $attr_name => $attr_value) { | ||||
|             switch ($attr_name) { | ||||
|                 case 'loop': | ||||
|                     if (is_numeric($attr_value)) { | ||||
|                         $v = (int)$attr_value; | ||||
|                         $t = 0; | ||||
|                     } else { | ||||
|                         $v = "(is_array(@\$_loop=$attr_value) ? count(\$_loop) : max(0, (int) \$_loop))"; | ||||
|                         $t = 1; | ||||
|                     } | ||||
|                     if ($t === 1) { | ||||
|                         $initLocal[ 'loop' ] = $v; | ||||
|                         $v = "{$local}loop"; | ||||
|                     } | ||||
|                     break; | ||||
|                 case 'show': | ||||
|                     if (is_bool($attr_value)) { | ||||
|                         $v = $attr_value ? 'true' : 'false'; | ||||
|                         $t = 0; | ||||
|                     } else { | ||||
|                         $v = "(bool) $attr_value"; | ||||
|                         $t = 3; | ||||
|                     } | ||||
|                     break; | ||||
|                 case 'step': | ||||
|                     if (is_numeric($attr_value)) { | ||||
|                         $v = (int)$attr_value; | ||||
|                         $v = ($v === 0) ? 1 : $v; | ||||
|                         $t = 0; | ||||
|                         break; | ||||
|                     } | ||||
|                     $initLocal[ 'step' ] = "((int)@$attr_value) === 0 ? 1 : (int)@$attr_value"; | ||||
|                     $v = "{$local}step"; | ||||
|                     $t = 2; | ||||
|                     break; | ||||
|                 case 'max': | ||||
|                 case 'start': | ||||
|                     if (is_numeric($attr_value)) { | ||||
|                         $v = (int)$attr_value; | ||||
|                         $t = 0; | ||||
|                         break; | ||||
|                     } | ||||
|                     $v = "(int)@$attr_value"; | ||||
|                     $t = 3; | ||||
|                     break; | ||||
|             } | ||||
|             if ($t === 3 && $compiler->getId($attr_value)) { | ||||
|                 $t = 1; | ||||
|             } | ||||
|             $propValue[ $attr_name ] = $v; | ||||
|             $propType[ $attr_name ] = $t; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'step' ])) { | ||||
|             $initNamedProperty[ 'step' ] = $propValue[ 'step' ]; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'iteration' ])) { | ||||
|             $propValue[ 'iteration' ] = "{$sectionVar}->value['iteration']"; | ||||
|         } | ||||
|         $incFor[ 'iteration' ] = "{$propValue['iteration']}++"; | ||||
|         $initFor[ 'iteration' ] = "{$propValue['iteration']} = 1"; | ||||
|         if ($propType[ 'step' ] === 0) { | ||||
|             if ($propValue[ 'step' ] === 1) { | ||||
|                 $incFor[ 'index' ] = "{$sectionVar}->value['index']++"; | ||||
|             } elseif ($propValue[ 'step' ] > 1) { | ||||
|                 $incFor[ 'index' ] = "{$sectionVar}->value['index'] += {$propValue['step']}"; | ||||
|             } else { | ||||
|                 $incFor[ 'index' ] = "{$sectionVar}->value['index'] -= " . -$propValue[ 'step' ]; | ||||
|             } | ||||
|         } else { | ||||
|             $incFor[ 'index' ] = "{$sectionVar}->value['index'] += {$propValue['step']}"; | ||||
|         } | ||||
|         if (!isset($propValue[ 'max' ])) { | ||||
|             $propValue[ 'max' ] = $propValue[ 'loop' ]; | ||||
|             $propType[ 'max' ] = $propType[ 'loop' ]; | ||||
|         } elseif ($propType[ 'max' ] !== 0) { | ||||
|             $propValue[ 'max' ] = "{$propValue['max']} < 0 ? {$propValue['loop']} : {$propValue['max']}"; | ||||
|             $propType[ 'max' ] = 1; | ||||
|         } else { | ||||
|             if ($propValue[ 'max' ] < 0) { | ||||
|                 $propValue[ 'max' ] = $propValue[ 'loop' ]; | ||||
|                 $propType[ 'max' ] = $propType[ 'loop' ]; | ||||
|             } | ||||
|         } | ||||
|         if (!isset($propValue[ 'start' ])) { | ||||
|             $start_code = | ||||
|                 array(1 => "{$propValue['step']} > 0 ? ", 2 => '0', 3 => ' : ', 4 => $propValue[ 'loop' ], 5 => ' - 1'); | ||||
|             if ($propType[ 'loop' ] === 0) { | ||||
|                 $start_code[ 5 ] = ''; | ||||
|                 $start_code[ 4 ] = $propValue[ 'loop' ] - 1; | ||||
|             } | ||||
|             if ($propType[ 'step' ] === 0) { | ||||
|                 if ($propValue[ 'step' ] > 0) { | ||||
|                     $start_code = array(1 => '0'); | ||||
|                     $propType[ 'start' ] = 0; | ||||
|                 } else { | ||||
|                     $start_code[ 1 ] = $start_code[ 2 ] = $start_code[ 3 ] = ''; | ||||
|                     $propType[ 'start' ] = $propType[ 'loop' ]; | ||||
|                 } | ||||
|             } else { | ||||
|                 $propType[ 'start' ] = 1; | ||||
|             } | ||||
|             $propValue[ 'start' ] = join('', $start_code); | ||||
|         } else { | ||||
|             $start_code = | ||||
|                 array( | ||||
|                     1  => "{$propValue['start']} < 0 ? ", 2 => 'max(', 3 => "{$propValue['step']} > 0 ? ", 4 => '0', | ||||
|                     5  => ' : ', 6 => '-1', 7 => ', ', 8 => "{$propValue['start']} + {$propValue['loop']}", 10 => ')', | ||||
|                     11 => ' : ', 12 => 'min(', 13 => $propValue[ 'start' ], 14 => ', ', | ||||
|                     15 => "{$propValue['step']} > 0 ? ", 16 => $propValue[ 'loop' ], 17 => ' : ', | ||||
|                     18 => $propType[ 'loop' ] === 0 ? $propValue[ 'loop' ] - 1 : "{$propValue['loop']} - 1", | ||||
|                     19 => ')' | ||||
|                 ); | ||||
|             if ($propType[ 'step' ] === 0) { | ||||
|                 $start_code[ 3 ] = $start_code[ 5 ] = $start_code[ 15 ] = $start_code[ 17 ] = ''; | ||||
|                 if ($propValue[ 'step' ] > 0) { | ||||
|                     $start_code[ 6 ] = $start_code[ 18 ] = ''; | ||||
|                 } else { | ||||
|                     $start_code[ 4 ] = $start_code[ 16 ] = ''; | ||||
|                 } | ||||
|             } | ||||
|             if ($propType[ 'start' ] === 0) { | ||||
|                 if ($propType[ 'loop' ] === 0) { | ||||
|                     $start_code[ 8 ] = $propValue[ 'start' ] + $propValue[ 'loop' ]; | ||||
|                 } | ||||
|                 $propType[ 'start' ] = $propType[ 'step' ] + $propType[ 'loop' ]; | ||||
|                 $start_code[ 1 ] = ''; | ||||
|                 if ($propValue[ 'start' ] < 0) { | ||||
|                     for ($i = 11; $i <= 19; $i++) { | ||||
|                         $start_code[ $i ] = ''; | ||||
|                     } | ||||
|                     if ($propType[ 'start' ] === 0) { | ||||
|                         $start_code = array( | ||||
|                             max( | ||||
|                                 $propValue[ 'step' ] > 0 ? 0 : -1, | ||||
|                                 $propValue[ 'start' ] + $propValue[ 'loop' ] | ||||
|                             ) | ||||
|                         ); | ||||
|                     } | ||||
|                 } else { | ||||
|                     for ($i = 1; $i <= 11; $i++) { | ||||
|                         $start_code[ $i ] = ''; | ||||
|                     } | ||||
|                     if ($propType[ 'start' ] === 0) { | ||||
|                         $start_code = | ||||
|                             array( | ||||
|                                 min( | ||||
|                                     $propValue[ 'step' ] > 0 ? $propValue[ 'loop' ] : $propValue[ 'loop' ] - 1, | ||||
|                                     $propValue[ 'start' ] | ||||
|                                 ) | ||||
|                             ); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             $propValue[ 'start' ] = join('', $start_code); | ||||
|         } | ||||
|         if ($propType[ 'start' ] !== 0) { | ||||
|             $initLocal[ 'start' ] = $propValue[ 'start' ]; | ||||
|             $propValue[ 'start' ] = "{$local}start"; | ||||
|         } | ||||
|         $initFor[ 'index' ] = "{$sectionVar}->value['index'] = {$propValue['start']}"; | ||||
|         if (!isset($_attr[ 'start' ]) && !isset($_attr[ 'step' ]) && !isset($_attr[ 'max' ])) { | ||||
|             $propValue[ 'total' ] = $propValue[ 'loop' ]; | ||||
|             $propType[ 'total' ] = $propType[ 'loop' ]; | ||||
|         } else { | ||||
|             $propType[ 'total' ] = | ||||
|                 $propType[ 'start' ] + $propType[ 'loop' ] + $propType[ 'step' ] + $propType[ 'max' ]; | ||||
|             if ($propType[ 'total' ] === 0) { | ||||
|                 $propValue[ 'total' ] = | ||||
|                     min( | ||||
|                         ceil( | ||||
|                             ($propValue[ 'step' ] > 0 ? $propValue[ 'loop' ] - $propValue[ 'start' ] : | ||||
|                                 (int)$propValue[ 'start' ] + 1) / abs($propValue[ 'step' ]) | ||||
|                         ), | ||||
|                         $propValue[ 'max' ] | ||||
|                     ); | ||||
|             } else { | ||||
|                 $total_code = array( | ||||
|                     1  => 'min(', 2 => 'ceil(', 3 => '(', 4 => "{$propValue['step']} > 0 ? ", | ||||
|                     5  => $propValue[ 'loop' ], 6 => ' - ', 7 => $propValue[ 'start' ], 8 => ' : ', | ||||
|                     9  => $propValue[ 'start' ], 10 => '+ 1', 11 => ')', 12 => '/ ', 13 => 'abs(', | ||||
|                     14 => $propValue[ 'step' ], 15 => ')', 16 => ')', 17 => ", {$propValue['max']})", | ||||
|                 ); | ||||
|                 if (!isset($propValue[ 'max' ])) { | ||||
|                     $total_code[ 1 ] = $total_code[ 17 ] = ''; | ||||
|                 } | ||||
|                 if ($propType[ 'loop' ] + $propType[ 'start' ] === 0) { | ||||
|                     $total_code[ 5 ] = $propValue[ 'loop' ] - $propValue[ 'start' ]; | ||||
|                     $total_code[ 6 ] = $total_code[ 7 ] = ''; | ||||
|                 } | ||||
|                 if ($propType[ 'start' ] === 0) { | ||||
|                     $total_code[ 9 ] = (int)$propValue[ 'start' ] + 1; | ||||
|                     $total_code[ 10 ] = ''; | ||||
|                 } | ||||
|                 if ($propType[ 'step' ] === 0) { | ||||
|                     $total_code[ 13 ] = $total_code[ 15 ] = ''; | ||||
|                     if ($propValue[ 'step' ] === 1 || $propValue[ 'step' ] === -1) { | ||||
|                         $total_code[ 2 ] = $total_code[ 12 ] = $total_code[ 14 ] = $total_code[ 16 ] = ''; | ||||
|                     } elseif ($propValue[ 'step' ] < 0) { | ||||
|                         $total_code[ 14 ] = -$propValue[ 'step' ]; | ||||
|                     } | ||||
|                     $total_code[ 4 ] = ''; | ||||
|                     if ($propValue[ 'step' ] > 0) { | ||||
|                         $total_code[ 8 ] = $total_code[ 9 ] = $total_code[ 10 ] = ''; | ||||
|                     } else { | ||||
|                         $total_code[ 5 ] = $total_code[ 6 ] = $total_code[ 7 ] = $total_code[ 8 ] = ''; | ||||
|                     } | ||||
|                 } | ||||
|                 $propValue[ 'total' ] = join('', $total_code); | ||||
|             } | ||||
|         } | ||||
|         if (isset($namedAttr[ 'loop' ])) { | ||||
|             $initNamedProperty[ 'loop' ] = "'loop' => {$propValue['loop']}"; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'total' ])) { | ||||
|             $initNamedProperty[ 'total' ] = "'total' => {$propValue['total']}"; | ||||
|             if ($propType[ 'total' ] > 0) { | ||||
|                 $propValue[ 'total' ] = "{$sectionVar}->value['total']"; | ||||
|             } | ||||
|         } elseif ($propType[ 'total' ] > 0) { | ||||
|             $initLocal[ 'total' ] = $propValue[ 'total' ]; | ||||
|             $propValue[ 'total' ] = "{$local}total"; | ||||
|         } | ||||
|         $cmpFor[ 'iteration' ] = "{$propValue['iteration']} <= {$propValue['total']}"; | ||||
|         foreach ($initLocal as $key => $code) { | ||||
|             $output .= "{$local}{$key} = {$code};\n"; | ||||
|         } | ||||
|         $_vars = 'array(' . join(', ', $initNamedProperty) . ')'; | ||||
|         $output .= "{$sectionVar} = new Smarty_Variable({$_vars});\n"; | ||||
|         $cond_code = "{$propValue['total']} !== 0"; | ||||
|         if ($propType[ 'total' ] === 0) { | ||||
|             if ($propValue[ 'total' ] === 0) { | ||||
|                 $cond_code = 'false'; | ||||
|             } else { | ||||
|                 $cond_code = 'true'; | ||||
|             } | ||||
|         } | ||||
|         if ($propType[ 'show' ] > 0) { | ||||
|             $output .= "{$local}show = {$propValue['show']} ? {$cond_code} : false;\n"; | ||||
|             $output .= "if ({$local}show) {\n"; | ||||
|         } elseif ($propValue[ 'show' ] === 'true') { | ||||
|             $output .= "if ({$cond_code}) {\n"; | ||||
|         } else { | ||||
|             $output .= "if (false) {\n"; | ||||
|         } | ||||
|         $jinit = join(', ', $initFor); | ||||
|         $jcmp = join(', ', $cmpFor); | ||||
|         $jinc = join(', ', $incFor); | ||||
|         $output .= "for ({$jinit}; {$jcmp}; {$jinc}){\n"; | ||||
|         if (isset($namedAttr[ 'rownum' ])) { | ||||
|             $output .= "{$sectionVar}->value['rownum'] = {$propValue['iteration']};\n"; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'index_prev' ])) { | ||||
|             $output .= "{$sectionVar}->value['index_prev'] = {$propValue['index']} - {$propValue['step']};\n"; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'index_next' ])) { | ||||
|             $output .= "{$sectionVar}->value['index_next'] = {$propValue['index']} + {$propValue['step']};\n"; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'first' ])) { | ||||
|             $output .= "{$sectionVar}->value['first'] = ({$propValue['iteration']} === 1);\n"; | ||||
|         } | ||||
|         if (isset($namedAttr[ 'last' ])) { | ||||
|             $output .= "{$sectionVar}->value['last'] = ({$propValue['iteration']} === {$propValue['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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         // check and get attributes | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         list($openTag, $nocache, $local, $sectionVar) = $this->closeTag($compiler, array('section')); | ||||
|         $this->openTag($compiler, 'sectionelse', array('sectionelse', $nocache, $local, $sectionVar)); | ||||
|         return "<?php }} else {\n ?>"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $compiler->loopNesting--; | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         list($openTag, $compiler->nocache, $local, $sectionVar) = | ||||
|             $this->closeTag($compiler, array('section', 'sectionelse')); | ||||
|         $output = "<?php\n"; | ||||
|         if ($openTag === 'sectionelse') { | ||||
|             $output .= "}\n"; | ||||
|         } else { | ||||
|             $output .= "}\n}\n"; | ||||
|         } | ||||
|         $output .= '?>'; | ||||
|         return $output; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,68 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         $compiler->variable_filter_stack[] = $compiler->variable_filters; | ||||
|         $compiler->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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $_attr = $this->getAttributes($compiler, $args); | ||||
|         // reset variable filter to previous state | ||||
|         if (count($compiler->variable_filter_stack)) { | ||||
|             $compiler->variable_filters = array_pop($compiler->variable_filter_stack); | ||||
|         } else { | ||||
|             $compiler->variable_filters = array(); | ||||
|         } | ||||
|         // this tag does not return compiled code | ||||
|         $compiler->has_code = false; | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,49 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Shared Inheritance | ||||
|  * Shared methods for {extends} and {block} tags | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Smarty Internal Plugin Compile Shared Inheritance Class | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  */ | ||||
| class Smarty_Internal_Compile_Shared_Inheritance extends Smarty_Internal_CompileBase | ||||
| { | ||||
|     /** | ||||
|      * Compile inheritance initialization code as prefix | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param bool|false                            $initChildSequence if true force child template | ||||
|      */ | ||||
|     public static function postCompile(Smarty_Internal_TemplateCompilerBase $compiler, $initChildSequence = false) | ||||
|     { | ||||
|         $compiler->prefixCompiledCode .= "<?php \$_smarty_tpl->_loadInheritance();\n\$_smarty_tpl->inheritance->init(\$_smarty_tpl, " . | ||||
|                                          var_export($initChildSequence, true) . ");\n?>\n"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register post compile callback to compile inheritance initialization code | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateCompilerBase $compiler | ||||
|      * @param bool|false                            $initChildSequence if true force child template | ||||
|      */ | ||||
|     public function registerInit(Smarty_Internal_TemplateCompilerBase $compiler, $initChildSequence = false) | ||||
|     { | ||||
|         if ($initChildSequence || !isset($compiler->_cache[ 'inheritanceInit' ])) { | ||||
|             $compiler->registerPostCompileCallback( | ||||
|                 array('Smarty_Internal_Compile_Shared_Inheritance', 'postCompile'), | ||||
|                 array($initChildSequence), | ||||
|                 'inheritanceInit', | ||||
|                 $initChildSequence | ||||
|             ); | ||||
|             $compiler->_cache[ 'inheritanceInit' ] = true; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										100
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_while.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compile_while.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| <?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 \Smarty_Internal_TemplateCompilerBase $compiler  compiler object | ||||
|      * @param array                                 $parameter array with compilation parameter | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      * @throws \SmartyCompilerException | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler, $parameter) | ||||
|     { | ||||
|         $compiler->loopNesting++; | ||||
|         // 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', null, true); | ||||
|         } | ||||
|         // maybe nocache because of nocache variables | ||||
|         $compiler->nocache = $compiler->nocache | $compiler->tag_nocache; | ||||
|         if (is_array($parameter[ 'if condition' ])) { | ||||
|             if ($compiler->nocache) { | ||||
|                 // create nocache var to make it know for further compiling | ||||
|                 if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                     $var = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|                 } else { | ||||
|                     $var = $parameter[ 'if condition' ][ 'var' ]; | ||||
|                 } | ||||
|                 $compiler->setNocacheInVariable($var); | ||||
|             } | ||||
|             $prefixVar = $compiler->getNewPrefixVariable(); | ||||
|             $assignCompiler = new Smarty_Internal_Compile_Assign(); | ||||
|             $assignAttr = array(); | ||||
|             $assignAttr[][ 'value' ] = $prefixVar; | ||||
|             if (is_array($parameter[ 'if condition' ][ 'var' ])) { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ][ 'var' ]; | ||||
|                 $_output = "<?php while ({$prefixVar} = {$parameter[ 'if condition' ][ 'value' ]}) {?>"; | ||||
|                 $_output .= $assignCompiler->compile( | ||||
|                     $assignAttr, | ||||
|                     $compiler, | ||||
|                     array('smarty_internal_index' => $parameter[ 'if condition' ][ 'var' ][ 'smarty_internal_index' ]) | ||||
|                 ); | ||||
|             } else { | ||||
|                 $assignAttr[][ 'var' ] = $parameter[ 'if condition' ][ 'var' ]; | ||||
|                 $_output = "<?php while ({$prefixVar} = {$parameter[ 'if condition' ][ 'value' ]}) {?>"; | ||||
|                 $_output .= $assignCompiler->compile($assignAttr, $compiler, array()); | ||||
|             } | ||||
|             return $_output; | ||||
|         } else { | ||||
|             return "<?php\n 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 \Smarty_Internal_TemplateCompilerBase $compiler compiler object | ||||
|      * | ||||
|      * @return string compiled code | ||||
|      */ | ||||
|     public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler) | ||||
|     { | ||||
|         $compiler->loopNesting--; | ||||
|         // must endblock be nocache? | ||||
|         if ($compiler->nocache) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         $compiler->nocache = $this->closeTag($compiler, array('while')); | ||||
|         return "<?php }?>\n"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										203
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										203
									
								
								lib/smarty/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,203 @@ | ||||
| <?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'); | ||||
|  | ||||
|     /** | ||||
|      * Mapping array for boolean option value | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $optionMap = array(1 => true, 0 => false, 'true' => true, 'false' => false); | ||||
|  | ||||
|     /** | ||||
|      * Mapping array with attributes as key | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $mapCache = array(); | ||||
|  | ||||
|     /** | ||||
|      * 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(); | ||||
|         if (!isset($this->mapCache[ 'option' ])) { | ||||
|             $this->mapCache[ 'option' ] = array_fill_keys($this->option_flags, true); | ||||
|         } | ||||
|         foreach ($attributes as $key => $mixed) { | ||||
|             // shorthand ? | ||||
|             if (!is_array($mixed)) { | ||||
|                 // option flag ? | ||||
|                 if (isset($this->mapCache[ 'option' ][ trim($mixed, '\'"') ])) { | ||||
|                     $_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', null, true); | ||||
|                 } | ||||
|                 // named attribute | ||||
|             } else { | ||||
|                 foreach ($mixed as $k => $v) { | ||||
|                     // option flag? | ||||
|                     if (isset($this->mapCache[ 'option' ][ $k ])) { | ||||
|                         if (is_bool($v)) { | ||||
|                             $_indexed_attr[ $k ] = $v; | ||||
|                         } else { | ||||
|                             if (is_string($v)) { | ||||
|                                 $v = trim($v, '\'" '); | ||||
|                             } | ||||
|                             if (isset($this->optionMap[ $v ])) { | ||||
|                                 $_indexed_attr[ $k ] = $this->optionMap[ $v ]; | ||||
|                             } else { | ||||
|                                 $compiler->trigger_template_error( | ||||
|                                     "illegal value '" . var_export($v, true) . | ||||
|                                     "' for option flag '{$k}'", | ||||
|                                     null, | ||||
|                                     true | ||||
|                                 ); | ||||
|                             } | ||||
|                         } | ||||
|                         // must be named attribute | ||||
|                     } else { | ||||
|                         $_indexed_attr[ $k ] = $v; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // check if all required attributes present | ||||
|         foreach ($this->required_attributes as $attr) { | ||||
|             if (!isset($_indexed_attr[ $attr ])) { | ||||
|                 $compiler->trigger_template_error("missing '{$attr}' attribute", null, true); | ||||
|             } | ||||
|         } | ||||
|         // check for not allowed attributes | ||||
|         if ($this->optional_attributes !== array('_any')) { | ||||
|             if (!isset($this->mapCache[ 'all' ])) { | ||||
|                 $this->mapCache[ 'all' ] = | ||||
|                     array_fill_keys( | ||||
|                         array_merge( | ||||
|                             $this->required_attributes, | ||||
|                             $this->optional_attributes, | ||||
|                             $this->option_flags | ||||
|                         ), | ||||
|                         true | ||||
|                     ); | ||||
|             } | ||||
|             foreach ($_indexed_attr as $key => $dummy) { | ||||
|                 if (!isset($this->mapCache[ 'all' ][ $key ]) && $key !== 0) { | ||||
|                     $compiler->trigger_template_error("unexpected '{$key}' attribute", null, true); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // default 'false' for all option flags not set | ||||
|         foreach ($this->option_flags as $flag) { | ||||
|             if (!isset($_indexed_attr[ $flag ])) { | ||||
|                 $_indexed_attr[ $flag ] = false; | ||||
|             } | ||||
|         } | ||||
|         if (isset($_indexed_attr[ 'nocache' ]) && $_indexed_attr[ 'nocache' ]) { | ||||
|             $compiler->tag_nocache = true; | ||||
|         } | ||||
|         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', null, true); | ||||
|         return; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,209 @@ | ||||
| <?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 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 Smarty object | ||||
|      */ | ||||
|     public $smarty; | ||||
|  | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var Smarty_Internal_Template object | ||||
|      */ | ||||
|     public $template; | ||||
|  | ||||
|     /** | ||||
|      * Compiled config data sections and variables | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $config_data = array(); | ||||
|  | ||||
|     /** | ||||
|      * compiled config data must always be written | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     public $write_compiled_code = true; | ||||
|  | ||||
|     /** | ||||
|      * 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 $smarty) | ||||
|     { | ||||
|         $this->smarty = $smarty; | ||||
|         // get required plugins | ||||
|         $this->lexer_class = $lexer_class; | ||||
|         $this->parser_class = $parser_class; | ||||
|         $this->smarty = $smarty; | ||||
|         $this->config_data[ 'sections' ] = array(); | ||||
|         $this->config_data[ 'vars' ] = array(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Method to compile Smarty config source. | ||||
|      * | ||||
|      * @param Smarty_Internal_Template $template | ||||
|      * | ||||
|      * @return bool true if compiling succeeded, false if it failed | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function compileTemplate(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $this->template = $template; | ||||
|         $this->template->compiled->file_dependency[ $this->template->source->uid ] = | ||||
|             array( | ||||
|                 $this->template->source->filepath, | ||||
|                 $this->template->source->getTimeStamp(), | ||||
|                 $this->template->source->type | ||||
|             ); | ||||
|         if ($this->smarty->debugging) { | ||||
|             if (!isset($this->smarty->_debug)) { | ||||
|                 $this->smarty->_debug = new Smarty_Internal_Debug(); | ||||
|             } | ||||
|             $this->smarty->_debug->start_compile($this->template); | ||||
|         } | ||||
|         // init the lexer/parser to compile the config file | ||||
|         /* @var Smarty_Internal_ConfigFileLexer $this->lex */ | ||||
|         $this->lex = new $this->lexer_class( | ||||
|             str_replace( | ||||
|                 array( | ||||
|                     "\r\n", | ||||
|                     "\r" | ||||
|                 ), | ||||
|                 "\n", | ||||
|                 $template->source->getContent() | ||||
|             ) . "\n", | ||||
|             $this | ||||
|         ); | ||||
|         /* @var Smarty_Internal_ConfigFileParser $this->parser */ | ||||
|         $this->parser = new $this->parser_class($this->lex, $this); | ||||
|         if (function_exists('mb_internal_encoding') | ||||
|             && function_exists('ini_get') | ||||
|             && ((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(); | ||||
|         } | ||||
|         // get tokens from lexer and parse them | ||||
|         while ($this->lex->yylex()) { | ||||
|             if ($this->smarty->_parserdebug) { | ||||
|                 echo "<br>Parsing  {$this->parser->yyTokenName[$this->lex->token]} Token {$this->lex->value} Line {$this->lex->line} \n"; | ||||
|             } | ||||
|             $this->parser->doParse($this->lex->token, $this->lex->value); | ||||
|         } | ||||
|         // finish parsing process | ||||
|         $this->parser->doParse(0, 0); | ||||
|         if ($mbEncoding) { | ||||
|             mb_internal_encoding($mbEncoding); | ||||
|         } | ||||
|         if ($this->smarty->debugging) { | ||||
|             $this->smarty->_debug->end_compile($this->template); | ||||
|         } | ||||
|         // template header code | ||||
|         $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"; | ||||
|         $code = '<?php $_smarty_tpl->smarty->ext->configLoad->_loadConfigVars($_smarty_tpl, ' . | ||||
|                 var_export($this->config_data, true) . '); ?>'; | ||||
|         return $template_header . $this->template->smarty->ext->_codeFrame->create($this->template, $code); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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) | ||||
|     { | ||||
|         // get config 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->template->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); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										739
									
								
								lib/smarty/libs/sysplugins/smarty_internal_configfilelexer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										739
									
								
								lib/smarty/libs/sysplugins/smarty_internal_configfilelexer.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,739 @@ | ||||
| <?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_Configfilelexer | ||||
|  * | ||||
|  * This is the config file lexer. | ||||
|  * It is generated from the smarty_internal_configfilelexer.plex file | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage Compiler | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Configfilelexer | ||||
| { | ||||
|     const START              = 1; | ||||
|     const VALUE              = 2; | ||||
|     const NAKED_STRING_VALUE = 3; | ||||
|     const COMMENT            = 4; | ||||
|     const SECTION            = 5; | ||||
|     const TRIPPLE            = 6; | ||||
|  | ||||
|     /** | ||||
|      * Source | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $data; | ||||
|  | ||||
|     /** | ||||
|      * Source length | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $dataLength = null; | ||||
|  | ||||
|     /** | ||||
|      * byte counter | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $counter; | ||||
|  | ||||
|     /** | ||||
|      * token number | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $token; | ||||
|  | ||||
|     /** | ||||
|      * token value | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $value; | ||||
|  | ||||
|     /** | ||||
|      * current line | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $line; | ||||
|  | ||||
|     /** | ||||
|      * state number | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $state = 1; | ||||
|  | ||||
|     /** | ||||
|      * Smarty object | ||||
|      * | ||||
|      * @var Smarty | ||||
|      */ | ||||
|     public $smarty = null; | ||||
|  | ||||
|     /** | ||||
|      * trace file | ||||
|      * | ||||
|      * @var resource | ||||
|      */ | ||||
|     public $yyTraceFILE; | ||||
|  | ||||
|     /** | ||||
|      * trace prompt | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $yyTracePrompt; | ||||
|  | ||||
|     /** | ||||
|      * state names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $state_name = array( | ||||
|         1 => 'START', 2 => 'VALUE', 3 => 'NAKED_STRING_VALUE', 4 => 'COMMENT', 5 => 'SECTION', 6 => 'TRIPPLE' | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * token names | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $smarty_token_names = array(        // Text for parser error messages | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * compiler object | ||||
|      * | ||||
|      * @var Smarty_Internal_Config_File_Compiler | ||||
|      */ | ||||
|     private $compiler = null; | ||||
|  | ||||
|     /** | ||||
|      * copy of config_booleanize | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $configBooleanize = false; | ||||
|  | ||||
|     /** | ||||
|      * storage for assembled token patterns | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $yy_global_pattern1 = null; | ||||
|  | ||||
|     private $yy_global_pattern2 = null; | ||||
|  | ||||
|     private $yy_global_pattern3 = null; | ||||
|  | ||||
|     private $yy_global_pattern4 = null; | ||||
|  | ||||
|     private $yy_global_pattern5 = null; | ||||
|  | ||||
|     private $yy_global_pattern6 = null; | ||||
|  | ||||
|     private $_yy_state          = 1; | ||||
|  | ||||
|     private $_yy_stack          = array(); | ||||
|  | ||||
|     /** | ||||
|      * constructor | ||||
|      * | ||||
|      * @param   string                             $data template source | ||||
|      * @param Smarty_Internal_Config_File_Compiler $compiler | ||||
|      */ | ||||
|     public function __construct($data, Smarty_Internal_Config_File_Compiler $compiler) | ||||
|     { | ||||
|         $this->data = $data . "\n"; //now all lines are \n-terminated | ||||
|         $this->dataLength = strlen($data); | ||||
|         $this->counter = 0; | ||||
|         if (preg_match('/^\xEF\xBB\xBF/', $this->data, $match)) { | ||||
|             $this->counter += strlen($match[ 0 ]); | ||||
|         } | ||||
|         $this->line = 1; | ||||
|         $this->compiler = $compiler; | ||||
|         $this->smarty = $compiler->smarty; | ||||
|         $this->configBooleanize = $this->smarty->config_booleanize; | ||||
|     } | ||||
|  | ||||
|     public function replace($input) | ||||
|     { | ||||
|         return $input; | ||||
|     } // end function | ||||
|  | ||||
|     public function PrintTrace() | ||||
|     { | ||||
|         $this->yyTraceFILE = fopen('php://output', 'w'); | ||||
|         $this->yyTracePrompt = '<br>'; | ||||
|     } | ||||
|  | ||||
|     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() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern1)) { | ||||
|             $this->yy_global_pattern1 = | ||||
|                 $this->replace("/\G(#|;)|\G(\\[)|\G(\\])|\G(=)|\G([ \t\r]+)|\G(\n)|\G([0-9]*[a-zA-Z_]\\w*)|\G([\S\s])/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern1, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r1_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_1() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_COMMENTSTART; | ||||
|         $this->yypushstate(self::COMMENT); | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_2() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_OPENB; | ||||
|         $this->yypushstate(self::SECTION); | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_3() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_CLOSEB; | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_4() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_EQUAL; | ||||
|         $this->yypushstate(self::VALUE); | ||||
|     } // end function | ||||
|  | ||||
|     public function yy_r1_5() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_6() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE; | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_7() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_ID; | ||||
|     } | ||||
|  | ||||
|     public function yy_r1_8() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_OTHER; | ||||
|     } | ||||
|  | ||||
|     public function yylex2() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern2)) { | ||||
|             $this->yy_global_pattern2 = | ||||
|                 $this->replace("/\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)/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern2, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r2_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_1() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_2() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_FLOAT; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_3() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_INT; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_4() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_QUOTES; | ||||
|         $this->yypushstate(self::TRIPPLE); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_5() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_SINGLE_QUOTED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_6() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_DOUBLE_QUOTED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } // end function | ||||
|  | ||||
|     public function yy_r2_7() | ||||
|     { | ||||
|         if (!$this->configBooleanize || | ||||
|             !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(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_8() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yy_r2_9() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->value = ''; | ||||
|         $this->yypopstate(); | ||||
|     } // end function | ||||
|  | ||||
|     public function yylex3() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern3)) { | ||||
|             $this->yy_global_pattern3 = $this->replace("/\G([^\n]+?(?=[ \t\r]*\n))/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern3, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r3_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r3_1() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex4() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern4)) { | ||||
|             $this->yy_global_pattern4 = $this->replace("/\G([ \t\r]+)|\G([^\n]+?(?=[ \t\r]*\n))|\G(\n)/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern4, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r4_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r4_1() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     public function yy_r4_2() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING; | ||||
|     } // end function | ||||
|  | ||||
|     public function yy_r4_3() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE; | ||||
|         $this->yypopstate(); | ||||
|     } | ||||
|  | ||||
|     public function yylex5() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern5)) { | ||||
|             $this->yy_global_pattern5 = $this->replace("/\G(\\.)|\G(.*?(?=[\.=[\]\r\n]))/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern5, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r5_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r5_1() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_DOT; | ||||
|     } | ||||
|  | ||||
|     public function yy_r5_2() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_SECTION; | ||||
|         $this->yypopstate(); | ||||
|     } // end function | ||||
|  | ||||
|     public function yylex6() | ||||
|     { | ||||
|         if (!isset($this->yy_global_pattern6)) { | ||||
|             $this->yy_global_pattern6 = $this->replace("/\G(\"\"\"(?=[ \t\r]*[\n#;]))|\G([\S\s])/isS"); | ||||
|         } | ||||
|         if (!isset($this->dataLength)) { | ||||
|             $this->dataLength = strlen($this->data); | ||||
|         } | ||||
|         if ($this->counter >= $this->dataLength) { | ||||
|             return false; // end of input | ||||
|         } | ||||
|         do { | ||||
|             if (preg_match($this->yy_global_pattern6, $this->data, $yymatches, 0, $this->counter)) { | ||||
|                 if (!isset($yymatches[ 0 ][ 1 ])) { | ||||
|                     $yymatches = preg_grep("/(.|\s)+/", $yymatches); | ||||
|                 } else { | ||||
|                     $yymatches = array_filter($yymatches); | ||||
|                 } | ||||
|                 if (empty($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 | ||||
|                 $this->value = current($yymatches); // token value | ||||
|                 $r = $this->{'yy_r6_' . $this->token}(); | ||||
|                 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 >= $this->dataLength) { | ||||
|                         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); | ||||
|     } | ||||
|  | ||||
|     public function yy_r6_1() | ||||
|     { | ||||
|         $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_QUOTES_END; | ||||
|         $this->yypopstate(); | ||||
|         $this->yypushstate(self::START); | ||||
|     } | ||||
|  | ||||
|     public function yy_r6_2() | ||||
|     { | ||||
|         $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_config_file_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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1046
									
								
								lib/smarty/libs/sysplugins/smarty_internal_configfileparser.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1046
									
								
								lib/smarty/libs/sysplugins/smarty_internal_configfileparser.php
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										292
									
								
								lib/smarty/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										292
									
								
								lib/smarty/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,292 @@ | ||||
| <?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 | ||||
|  * | ||||
|  * @property int    $scope | ||||
|  * @property Smarty $smarty | ||||
|  * The following methods will be dynamically loaded by the extension handler when they are called. | ||||
|  * They are located in a corresponding Smarty_Internal_Method_xxxx class | ||||
|  * | ||||
|  * @method mixed _getConfigVariable(string $varName, bool $errorEnable = true) | ||||
|  * @method mixed getConfigVariable(string $varName, bool $errorEnable = true) | ||||
|  * @method mixed getConfigVars(string $varName = null, bool $searchParents = true) | ||||
|  * @method mixed getGlobal(string $varName = null) | ||||
|  * @method mixed getStreamVariable(string $variable) | ||||
|  * @method Smarty_Internal_Data clearAssign(mixed $tpl_var) | ||||
|  * @method Smarty_Internal_Data clearAllAssign() | ||||
|  * @method Smarty_Internal_Data clearConfig(string $varName = null) | ||||
|  * @method Smarty_Internal_Data configLoad(string $config_file, mixed $sections = null, string $scope = 'local') | ||||
|  */ | ||||
| abstract class Smarty_Internal_Data | ||||
| { | ||||
|     /** | ||||
|      * This object type (Smarty = 1, template = 2, data = 4) | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $_objType = 4; | ||||
|  | ||||
|     /** | ||||
|      * name of class used for templates | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $template_class = 'Smarty_Internal_Template'; | ||||
|  | ||||
|     /** | ||||
|      * template variables | ||||
|      * | ||||
|      * @var Smarty_Variable[] | ||||
|      */ | ||||
|     public $tpl_vars = array(); | ||||
|  | ||||
|     /** | ||||
|      * parent template (if any) | ||||
|      * | ||||
|      * @var Smarty|Smarty_Internal_Template|Smarty_Data | ||||
|      */ | ||||
|     public $parent = null; | ||||
|  | ||||
|     /** | ||||
|      * configuration settings | ||||
|      * | ||||
|      * @var string[] | ||||
|      */ | ||||
|     public $config_vars = array(); | ||||
|  | ||||
|     /** | ||||
|      * extension handler | ||||
|      * | ||||
|      * @var Smarty_Internal_Extension_Handler | ||||
|      */ | ||||
|     public $ext = null; | ||||
|  | ||||
|     /** | ||||
|      * Smarty_Internal_Data constructor. | ||||
|      * | ||||
|      * Install extension handler | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         $this->ext = new Smarty_Internal_Extension_Handler(); | ||||
|         $this->ext->objType = $this->_objType; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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) { | ||||
|                 $this->assign($_key, $_val, $nocache); | ||||
|             } | ||||
|         } else { | ||||
|             if ($tpl_var !== '') { | ||||
|                 if ($this->_objType === 2) { | ||||
|                     /** | ||||
|                      * | ||||
|                      * | ||||
|                      * @var Smarty_Internal_Template $this | ||||
|                      */ | ||||
|                     $this->_assignInScope($tpl_var, $value, $nocache); | ||||
|                 } else { | ||||
|                     $this->tpl_vars[ $tpl_var ] = new Smarty_Variable($value, $nocache); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * appends values to template variables | ||||
|      * | ||||
|      * @api  Smarty::append() | ||||
|      * @link http://www.smarty.net/docs/en/api.append.tpl | ||||
|      * | ||||
|      * @param array|string $tpl_var the template variable name(s) | ||||
|      * @param mixed        $value   the value to append | ||||
|      * @param bool         $merge   flag if array elements shall be merged | ||||
|      * @param bool         $nocache if true any output of this variable will | ||||
|      *                              be not cached | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function append($tpl_var, $value = null, $merge = false, $nocache = false) | ||||
|     { | ||||
|         return $this->ext->append->append($this, $tpl_var, $value, $merge, $nocache); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function assignGlobal($varName, $value = null, $nocache = false) | ||||
|     { | ||||
|         return $this->ext->assignGlobal->assignGlobal($this, $varName, $value, $nocache); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function appendByRef($tpl_var, &$value, $merge = false) | ||||
|     { | ||||
|         return $this->ext->appendByRef->appendByRef($this, $tpl_var, $value, $merge); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function assignByRef($tpl_var, &$value, $nocache = false) | ||||
|     { | ||||
|         return $this->ext->assignByRef->assignByRef($this, $tpl_var, $value, $nocache); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all template variables | ||||
|      * | ||||
|      * @api  Smarty::getTemplateVars() | ||||
|      * @link http://www.smarty.net/docs/en/api.get.template.vars.tpl | ||||
|      * | ||||
|      * @param string                                                  $varName       variable name or null | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $_ptr          optional pointer to data object | ||||
|      * @param bool                                                    $searchParents include parent templates? | ||||
|      * | ||||
|      * @return mixed variable value or or array of variables | ||||
|      */ | ||||
|     public function getTemplateVars($varName = null, Smarty_Internal_Data $_ptr = null, $searchParents = true) | ||||
|     { | ||||
|         return $this->ext->getTemplateVars->getTemplateVars($this, $varName, $_ptr, $searchParents); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets the object of a Smarty variable | ||||
|      * | ||||
|      * @param string               $variable      the name of the Smarty variable | ||||
|      * @param Smarty_Internal_Data $_ptr          optional pointer to data object | ||||
|      * @param boolean              $searchParents search also in parent data | ||||
|      * @param bool                 $error_enable | ||||
|      * | ||||
|      * @return     Smarty_Variable|Smarty_Undefined_Variable the object of the variable | ||||
|      * @deprecated since 3.1.28 please use Smarty_Internal_Data::getTemplateVars() instead. | ||||
|      */ | ||||
|     public function getVariable( | ||||
|         $variable = null, | ||||
|         Smarty_Internal_Data $_ptr = null, | ||||
|         $searchParents = true, | ||||
|         $error_enable = true | ||||
|     ) { | ||||
|         return $this->ext->getTemplateVars->_getVariable($this, $variable, $_ptr, $searchParents, $error_enable); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Follow the parent chain an merge template and config variables | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|null $data | ||||
|      */ | ||||
|     public function _mergeVars(Smarty_Internal_Data $data = null) | ||||
|     { | ||||
|         if (isset($data)) { | ||||
|             if (!empty($this->tpl_vars)) { | ||||
|                 $data->tpl_vars = array_merge($this->tpl_vars, $data->tpl_vars); | ||||
|             } | ||||
|             if (!empty($this->config_vars)) { | ||||
|                 $data->config_vars = array_merge($this->config_vars, $data->config_vars); | ||||
|             } | ||||
|         } else { | ||||
|             $data = $this; | ||||
|         } | ||||
|         if (isset($this->parent)) { | ||||
|             $this->parent->_mergeVars($data); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return true if this instance is a Data obj | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function _isDataObj() | ||||
|     { | ||||
|         return $this->_objType === 4; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return true if this instance is a template obj | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function _isTplObj() | ||||
|     { | ||||
|         return $this->_objType === 2; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return true if this instance is a Smarty obj | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function _isSmartyObj() | ||||
|     { | ||||
|         return $this->_objType === 1; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Smarty object | ||||
|      * | ||||
|      * @return Smarty | ||||
|      */ | ||||
|     public function _getSmartyObj() | ||||
|     { | ||||
|         return $this->smarty; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Handle unknown class methods | ||||
|      * | ||||
|      * @param string $name unknown method-name | ||||
|      * @param array  $args argument array | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function __call($name, $args) | ||||
|     { | ||||
|         return $this->ext->_callExternalMethod($this, $name, $args); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										425
									
								
								lib/smarty/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								lib/smarty/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,425 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Smarty Internal Plugin Debug | ||||
|  * Class to collect data for the Smarty Debugging Console | ||||
|  * | ||||
|  * @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 $template_data = array(); | ||||
|  | ||||
|     /** | ||||
|      * List of uid's which shall be ignored | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $ignore_uid = array(); | ||||
|  | ||||
|     /** | ||||
|      * Index of display() and fetch() calls | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $index = 0; | ||||
|  | ||||
|     /** | ||||
|      * Counter for window offset | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $offset = 0; | ||||
|  | ||||
|     /** | ||||
|      * Start logging template | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template template | ||||
|      * @param null                      $mode     true: display   false: fetch  null: subtemplate | ||||
|      */ | ||||
|     public function start_template(Smarty_Internal_Template $template, $mode = null) | ||||
|     { | ||||
|         if (isset($mode) && !$template->_isSubTpl()) { | ||||
|             $this->index++; | ||||
|             $this->offset++; | ||||
|             $this->template_data[ $this->index ] = null; | ||||
|         } | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'start_template_time' ] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of cache time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template cached template | ||||
|      */ | ||||
|     public function end_template(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'total_time' ] += | ||||
|             microtime(true) - $this->template_data[ $this->index ][ $key ][ 'start_template_time' ]; | ||||
|         //$this->template_data[$this->index][$key]['properties'] = $template->properties; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of compile time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      */ | ||||
|     public function start_compile(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         static $_is_stringy = array('string' => true, 'eval' => true); | ||||
|         if (!empty($template->compiler->trace_uid)) { | ||||
|             $key = $template->compiler->trace_uid; | ||||
|             if (!isset($this->template_data[ $this->index ][ $key ])) { | ||||
|                 if (isset($_is_stringy[ $template->source->type ])) { | ||||
|                     $this->template_data[ $this->index ][ $key ][ 'name' ] = | ||||
|                         '\'' . substr($template->source->name, 0, 25) . '...\''; | ||||
|                 } else { | ||||
|                     $this->template_data[ $this->index ][ $key ][ 'name' ] = $template->source->filepath; | ||||
|                 } | ||||
|                 $this->template_data[ $this->index ][ $key ][ 'compile_time' ] = 0; | ||||
|                 $this->template_data[ $this->index ][ $key ][ 'render_time' ] = 0; | ||||
|                 $this->template_data[ $this->index ][ $key ][ 'cache_time' ] = 0; | ||||
|             } | ||||
|         } else { | ||||
|             if (isset($this->ignore_uid[ $template->source->uid ])) { | ||||
|                 return; | ||||
|             } | ||||
|             $key = $this->get_key($template); | ||||
|         } | ||||
|         $this->template_data[ $this->index ][ $key ][ 'start_time' ] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of compile time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      */ | ||||
|     public function end_compile(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         if (!empty($template->compiler->trace_uid)) { | ||||
|             $key = $template->compiler->trace_uid; | ||||
|         } else { | ||||
|             if (isset($this->ignore_uid[ $template->source->uid ])) { | ||||
|                 return; | ||||
|             } | ||||
|             $key = $this->get_key($template); | ||||
|         } | ||||
|         $this->template_data[ $this->index ][ $key ][ 'compile_time' ] += | ||||
|             microtime(true) - $this->template_data[ $this->index ][ $key ][ 'start_time' ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of render time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      */ | ||||
|     public function start_render(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'start_time' ] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of compile time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      */ | ||||
|     public function end_render(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'render_time' ] += | ||||
|             microtime(true) - $this->template_data[ $this->index ][ $key ][ 'start_time' ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start logging of cache time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template cached template | ||||
|      */ | ||||
|     public function start_cache(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'start_time' ] = microtime(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * End logging of cache time | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template cached template | ||||
|      */ | ||||
|     public function end_cache(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         $key = $this->get_key($template); | ||||
|         $this->template_data[ $this->index ][ $key ][ 'cache_time' ] += | ||||
|             microtime(true) - $this->template_data[ $this->index ][ $key ][ 'start_time' ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register template object | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template cached template | ||||
|      */ | ||||
|     public function register_template(Smarty_Internal_Template $template) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register data object | ||||
|      * | ||||
|      * @param \Smarty_Data $data data object | ||||
|      */ | ||||
|     public static function register_data(Smarty_Data $data) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Opens a window for the Smarty Debugging Console and display the data | ||||
|      * | ||||
|      * @param Smarty_Internal_Template|Smarty $obj object to debug | ||||
|      * @param bool                            $full | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function display_debug($obj, $full = false) | ||||
|     { | ||||
|         if (!$full) { | ||||
|             $this->offset++; | ||||
|             $savedIndex = $this->index; | ||||
|             $this->index = 9999; | ||||
|         } | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         // create fresh instance of smarty for displaying the debug console | ||||
|         // to avoid problems if the application did overload the Smarty class | ||||
|         $debObj = new Smarty(); | ||||
|         // copy the working dirs from application | ||||
|         $debObj->setCompileDir($smarty->getCompileDir()); | ||||
|         // init properties by hand as user may have edited the original Smarty class | ||||
|         $debObj->setPluginsDir(is_dir(dirname(__FILE__) . '/../plugins') ? dirname(__FILE__) . | ||||
|                                                                            '/../plugins' : $smarty->getPluginsDir()); | ||||
|         $debObj->force_compile = false; | ||||
|         $debObj->compile_check = Smarty::COMPILECHECK_ON; | ||||
|         $debObj->left_delimiter = '{'; | ||||
|         $debObj->right_delimiter = '}'; | ||||
|         $debObj->security_policy = null; | ||||
|         $debObj->debugging = false; | ||||
|         $debObj->debugging_ctrl = 'NONE'; | ||||
|         $debObj->error_reporting = E_ALL & ~E_NOTICE; | ||||
|         $debObj->debug_tpl = | ||||
|             isset($smarty->debug_tpl) ? $smarty->debug_tpl : 'file:' . dirname(__FILE__) . '/../debug.tpl'; | ||||
|         $debObj->registered_plugins = array(); | ||||
|         $debObj->registered_resources = array(); | ||||
|         $debObj->registered_filters = array(); | ||||
|         $debObj->autoload_filters = array(); | ||||
|         $debObj->default_modifiers = array(); | ||||
|         $debObj->escape_html = true; | ||||
|         $debObj->caching = Smarty::CACHING_OFF; | ||||
|         $debObj->compile_id = null; | ||||
|         $debObj->cache_id = null; | ||||
|         // prepare information of assigned variables | ||||
|         $ptr = $this->get_debug_vars($obj); | ||||
|         $_assigned_vars = $ptr->tpl_vars; | ||||
|         ksort($_assigned_vars); | ||||
|         $_config_vars = $ptr->config_vars; | ||||
|         ksort($_config_vars); | ||||
|         $debugging = $smarty->debugging; | ||||
|         $_template = new Smarty_Internal_Template($debObj->debug_tpl, $debObj); | ||||
|         if ($obj->_isTplObj()) { | ||||
|             $_template->assign('template_name', $obj->source->type . ':' . $obj->source->name); | ||||
|         } | ||||
|         if ($obj->_objType === 1 || $full) { | ||||
|             $_template->assign('template_data', $this->template_data[ $this->index ]); | ||||
|         } 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); | ||||
|         $_template->assign('display_mode', $debugging === 2 || !$full); | ||||
|         $_template->assign('offset', $this->offset * 50); | ||||
|         echo $_template->fetch(); | ||||
|         if (isset($full)) { | ||||
|             $this->index--; | ||||
|         } | ||||
|         if (!$full) { | ||||
|             $this->index = $savedIndex; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Recursively gets variables from all template/data scopes | ||||
|      * | ||||
|      * @param Smarty_Internal_Template|Smarty_Data $obj object to debug | ||||
|      * | ||||
|      * @return StdClass | ||||
|      */ | ||||
|     public function get_debug_vars($obj) | ||||
|     { | ||||
|         $config_vars = array(); | ||||
|         foreach ($obj->config_vars as $key => $var) { | ||||
|             $config_vars[ $key ][ 'value' ] = $var; | ||||
|             if ($obj->_isTplObj()) { | ||||
|                 $config_vars[ $key ][ 'scope' ] = $obj->source->type . ':' . $obj->source->name; | ||||
|             } elseif ($obj->_isDataObj()) { | ||||
|                 $tpl_vars[ $key ][ 'scope' ] = $obj->dataObjectName; | ||||
|             } else { | ||||
|                 $config_vars[ $key ][ 'scope' ] = 'Smarty object'; | ||||
|             } | ||||
|         } | ||||
|         $tpl_vars = array(); | ||||
|         foreach ($obj->tpl_vars as $key => $var) { | ||||
|             foreach ($var as $varkey => $varvalue) { | ||||
|                 if ($varkey === 'value') { | ||||
|                     $tpl_vars[ $key ][ $varkey ] = $varvalue; | ||||
|                 } else { | ||||
|                     if ($varkey === 'nocache') { | ||||
|                         if ($varvalue === true) { | ||||
|                             $tpl_vars[ $key ][ $varkey ] = $varvalue; | ||||
|                         } | ||||
|                     } else { | ||||
|                         if ($varkey !== 'scope' || $varvalue !== 0) { | ||||
|                             $tpl_vars[ $key ][ 'attributes' ][ $varkey ] = $varvalue; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if ($obj->_isTplObj()) { | ||||
|                 $tpl_vars[ $key ][ 'scope' ] = $obj->source->type . ':' . $obj->source->name; | ||||
|             } elseif ($obj->_isDataObj()) { | ||||
|                 $tpl_vars[ $key ][ 'scope' ] = $obj->dataObjectName; | ||||
|             } else { | ||||
|                 $tpl_vars[ $key ][ 'scope' ] = 'Smarty object'; | ||||
|             } | ||||
|         } | ||||
|         if (isset($obj->parent)) { | ||||
|             $parent = $this->get_debug_vars($obj->parent); | ||||
|             foreach ($parent->tpl_vars as $name => $pvar) { | ||||
|                 if (isset($tpl_vars[ $name ]) && $tpl_vars[ $name ][ 'value' ] === $pvar[ 'value' ]) { | ||||
|                     $tpl_vars[ $name ][ 'scope' ] = $pvar[ 'scope' ]; | ||||
|                 } | ||||
|             } | ||||
|             $tpl_vars = array_merge($parent->tpl_vars, $tpl_vars); | ||||
|             foreach ($parent->config_vars as $name => $pvar) { | ||||
|                 if (isset($config_vars[ $name ]) && $config_vars[ $name ][ 'value' ] === $pvar[ 'value' ]) { | ||||
|                     $config_vars[ $name ][ 'scope' ] = $pvar[ 'scope' ]; | ||||
|                 } | ||||
|             } | ||||
|             $config_vars = array_merge($parent->config_vars, $config_vars); | ||||
|         } else { | ||||
|             foreach (Smarty::$global_tpl_vars as $key => $var) { | ||||
|                 if (!array_key_exists($key, $tpl_vars)) { | ||||
|                     foreach ($var as $varkey => $varvalue) { | ||||
|                         if ($varkey === 'value') { | ||||
|                             $tpl_vars[ $key ][ $varkey ] = $varvalue; | ||||
|                         } else { | ||||
|                             if ($varkey === 'nocache') { | ||||
|                                 if ($varvalue === true) { | ||||
|                                     $tpl_vars[ $key ][ $varkey ] = $varvalue; | ||||
|                                 } | ||||
|                             } else { | ||||
|                                 if ($varkey !== 'scope' || $varvalue !== 0) { | ||||
|                                     $tpl_vars[ $key ][ 'attributes' ][ $varkey ] = $varvalue; | ||||
|                                 } | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     $tpl_vars[ $key ][ 'scope' ] = 'Global'; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return (object)array('tpl_vars' => $tpl_vars, 'config_vars' => $config_vars); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return key into $template_data for template | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template template object | ||||
|      * | ||||
|      * @return string key into $template_data | ||||
|      */ | ||||
|     private function get_key(Smarty_Internal_Template $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($this->template_data[ $this->index ][ $key ])) { | ||||
|             return $key; | ||||
|         } else { | ||||
|             if (isset($_is_stringy[ $template->source->type ])) { | ||||
|                 $this->template_data[ $this->index ][ $key ][ 'name' ] = | ||||
|                     '\'' . substr($template->source->name, 0, 25) . '...\''; | ||||
|             } else { | ||||
|                 $this->template_data[ $this->index ][ $key ][ 'name' ] = $template->source->filepath; | ||||
|             } | ||||
|             $this->template_data[ $this->index ][ $key ][ 'compile_time' ] = 0; | ||||
|             $this->template_data[ $this->index ][ $key ][ 'render_time' ] = 0; | ||||
|             $this->template_data[ $this->index ][ $key ][ 'cache_time' ] = 0; | ||||
|             $this->template_data[ $this->index ][ $key ][ 'total_time' ] = 0; | ||||
|             return $key; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Ignore template | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $template | ||||
|      */ | ||||
|     public function ignore(Smarty_Internal_Template $template) | ||||
|     { | ||||
|         // calculate Uid if not already done | ||||
|         if ($template->source->uid === '') { | ||||
|             $template->source->filepath; | ||||
|         } | ||||
|         $this->ignore_uid[ $template->source->uid ] = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * handle 'URL' debugging mode | ||||
|      * | ||||
|      * @param Smarty $smarty | ||||
|      */ | ||||
|     public function debugUrl(Smarty $smarty) | ||||
|     { | ||||
|         if (isset($_SERVER[ 'QUERY_STRING' ])) { | ||||
|             $_query_string = $_SERVER[ 'QUERY_STRING' ]; | ||||
|         } else { | ||||
|             $_query_string = ''; | ||||
|         } | ||||
|         if (false !== strpos($_query_string, $smarty->smarty_debug_id)) { | ||||
|             if (false !== strpos($_query_string, $smarty->smarty_debug_id . '=on')) { | ||||
|                 // enable debugging for this browser session | ||||
|                 setcookie('SMARTY_DEBUG', true); | ||||
|                 $smarty->debugging = true; | ||||
|             } elseif (false !== strpos($_query_string, $smarty->smarty_debug_id . '=off')) { | ||||
|                 // disable debugging for this browser session | ||||
|                 setcookie('SMARTY_DEBUG', false); | ||||
|                 $smarty->debugging = false; | ||||
|             } else { | ||||
|                 // enable debugging for this page | ||||
|                 $smarty->debugging = true; | ||||
|             } | ||||
|         } else { | ||||
|             if (isset($_COOKIE[ 'SMARTY_DEBUG' ])) { | ||||
|                 $smarty->debugging = true; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										113
									
								
								lib/smarty/libs/sysplugins/smarty_internal_errorhandler.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								lib/smarty/libs/sysplugins/smarty_internal_errorhandler.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty error handler | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  * | ||||
|  * @deprecated | ||||
| Smarty does no longer use @filemtime() | ||||
|  */ | ||||
| class Smarty_Internal_ErrorHandler | ||||
| { | ||||
|     /** | ||||
|      * contains directories outside of SMARTY_DIR that are to be muted by muteExpectedErrors() | ||||
|      */ | ||||
|     public static $mutedDirectories = array(); | ||||
|  | ||||
|     /** | ||||
|      * error handler returned by set_error_handler() in self::muteExpectedErrors() | ||||
|      */ | ||||
|     private static $previousErrorHandler = null; | ||||
|  | ||||
|     /** | ||||
|      * Enable error handler to mute expected messages | ||||
|      * | ||||
|      */ | ||||
|     public static function muteExpectedErrors() | ||||
|     { | ||||
|         /* | ||||
|             error muting is done because some people implemented custom error_handlers using | ||||
|             http://php.net/set_error_handler and for some reason did not understand the following paragraph: | ||||
|  | ||||
|                 It is important to remember that the standard PHP error handler is completely bypassed for the | ||||
|                 error types specified by error_types unless the callback function returns FALSE. | ||||
|                 error_reporting() settings will have no effect and your error handler will be called regardless - | ||||
|                 however you are still able to read the current value of error_reporting and act appropriately. | ||||
|                 Of particular note is that this value will be 0 if the statement that caused the error was | ||||
|                 prepended by the @ error-control operator. | ||||
|  | ||||
|             Smarty deliberately uses @filemtime() over file_exists() and filemtime() in some places. Reasons include | ||||
|                 - @filemtime() is almost twice as fast as using an additional file_exists() | ||||
|                 - between file_exists() and filemtime() a possible race condition is opened, | ||||
|                   which does not exist using the simple @filemtime() approach. | ||||
|         */ | ||||
|         $error_handler = array('Smarty_Internal_ErrorHandler', 'mutingErrorHandler'); | ||||
|         $previous = set_error_handler($error_handler); | ||||
|         // avoid dead loops | ||||
|         if ($previous !== $error_handler) { | ||||
|             self::$previousErrorHandler = $previous; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Error Handler to mute expected messages | ||||
|      * | ||||
|      * @link http://php.net/set_error_handler | ||||
|      * | ||||
|      * @param integer $errno Error level | ||||
|      * @param         $errstr | ||||
|      * @param         $errfile | ||||
|      * @param         $errline | ||||
|      * @param         $errcontext | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public static function mutingErrorHandler($errno, $errstr, $errfile, $errline, $errcontext = array()) | ||||
|     { | ||||
|         $_is_muted_directory = false; | ||||
|         // add the SMARTY_DIR to the list of muted directories | ||||
|         if (!isset(self::$mutedDirectories[ SMARTY_DIR ])) { | ||||
|             $smarty_dir = realpath(SMARTY_DIR); | ||||
|             if ($smarty_dir !== false) { | ||||
|                 self::$mutedDirectories[ SMARTY_DIR ] = | ||||
|                     array('file' => $smarty_dir, 'length' => strlen($smarty_dir),); | ||||
|             } | ||||
|         } | ||||
|         // walk the muted directories and test against $errfile | ||||
|         foreach (self::$mutedDirectories as $key => &$dir) { | ||||
|             if (!$dir) { | ||||
|                 // resolve directory and length for speedy comparisons | ||||
|                 $file = realpath($key); | ||||
|                 if ($file === false) { | ||||
|                     // this directory does not exist, remove and skip it | ||||
|                     unset(self::$mutedDirectories[ $key ]); | ||||
|                     continue; | ||||
|                 } | ||||
|                 $dir = array('file' => $file, 'length' => strlen($file),); | ||||
|             } | ||||
|             if (!strncmp($errfile, $dir[ 'file' ], $dir[ 'length' ])) { | ||||
|                 $_is_muted_directory = true; | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|         // pass to next error handler if this error did not occur inside SMARTY_DIR | ||||
|         // or the error was within smarty but masked to be ignored | ||||
|         if (!$_is_muted_directory || ($errno && $errno & error_reporting())) { | ||||
|             if (self::$previousErrorHandler) { | ||||
|                 return call_user_func( | ||||
|                     self::$previousErrorHandler, | ||||
|                     $errno, | ||||
|                     $errstr, | ||||
|                     $errfile, | ||||
|                     $errline, | ||||
|                     $errcontext | ||||
|                 ); | ||||
|             } else { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										197
									
								
								lib/smarty/libs/sysplugins/smarty_internal_extension_handler.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										197
									
								
								lib/smarty/libs/sysplugins/smarty_internal_extension_handler.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,197 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Extension handler | ||||
|  * | ||||
|  * Load extensions dynamically | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  * | ||||
|  * Runtime extensions | ||||
|  * @property   Smarty_Internal_Runtime_CacheModify       $_cacheModify | ||||
|  * @property   Smarty_Internal_Runtime_CacheResourceFile $_cacheResourceFile | ||||
|  * @property   Smarty_Internal_Runtime_Capture           $_capture | ||||
|  * @property   Smarty_Internal_Runtime_CodeFrame         $_codeFrame | ||||
|  * @property   Smarty_Internal_Runtime_FilterHandler     $_filterHandler | ||||
|  * @property   Smarty_Internal_Runtime_Foreach           $_foreach | ||||
|  * @property   Smarty_Internal_Runtime_GetIncludePath    $_getIncludePath | ||||
|  * @property   Smarty_Internal_Runtime_Make_Nocache      $_make_nocache | ||||
|  * @property   Smarty_Internal_Runtime_UpdateCache       $_updateCache | ||||
|  * @property   Smarty_Internal_Runtime_UpdateScope       $_updateScope | ||||
|  * @property   Smarty_Internal_Runtime_TplFunction       $_tplFunction | ||||
|  * @property   Smarty_Internal_Runtime_WriteFile         $_writeFile | ||||
|  * | ||||
|  * Method extensions | ||||
|  * @property   Smarty_Internal_Method_GetTemplateVars    $getTemplateVars | ||||
|  * @property   Smarty_Internal_Method_Append             $append | ||||
|  * @property   Smarty_Internal_Method_AppendByRef        $appendByRef | ||||
|  * @property   Smarty_Internal_Method_AssignGlobal       $assignGlobal | ||||
|  * @property   Smarty_Internal_Method_AssignByRef        $assignByRef | ||||
|  * @property   Smarty_Internal_Method_LoadFilter         $loadFilter | ||||
|  * @property   Smarty_Internal_Method_LoadPlugin         $loadPlugin | ||||
|  * @property   Smarty_Internal_Method_RegisterFilter     $registerFilter | ||||
|  * @property   Smarty_Internal_Method_RegisterObject     $registerObject | ||||
|  * @property   Smarty_Internal_Method_RegisterPlugin     $registerPlugin | ||||
|  * @property   mixed|\Smarty_Template_Cached             configLoad | ||||
|  */ | ||||
| class Smarty_Internal_Extension_Handler | ||||
| { | ||||
|     public $objType = null; | ||||
|  | ||||
|     /** | ||||
|      * Cache for property information from generic getter/setter | ||||
|      * Preloaded with names which should not use with generic getter/setter | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_property_info     = array( | ||||
|         'AutoloadFilters' => 0, 'DefaultModifiers' => 0, 'ConfigVars' => 0, | ||||
|         'DebugTemplate'   => 0, 'RegisteredObject' => 0, 'StreamVariable' => 0, | ||||
|         'TemplateVars'    => 0, 'Literals' => 'Literals', | ||||
|     );// | ||||
|  | ||||
|     private $resolvedProperties = array(); | ||||
|  | ||||
|     /** | ||||
|      * Call external Method | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data $data | ||||
|      * @param string                $name external method names | ||||
|      * @param array                 $args argument array | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function _callExternalMethod(Smarty_Internal_Data $data, $name, $args) | ||||
|     { | ||||
|         /* @var Smarty $data ->smarty */ | ||||
|         $smarty = isset($data->smarty) ? $data->smarty : $data; | ||||
|         if (!isset($smarty->ext->$name)) { | ||||
|             if (preg_match('/^((set|get)|(.*?))([A-Z].*)$/', $name, $match)) { | ||||
|                 $basename = $this->upperCase($match[ 4 ]); | ||||
|                 if (!isset($smarty->ext->$basename) && isset($this->_property_info[ $basename ]) | ||||
|                     && is_string($this->_property_info[ $basename ]) | ||||
|                 ) { | ||||
|                     $class = 'Smarty_Internal_Method_' . $this->_property_info[ $basename ]; | ||||
|                     if (class_exists($class)) { | ||||
|                         $classObj = new $class(); | ||||
|                         $methodes = get_class_methods($classObj); | ||||
|                         foreach ($methodes as $method) { | ||||
|                             $smarty->ext->$method = $classObj; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 if (!empty($match[ 2 ]) && !isset($smarty->ext->$name)) { | ||||
|                     $class = 'Smarty_Internal_Method_' . $this->upperCase($name); | ||||
|                     if (!class_exists($class)) { | ||||
|                         $objType = $data->_objType; | ||||
|                         $propertyType = false; | ||||
|                         if (!isset($this->resolvedProperties[ $match[ 0 ] ][ $objType ])) { | ||||
|                             $property = isset($this->resolvedProperties[ 'property' ][ $basename ]) ? | ||||
|                                 $this->resolvedProperties[ 'property' ][ $basename ] : | ||||
|                                 $property = $this->resolvedProperties[ 'property' ][ $basename ] = strtolower( | ||||
|                                     join( | ||||
|                                         '_', | ||||
|                                         preg_split( | ||||
|                                             '/([A-Z][^A-Z]*)/', | ||||
|                                             $basename, | ||||
|                                             -1, | ||||
|                                             PREG_SPLIT_NO_EMPTY | | ||||
|                                             PREG_SPLIT_DELIM_CAPTURE | ||||
|                                         ) | ||||
|                                     ) | ||||
|                                 ); | ||||
|                             if ($property !== false) { | ||||
|                                 if (property_exists($data, $property)) { | ||||
|                                     $propertyType = $this->resolvedProperties[ $match[ 0 ] ][ $objType ] = 1; | ||||
|                                 } elseif (property_exists($smarty, $property)) { | ||||
|                                     $propertyType = $this->resolvedProperties[ $match[ 0 ] ][ $objType ] = 2; | ||||
|                                 } else { | ||||
|                                     $this->resolvedProperties[ 'property' ][ $basename ] = $property = false; | ||||
|                                 } | ||||
|                             } | ||||
|                         } else { | ||||
|                             $propertyType = $this->resolvedProperties[ $match[ 0 ] ][ $objType ]; | ||||
|                             $property = $this->resolvedProperties[ 'property' ][ $basename ]; | ||||
|                         } | ||||
|                         if ($propertyType) { | ||||
|                             $obj = $propertyType === 1 ? $data : $smarty; | ||||
|                             if ($match[ 2 ] === 'get') { | ||||
|                                 return $obj->$property; | ||||
|                             } elseif ($match[ 2 ] === 'set') { | ||||
|                                 return $obj->$property = $args[ 0 ]; | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $callback = array($smarty->ext->$name, $name); | ||||
|         array_unshift($args, $data); | ||||
|         if (isset($callback) && $callback[ 0 ]->objMap | $data->_objType) { | ||||
|             return call_user_func_array($callback, $args); | ||||
|         } | ||||
|         return call_user_func_array(array(new Smarty_Internal_Undefined(), $name), $args); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Make first character of name parts upper case | ||||
|      * | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function upperCase($name) | ||||
|     { | ||||
|         $_name = explode('_', $name); | ||||
|         $_name = array_map('ucfirst', $_name); | ||||
|         return implode('_', $_name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * get extension object | ||||
|      * | ||||
|      * @param string $property_name property name | ||||
|      * | ||||
|      * @return mixed|Smarty_Template_Cached | ||||
|      */ | ||||
|     public function __get($property_name) | ||||
|     { | ||||
|         // object properties of runtime template extensions will start with '_' | ||||
|         if ($property_name[ 0 ] === '_') { | ||||
|             $class = 'Smarty_Internal_Runtime' . $this->upperCase($property_name); | ||||
|         } else { | ||||
|             $class = 'Smarty_Internal_Method_' . $this->upperCase($property_name); | ||||
|         } | ||||
|         if (!class_exists($class)) { | ||||
|             return $this->$property_name = new Smarty_Internal_Undefined($class); | ||||
|         } | ||||
|         return $this->$property_name = new $class(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * set extension property | ||||
|      * | ||||
|      * @param string $property_name property name | ||||
|      * @param mixed  $value         value | ||||
|      * | ||||
|      */ | ||||
|     public function __set($property_name, $value) | ||||
|     { | ||||
|         $this->$property_name = $value; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Call error handler for undefined method | ||||
|      * | ||||
|      * @param string $name unknown method-name | ||||
|      * @param array  $args argument array | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function __call($name, $args) | ||||
|     { | ||||
|         return call_user_func_array(array(new Smarty_Internal_Undefined(), $name), array($this)); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,53 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method AddAutoloadFilters | ||||
|  * | ||||
|  * Smarty::addAutoloadFilters() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_AddAutoloadFilters extends Smarty_Internal_Method_SetAutoloadFilters | ||||
| { | ||||
|     /** | ||||
|      * Add autoload filters | ||||
|      * | ||||
|      * @api Smarty::setAutoloadFilters() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array                                                           $filters filters to load automatically | ||||
|      * @param string                                                          $type    "pre", "output", … specify | ||||
|      *                                                                                 the filter type to set. | ||||
|      *                                                                                 Defaults to none treating | ||||
|      *                                                                                 $filters' keys as the | ||||
|      *                                                                                 appropriate types | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function addAutoloadFilters(Smarty_Internal_TemplateBase $obj, $filters, $type = null) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if ($type !== null) { | ||||
|             $this->_checkFilterType($type); | ||||
|             if (!empty($smarty->autoload_filters[ $type ])) { | ||||
|                 $smarty->autoload_filters[ $type ] = array_merge($smarty->autoload_filters[ $type ], (array)$filters); | ||||
|             } else { | ||||
|                 $smarty->autoload_filters[ $type ] = (array)$filters; | ||||
|             } | ||||
|         } else { | ||||
|             foreach ((array)$filters as $type => $value) { | ||||
|                 $this->_checkFilterType($type); | ||||
|                 if (!empty($smarty->autoload_filters[ $type ])) { | ||||
|                     $smarty->autoload_filters[ $type ] = | ||||
|                         array_merge($smarty->autoload_filters[ $type ], (array)$value); | ||||
|                 } else { | ||||
|                     $smarty->autoload_filters[ $type ] = (array)$value; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,42 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method AddDefaultModifiers | ||||
|  * | ||||
|  * Smarty::addDefaultModifiers() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_AddDefaultModifiers | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Add default modifiers | ||||
|      * | ||||
|      * @api Smarty::addDefaultModifiers() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array|string                                                    $modifiers modifier or list of modifiers | ||||
|      *                                                                                   to add | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      */ | ||||
|     public function addDefaultModifiers(Smarty_Internal_TemplateBase $obj, $modifiers) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (is_array($modifiers)) { | ||||
|             $smarty->default_modifiers = array_merge($smarty->default_modifiers, $modifiers); | ||||
|         } else { | ||||
|             $smarty->default_modifiers[] = $modifiers; | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										74
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_append.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_append.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,74 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method Append | ||||
|  * | ||||
|  * Smarty::append() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_Append | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * appends values to template variables | ||||
|      * | ||||
|      * @api  Smarty::append() | ||||
|      * @link http://www.smarty.net/docs/en/api.append.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param array|string                                            $tpl_var the template variable name(s) | ||||
|      * @param mixed                                                   $value   the value to append | ||||
|      * @param bool                                                    $merge   flag if array elements shall be merged | ||||
|      * @param bool                                                    $nocache if true any output of this variable will | ||||
|      *                                                                         be not cached | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function append(Smarty_Internal_Data $data, $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 !== '') { | ||||
|                     $this->append($data, $_key, $_val, $merge, $nocache); | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             if ($tpl_var !== '' && isset($value)) { | ||||
|                 if (!isset($data->tpl_vars[ $tpl_var ])) { | ||||
|                     $tpl_var_inst = $data->ext->getTemplateVars->_getVariable($data, $tpl_var, null, true, false); | ||||
|                     if ($tpl_var_inst instanceof Smarty_Undefined_Variable) { | ||||
|                         $data->tpl_vars[ $tpl_var ] = new Smarty_Variable(null, $nocache); | ||||
|                     } else { | ||||
|                         $data->tpl_vars[ $tpl_var ] = clone $tpl_var_inst; | ||||
|                     } | ||||
|                 } | ||||
|                 if (!(is_array($data->tpl_vars[ $tpl_var ]->value) | ||||
|                       || $data->tpl_vars[ $tpl_var ]->value instanceof ArrayAccess) | ||||
|                 ) { | ||||
|                     settype($data->tpl_vars[ $tpl_var ]->value, 'array'); | ||||
|                 } | ||||
|                 if ($merge && is_array($value)) { | ||||
|                     foreach ($value as $_mkey => $_mval) { | ||||
|                         $data->tpl_vars[ $tpl_var ]->value[ $_mkey ] = $_mval; | ||||
|                     } | ||||
|                 } else { | ||||
|                     $data->tpl_vars[ $tpl_var ]->value[] = $value; | ||||
|                 } | ||||
|             } | ||||
|             if ($data->_isTplObj() && $data->scope) { | ||||
|                 $data->ext->_updateScope->_updateScope($data, $tpl_var); | ||||
|             } | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,49 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method AppendByRef | ||||
|  * | ||||
|  * Smarty::appendByRef() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_AppendByRef | ||||
| { | ||||
|     /** | ||||
|      * appends values to template variables by reference | ||||
|      * | ||||
|      * @api  Smarty::appendByRef() | ||||
|      * @link http://www.smarty.net/docs/en/api.append.by.ref.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $tpl_var the template variable name | ||||
|      * @param mixed                                                   &$value  the referenced value to append | ||||
|      * @param bool                                                    $merge   flag if array elements shall be merged | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public static function appendByRef(Smarty_Internal_Data $data, $tpl_var, &$value, $merge = false) | ||||
|     { | ||||
|         if ($tpl_var !== '' && isset($value)) { | ||||
|             if (!isset($data->tpl_vars[ $tpl_var ])) { | ||||
|                 $data->tpl_vars[ $tpl_var ] = new Smarty_Variable(); | ||||
|             } | ||||
|             if (!is_array($data->tpl_vars[ $tpl_var ]->value)) { | ||||
|                 settype($data->tpl_vars[ $tpl_var ]->value, 'array'); | ||||
|             } | ||||
|             if ($merge && is_array($value)) { | ||||
|                 foreach ($value as $_key => $_val) { | ||||
|                     $data->tpl_vars[ $tpl_var ]->value[ $_key ] = &$value[ $_key ]; | ||||
|                 } | ||||
|             } else { | ||||
|                 $data->tpl_vars[ $tpl_var ]->value[] = &$value; | ||||
|             } | ||||
|             if ($data->_isTplObj() && $data->scope) { | ||||
|                 $data->ext->_updateScope->_updateScope($data, $tpl_var); | ||||
|             } | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,36 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method AssignByRef | ||||
|  * | ||||
|  * Smarty::assignByRef() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_AssignByRef | ||||
| { | ||||
|     /** | ||||
|      * assigns values to template variables by reference | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @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|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function assignByRef(Smarty_Internal_Data $data, $tpl_var, &$value, $nocache) | ||||
|     { | ||||
|         if ($tpl_var !== '') { | ||||
|             $data->tpl_vars[ $tpl_var ] = new Smarty_Variable(null, $nocache); | ||||
|             $data->tpl_vars[ $tpl_var ]->value = &$value; | ||||
|             if ($data->_isTplObj() && $data->scope) { | ||||
|                 $data->ext->_updateScope->_updateScope($data, $tpl_var); | ||||
|             } | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method AssignGlobal | ||||
|  * | ||||
|  * Smarty::assignGlobal() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_AssignGlobal | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * assigns a global Smarty variable | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @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|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function assignGlobal(Smarty_Internal_Data $data, $varName, $value = null, $nocache = false) | ||||
|     { | ||||
|         if ($varName !== '') { | ||||
|             Smarty::$global_tpl_vars[ $varName ] = new Smarty_Variable($value, $nocache); | ||||
|             $ptr = $data; | ||||
|             while ($ptr->_isTplObj()) { | ||||
|                 $ptr->tpl_vars[ $varName ] = clone Smarty::$global_tpl_vars[ $varName ]; | ||||
|                 $ptr = $ptr->parent; | ||||
|             } | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,36 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearAllAssign | ||||
|  * | ||||
|  * Smarty::clearAllAssign() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearAllAssign | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * clear all the assigned template variables. | ||||
|      * | ||||
|      * @api  Smarty::clearAllAssign() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.all.assign.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function clearAllAssign(Smarty_Internal_Data $data) | ||||
|     { | ||||
|         $data->tpl_vars = array(); | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearAllCache | ||||
|  * | ||||
|  * Smarty::clearAllCache() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearAllCache | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 1; | ||||
|  | ||||
|     /** | ||||
|      * Empty cache folder | ||||
|      * | ||||
|      * @api  Smarty::clearAllCache() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.all.cache.tpl | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @param integer $exp_time expiration time | ||||
|      * @param string  $type     resource type | ||||
|      * | ||||
|      * @return int number of cache files deleted | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function clearAllCache(Smarty $smarty, $exp_time = null, $type = null) | ||||
|     { | ||||
|         $smarty->_clearTemplateCache(); | ||||
|         // load cache resource and call clearAll | ||||
|         $_cache_resource = Smarty_CacheResource::load($smarty, $type); | ||||
|         return $_cache_resource->clearAll($smarty, $exp_time); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,43 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearAssign | ||||
|  * | ||||
|  * Smarty::clearAssign() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearAssign | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * clear the given assigned template variable(s). | ||||
|      * | ||||
|      * @api  Smarty::clearAssign() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.assign.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string|array                                            $tpl_var the template variable(s) to clear | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function clearAssign(Smarty_Internal_Data $data, $tpl_var) | ||||
|     { | ||||
|         if (is_array($tpl_var)) { | ||||
|             foreach ($tpl_var as $curr_var) { | ||||
|                 unset($data->tpl_vars[ $curr_var ]); | ||||
|             } | ||||
|         } else { | ||||
|             unset($data->tpl_vars[ $tpl_var ]); | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,50 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearCache | ||||
|  * | ||||
|  * Smarty::clearCache() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearCache | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 1; | ||||
|  | ||||
|     /** | ||||
|      * Empty cache for a specific template | ||||
|      * | ||||
|      * @api  Smarty::clearCache() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.cache.tpl | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @param string  $template_name template name | ||||
|      * @param string  $cache_id      cache id | ||||
|      * @param string  $compile_id    compile id | ||||
|      * @param integer $exp_time      expiration time | ||||
|      * @param string  $type          resource type | ||||
|      * | ||||
|      * @return int number of cache files deleted | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function clearCache( | ||||
|         Smarty $smarty, | ||||
|         $template_name, | ||||
|         $cache_id = null, | ||||
|         $compile_id = null, | ||||
|         $exp_time = null, | ||||
|         $type = null | ||||
|     ) { | ||||
|         $smarty->_clearTemplateCache(); | ||||
|         // load cache resource and call clear | ||||
|         $_cache_resource = Smarty_CacheResource::load($smarty, $type); | ||||
|         return $_cache_resource->clear($smarty, $template_name, $cache_id, $compile_id, $exp_time); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,131 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearCompiledTemplate | ||||
|  * | ||||
|  * Smarty::clearCompiledTemplate() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearCompiledTemplate | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 1; | ||||
|  | ||||
|     /** | ||||
|      * Delete compiled template file | ||||
|      * | ||||
|      * @api  Smarty::clearCompiledTemplate() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.compiled.template.tpl | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @param string  $resource_name template name | ||||
|      * @param string  $compile_id    compile id | ||||
|      * @param integer $exp_time      expiration time | ||||
|      * | ||||
|      * @return int number of template files deleted | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function clearCompiledTemplate(Smarty $smarty, $resource_name = null, $compile_id = null, $exp_time = null) | ||||
|     { | ||||
|         // clear template objects cache | ||||
|         $smarty->_clearTemplateCache(); | ||||
|         $_compile_dir = $smarty->getCompileDir(); | ||||
|         if ($_compile_dir === '/') { //We should never want to delete this! | ||||
|             return 0; | ||||
|         } | ||||
|         $_compile_id = isset($compile_id) ? preg_replace('![^\w]+!', '_', $compile_id) : null; | ||||
|         $_dir_sep = $smarty->use_sub_dirs ? DIRECTORY_SEPARATOR : '^'; | ||||
|         if (isset($resource_name)) { | ||||
|             $_save_stat = $smarty->caching; | ||||
|             $smarty->caching = Smarty::CACHING_OFF; | ||||
|             /* @var Smarty_Internal_Template $tpl */ | ||||
|             $tpl = $smarty->createTemplate($resource_name); | ||||
|             $smarty->caching = $_save_stat; | ||||
|             if (!$tpl->source->handler->uncompiled && !$tpl->source->handler->recompiled && $tpl->source->exists) { | ||||
|                 $_resource_part_1 = basename(str_replace('^', DIRECTORY_SEPARATOR, $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 = $_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) === '.') { | ||||
|                 continue; | ||||
|             } | ||||
|             $_filepath = (string)$_file; | ||||
|             if ($_file->isDir()) { | ||||
|                 if (!$_compile->isDot()) { | ||||
|                     // delete folder if empty | ||||
|                     @rmdir($_file->getPathname()); | ||||
|                 } | ||||
|             } else { | ||||
|                 // delete only php files | ||||
|                 if (substr($_filepath, -4) !== '.php') { | ||||
|                     continue; | ||||
|                 } | ||||
|                 $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 (is_file($_filepath) && time() - filemtime($_filepath) >= $exp_time) { | ||||
|                             $unlink = true; | ||||
|                         } | ||||
|                     } else { | ||||
|                         $unlink = true; | ||||
|                     } | ||||
|                 } | ||||
|                 if ($unlink && is_file($_filepath) && @unlink($_filepath)) { | ||||
|                     $_count++; | ||||
|                     if (function_exists('opcache_invalidate') | ||||
|                         && (!function_exists('ini_get') || strlen(ini_get('opcache.restrict_api')) < 1) | ||||
|                     ) { | ||||
|                         opcache_invalidate($_filepath, true); | ||||
|                     } elseif (function_exists('apc_delete_file')) { | ||||
|                         apc_delete_file($_filepath); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $_count; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ClearConfig | ||||
|  * | ||||
|  * Smarty::clearConfig() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ClearConfig | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * clear a single or all config variables | ||||
|      * | ||||
|      * @api  Smarty::clearConfig() | ||||
|      * @link http://www.smarty.net/docs/en/api.clear.config.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string|null                                             $name variable name or null | ||||
|      * | ||||
|      * @return \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty | ||||
|      */ | ||||
|     public function clearConfig(Smarty_Internal_Data $data, $name = null) | ||||
|     { | ||||
|         if (isset($name)) { | ||||
|             unset($data->config_vars[ $name ]); | ||||
|         } else { | ||||
|             $data->config_vars = array(); | ||||
|         } | ||||
|         return $data; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,36 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method CompileAllConfig | ||||
|  * | ||||
|  * Smarty::compileAllConfig() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_CompileAllConfig extends Smarty_Internal_Method_CompileAllTemplates | ||||
| { | ||||
|     /** | ||||
|      * Compile all config files | ||||
|      * | ||||
|      * @api Smarty::compileAllConfig() | ||||
|      * | ||||
|      * @param \Smarty $smarty        passed smarty object | ||||
|      * @param string  $extension     file extension | ||||
|      * @param bool    $force_compile force all to recompile | ||||
|      * @param int     $time_limit | ||||
|      * @param int     $max_errors | ||||
|      * | ||||
|      * @return int number of template files recompiled | ||||
|      */ | ||||
|     public function compileAllConfig( | ||||
|         Smarty $smarty, | ||||
|         $extension = '.conf', | ||||
|         $force_compile = false, | ||||
|         $time_limit = 0, | ||||
|         $max_errors = null | ||||
|     ) { | ||||
|         return $this->compileAll($smarty, $extension, $force_compile, $time_limit, $max_errors, true); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,130 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method CompileAllTemplates | ||||
|  * | ||||
|  * Smarty::compileAllTemplates() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_CompileAllTemplates | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 1; | ||||
|  | ||||
|     /** | ||||
|      * Compile all template files | ||||
|      * | ||||
|      * @api Smarty::compileAllTemplates() | ||||
|      * | ||||
|      * @param \Smarty $smarty        passed smarty object | ||||
|      * @param string  $extension     file extension | ||||
|      * @param bool    $force_compile force all to recompile | ||||
|      * @param int     $time_limit | ||||
|      * @param int     $max_errors | ||||
|      * | ||||
|      * @return integer number of template files recompiled | ||||
|      */ | ||||
|     public function compileAllTemplates( | ||||
|         Smarty $smarty, | ||||
|         $extension = '.tpl', | ||||
|         $force_compile = false, | ||||
|         $time_limit = 0, | ||||
|         $max_errors = null | ||||
|     ) { | ||||
|         return $this->compileAll($smarty, $extension, $force_compile, $time_limit, $max_errors); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Compile all template or config files | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @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 bool    $isConfig      flag true if called for config files | ||||
|      * | ||||
|      * @return int number of template files compiled | ||||
|      */ | ||||
|     protected function compileAll( | ||||
|         Smarty $smarty, | ||||
|         $extension, | ||||
|         $force_compile, | ||||
|         $time_limit, | ||||
|         $max_errors, | ||||
|         $isConfig = false | ||||
|     ) { | ||||
|         // switch off time limit | ||||
|         if (function_exists('set_time_limit')) { | ||||
|             @set_time_limit($time_limit); | ||||
|         } | ||||
|         $_count = 0; | ||||
|         $_error_count = 0; | ||||
|         $sourceDir = $isConfig ? $smarty->getConfigDir() : $smarty->getTemplateDir(); | ||||
|         // loop over array of source directories | ||||
|         foreach ($sourceDir as $_dir) { | ||||
|             $_dir_1 = new RecursiveDirectoryIterator( | ||||
|                 $_dir, | ||||
|                 defined('FilesystemIterator::FOLLOW_SYMLINKS') ? | ||||
|                     FilesystemIterator::FOLLOW_SYMLINKS : 0 | ||||
|             ); | ||||
|             $_dir_2 = new RecursiveIteratorIterator($_dir_1); | ||||
|             foreach ($_dir_2 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)) { | ||||
|                     $_file = substr($_fileinfo->getPath(), strlen($_dir)) . DIRECTORY_SEPARATOR . $_file; | ||||
|                 } | ||||
|                 echo "\n<br>", $_dir, '---', $_file; | ||||
|                 flush(); | ||||
|                 $_start_time = microtime(true); | ||||
|                 $_smarty = clone $smarty; | ||||
|                 // | ||||
|                 $_smarty->_cache = array(); | ||||
|                 $_smarty->ext = new Smarty_Internal_Extension_Handler(); | ||||
|                 $_smarty->ext->objType = $_smarty->_objType; | ||||
|                 $_smarty->force_compile = $force_compile; | ||||
|                 try { | ||||
|                     /* @var Smarty_Internal_Template $_tpl */ | ||||
|                     $_tpl = new $smarty->template_class($_file, $_smarty); | ||||
|                     $_tpl->caching = Smarty::CACHING_OFF; | ||||
|                     $_tpl->source = | ||||
|                         $isConfig ? Smarty_Template_Config::load($_tpl) : Smarty_Template_Source::load($_tpl); | ||||
|                     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 "\n<br>        ------>Error: ", $e->getMessage(), "<br><br>\n"; | ||||
|                     $_error_count++; | ||||
|                 } | ||||
|                 // free memory | ||||
|                 unset($_tpl); | ||||
|                 $_smarty->_clearTemplateCache(); | ||||
|                 if ($max_errors !== null && $_error_count === $max_errors) { | ||||
|                     echo "\n<br><br>too many errors\n"; | ||||
|                     exit(1); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         echo "\n<br>"; | ||||
|         return $_count; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										182
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_configload.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_configload.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,182 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method ConfigLoad | ||||
|  * | ||||
|  * Smarty::configLoad() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_ConfigLoad | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * load a config file, optionally load just selected sections | ||||
|      * | ||||
|      * @api  Smarty::configLoad() | ||||
|      * @link http://www.smarty.net/docs/en/api.config.load.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $config_file filename | ||||
|      * @param mixed                                                   $sections    array of section names, single | ||||
|      *                                                                             section or null | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Data|\Smarty_Internal_Template | ||||
|      * @throws \Exception | ||||
|      */ | ||||
|     public function configLoad(Smarty_Internal_Data $data, $config_file, $sections = null) | ||||
|     { | ||||
|         $this->_loadConfigFile($data, $config_file, $sections, null); | ||||
|         return $data; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * load a config file, optionally load just selected sections | ||||
|      * | ||||
|      * @api  Smarty::configLoad() | ||||
|      * @link http://www.smarty.net/docs/en/api.config.load.tpl | ||||
|      * | ||||
|      * @param \Smarty|\Smarty_Internal_Data|\Smarty_Internal_Template $data | ||||
|      * @param string                                                  $config_file filename | ||||
|      * @param mixed                                                   $sections    array of section names, single | ||||
|      *                                                                             section or null | ||||
|      * @param int                                                     $scope       scope into which config variables | ||||
|      *                                                                             shall be loaded | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      */ | ||||
|     public function _loadConfigFile(Smarty_Internal_Data $data, $config_file, $sections = null, $scope = 0) | ||||
|     { | ||||
|         /* @var \Smarty $smarty */ | ||||
|         $smarty = $data->_getSmartyObj(); | ||||
|         /* @var \Smarty_Internal_Template $confObj */ | ||||
|         $confObj = new Smarty_Internal_Template($config_file, $smarty, $data, null, null, null, null, true); | ||||
|         $confObj->caching = Smarty::CACHING_OFF; | ||||
|         $confObj->source->config_sections = $sections; | ||||
|         $confObj->source->scope = $scope; | ||||
|         $confObj->compiled = Smarty_Template_Compiled::load($confObj); | ||||
|         $confObj->compiled->render($confObj); | ||||
|         if ($data->_isTplObj()) { | ||||
|             $data->compiled->file_dependency[ $confObj->source->uid ] = | ||||
|                 array($confObj->source->filepath, $confObj->source->getTimeStamp(), $confObj->source->type); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * load config variables into template object | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $tpl | ||||
|      * @param array                     $new_config_vars | ||||
|      */ | ||||
|     public function _loadConfigVars(Smarty_Internal_Template $tpl, $new_config_vars) | ||||
|     { | ||||
|         $this->_assignConfigVars($tpl->parent->config_vars, $tpl, $new_config_vars); | ||||
|         $tagScope = $tpl->source->scope; | ||||
|         if ($tagScope >= 0) { | ||||
|             if ($tagScope === Smarty::SCOPE_LOCAL) { | ||||
|                 $this->_updateVarStack($tpl, $new_config_vars); | ||||
|                 $tagScope = 0; | ||||
|                 if (!$tpl->scope) { | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             if ($tpl->parent->_isTplObj() && ($tagScope || $tpl->parent->scope)) { | ||||
|                 $mergedScope = $tagScope | $tpl->scope; | ||||
|                 if ($mergedScope) { | ||||
|                     // update scopes | ||||
|                     /* @var \Smarty_Internal_Template|\Smarty|\Smarty_Internal_Data $ptr */ | ||||
|                     foreach ($tpl->smarty->ext->_updateScope->_getAffectedScopes($tpl->parent, $mergedScope) as $ptr) { | ||||
|                         $this->_assignConfigVars($ptr->config_vars, $tpl, $new_config_vars); | ||||
|                         if ($tagScope && $ptr->_isTplObj() && isset($tpl->_cache[ 'varStack' ])) { | ||||
|                             $this->_updateVarStack($tpl, $new_config_vars); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Assign all config variables in given scope | ||||
|      * | ||||
|      * @param array                     $config_vars     config variables in scope | ||||
|      * @param \Smarty_Internal_Template $tpl | ||||
|      * @param array                     $new_config_vars loaded config variables | ||||
|      */ | ||||
|     public function _assignConfigVars(&$config_vars, Smarty_Internal_Template $tpl, $new_config_vars) | ||||
|     { | ||||
|         // copy global config vars | ||||
|         foreach ($new_config_vars[ 'vars' ] as $variable => $value) { | ||||
|             if ($tpl->smarty->config_overwrite || !isset($config_vars[ $variable ])) { | ||||
|                 $config_vars[ $variable ] = $value; | ||||
|             } else { | ||||
|                 $config_vars[ $variable ] = array_merge((array)$config_vars[ $variable ], (array)$value); | ||||
|             } | ||||
|         } | ||||
|         // scan sections | ||||
|         $sections = $tpl->source->config_sections; | ||||
|         if (!empty($sections)) { | ||||
|             foreach ((array)$sections as $tpl_section) { | ||||
|                 if (isset($new_config_vars[ 'sections' ][ $tpl_section ])) { | ||||
|                     foreach ($new_config_vars[ 'sections' ][ $tpl_section ][ 'vars' ] as $variable => $value) { | ||||
|                         if ($tpl->smarty->config_overwrite || !isset($config_vars[ $variable ])) { | ||||
|                             $config_vars[ $variable ] = $value; | ||||
|                         } else { | ||||
|                             $config_vars[ $variable ] = array_merge((array)$config_vars[ $variable ], (array)$value); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Update config variables in template local variable stack | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $tpl | ||||
|      * @param array                     $config_vars | ||||
|      */ | ||||
|     public function _updateVarStack(Smarty_Internal_Template $tpl, $config_vars) | ||||
|     { | ||||
|         $i = 0; | ||||
|         while (isset($tpl->_cache[ 'varStack' ][ $i ])) { | ||||
|             $this->_assignConfigVars($tpl->_cache[ 'varStack' ][ $i ][ 'config' ], $tpl, $config_vars); | ||||
|             $i++; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets  a config variable value | ||||
|      * | ||||
|      * @param \Smarty|\Smarty_Internal_Data|\Smarty_Internal_Template $data | ||||
|      * @param string                                                  $varName the name of the config variable | ||||
|      * @param bool                                                    $errorEnable | ||||
|      * | ||||
|      * @return null|string  the value of the config variable | ||||
|      */ | ||||
|     public function _getConfigVariable(Smarty_Internal_Data $data, $varName, $errorEnable = true) | ||||
|     { | ||||
|         $_ptr = $data; | ||||
|         while ($_ptr !== null) { | ||||
|             if (isset($_ptr->config_vars[ $varName ])) { | ||||
|                 // found it, return it | ||||
|                 return $_ptr->config_vars[ $varName ]; | ||||
|             } | ||||
|             // not found, try at parent | ||||
|             $_ptr = $_ptr->parent; | ||||
|         } | ||||
|         if ($data->smarty->error_unassigned && $errorEnable) { | ||||
|             // force a notice | ||||
|             $x = $$varName; | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method CreateData | ||||
|  * | ||||
|  * Smarty::createData() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_CreateData | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * creates a data object | ||||
|      * | ||||
|      * @api  Smarty::createData() | ||||
|      * @link http://www.smarty.net/docs/en/api.create.data.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty      $obj | ||||
|      * @param \Smarty_Internal_Template|\Smarty_Internal_Data|\Smarty_Data|\Smarty $parent next higher level of Smarty | ||||
|      *                                                                                     variables | ||||
|      * @param string                                                               $name   optional data block name | ||||
|      * | ||||
|      * @return \Smarty_Data data object | ||||
|      */ | ||||
|     public function createData(Smarty_Internal_TemplateBase $obj, Smarty_Internal_Data $parent = null, $name = null) | ||||
|     { | ||||
|         /* @var Smarty $smarty */ | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $dataObj = new Smarty_Data($parent, $smarty, $name); | ||||
|         if ($smarty->debugging) { | ||||
|             Smarty_Internal_Debug::register_data($dataObj); | ||||
|         } | ||||
|         return $dataObj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,37 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetAutoloadFilters | ||||
|  * | ||||
|  * Smarty::getAutoloadFilters() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetAutoloadFilters extends Smarty_Internal_Method_SetAutoloadFilters | ||||
| { | ||||
|     /** | ||||
|      * Get autoload filters | ||||
|      * | ||||
|      * @api Smarty::getAutoloadFilters() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type type of filter to get auto loads | ||||
|      *                                                                              for. Defaults to all autoload | ||||
|      *                                                                              filters | ||||
|      * | ||||
|      * @return array array( 'type1' => array( 'filter1', 'filter2', … ) ) or array( 'filter1', 'filter2', …) if $type | ||||
|      *                was specified | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function getAutoloadFilters(Smarty_Internal_TemplateBase $obj, $type = null) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if ($type !== null) { | ||||
|             $this->_checkFilterType($type); | ||||
|             return isset($smarty->autoload_filters[ $type ]) ? $smarty->autoload_filters[ $type ] : array(); | ||||
|         } | ||||
|         return $smarty->autoload_filters; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,34 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetConfigVariable | ||||
|  * | ||||
|  * Smarty::getConfigVariable() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetConfigVariable | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * gets  a config variable value | ||||
|      * | ||||
|      * @param \Smarty|\Smarty_Internal_Data|\Smarty_Internal_Template $data | ||||
|      * @param string                                                  $varName the name of the config variable | ||||
|      * @param bool                                                    $errorEnable | ||||
|      * | ||||
|      * @return null|string  the value of the config variable | ||||
|      */ | ||||
|     public function getConfigVariable(Smarty_Internal_Data $data, $varName = null, $errorEnable = true) | ||||
|     { | ||||
|         return $data->ext->configLoad->_getConfigVariable($data, $varName, $errorEnable); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,58 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetConfigVars | ||||
|  * | ||||
|  * Smarty::getConfigVars() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetConfigVars | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all config variables | ||||
|      * | ||||
|      * @api  Smarty::getConfigVars() | ||||
|      * @link http://www.smarty.net/docs/en/api.get.config.vars.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $varname        variable name or null | ||||
|      * @param bool                                                    $search_parents include parent templates? | ||||
|      * | ||||
|      * @return mixed variable value or or array of variables | ||||
|      */ | ||||
|     public function getConfigVars(Smarty_Internal_Data $data, $varname = null, $search_parents = true) | ||||
|     { | ||||
|         $_ptr = $data; | ||||
|         $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; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,35 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetDebugTemplate | ||||
|  * | ||||
|  * Smarty::getDebugTemplate() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetDebugTemplate | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * return name of debugging template | ||||
|      * | ||||
|      * @api Smarty::getDebugTemplate() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getDebugTemplate(Smarty_Internal_TemplateBase $obj) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         return $smarty->debug_tpl; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,35 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetDefaultModifiers | ||||
|  * | ||||
|  * Smarty::getDefaultModifiers() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetDefaultModifiers | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Get default modifiers | ||||
|      * | ||||
|      * @api Smarty::getDefaultModifiers() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * | ||||
|      * @return array list of default modifiers | ||||
|      */ | ||||
|     public function getDefaultModifiers(Smarty_Internal_TemplateBase $obj) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         return $smarty->default_modifiers; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,47 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetGlobal | ||||
|  * | ||||
|  * Smarty::getGlobal() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetGlobal | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all global  variables | ||||
|      * | ||||
|      * @api Smarty::getGlobal() | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data $data | ||||
|      * @param string                $varName variable name or null | ||||
|      * | ||||
|      * @return string|array variable value or or array of variables | ||||
|      */ | ||||
|     public function getGlobal(Smarty_Internal_Data $data, $varName = null) | ||||
|     { | ||||
|         if (isset($varName)) { | ||||
|             if (isset(Smarty::$global_tpl_vars[ $varName ])) { | ||||
|                 return Smarty::$global_tpl_vars[ $varName ]->value; | ||||
|             } else { | ||||
|                 return ''; | ||||
|             } | ||||
|         } else { | ||||
|             $_result = array(); | ||||
|             foreach (Smarty::$global_tpl_vars as $key => $var) { | ||||
|                 $_result[ $key ] = $var->value; | ||||
|             } | ||||
|             return $_result; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetRegisteredObject | ||||
|  * | ||||
|  * Smarty::getRegisteredObject() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetRegisteredObject | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * return a reference to a registered object | ||||
|      * | ||||
|      * @api  Smarty::getRegisteredObject() | ||||
|      * @link http://www.smarty.net/docs/en/api.get.registered.object.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $object_name object name | ||||
|      * | ||||
|      * @return object | ||||
|      * @throws \SmartyException if no such object is found | ||||
|      */ | ||||
|     public function getRegisteredObject(Smarty_Internal_TemplateBase $obj, $object_name) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (!isset($smarty->registered_objects[ $object_name ])) { | ||||
|             throw new SmartyException("'$object_name' is not a registered object"); | ||||
|         } | ||||
|         if (!is_object($smarty->registered_objects[ $object_name ][ 0 ])) { | ||||
|             throw new SmartyException("registered '$object_name' is not an object"); | ||||
|         } | ||||
|         return $smarty->registered_objects[ $object_name ][ 0 ]; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,50 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetStreamVariable | ||||
|  * | ||||
|  * Smarty::getStreamVariable() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetStreamVariable | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * gets  a stream variable | ||||
|      * | ||||
|      * @api Smarty::getStreamVariable() | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $variable the stream of the variable | ||||
|      * | ||||
|      * @return mixed | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function getStreamVariable(Smarty_Internal_Data $data, $variable) | ||||
|     { | ||||
|         $_result = ''; | ||||
|         $fp = fopen($variable, 'r+'); | ||||
|         if ($fp) { | ||||
|             while (!feof($fp) && ($current_line = fgets($fp)) !== false) { | ||||
|                 $_result .= $current_line; | ||||
|             } | ||||
|             fclose($fp); | ||||
|             return $_result; | ||||
|         } | ||||
|         $smarty = isset($data->smarty) ? $data->smarty : $data; | ||||
|         if ($smarty->error_unassigned) { | ||||
|             throw new SmartyException('Undefined stream variable "' . $variable . '"'); | ||||
|         } else { | ||||
|             return null; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,63 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetTags | ||||
|  * | ||||
|  * Smarty::getTags() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetTags | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Return array of tag/attributes of all tags used by an template | ||||
|      * | ||||
|      * @api  Smarty::getTags() | ||||
|      * @link http://www.smarty.net/docs/en/api.get.tags.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param null|string|Smarty_Internal_Template                            $template | ||||
|      * | ||||
|      * @return array of tag/attributes | ||||
|      * @throws \Exception | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function getTags(Smarty_Internal_TemplateBase $obj, $template = null) | ||||
|     { | ||||
|         /* @var Smarty $smarty */ | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if ($obj->_isTplObj() && !isset($template)) { | ||||
|             $tpl = clone $obj; | ||||
|         } elseif (isset($template) && $template->_isTplObj()) { | ||||
|             $tpl = clone $template; | ||||
|         } elseif (isset($template) && is_string($template)) { | ||||
|             /* @var Smarty_Internal_Template $tpl */ | ||||
|             $tpl = new $smarty->template_class($template, $smarty); | ||||
|             // checks if template exists | ||||
|             if (!$tpl->source->exists) { | ||||
|                 throw new SmartyException("Unable to load template {$tpl->source->type} '{$tpl->source->name}'"); | ||||
|             } | ||||
|         } | ||||
|         if (isset($tpl)) { | ||||
|             $tpl->smarty = clone $tpl->smarty; | ||||
|             $tpl->smarty->_cache[ 'get_used_tags' ] = true; | ||||
|             $tpl->_cache[ 'used_tags' ] = array(); | ||||
|             $tpl->smarty->merge_compiled_includes = false; | ||||
|             $tpl->smarty->disableSecurity(); | ||||
|             $tpl->caching = Smarty::CACHING_OFF; | ||||
|             $tpl->loadCompiler(); | ||||
|             $tpl->compiler->compileTemplate($tpl); | ||||
|             return $tpl->_cache[ 'used_tags' ]; | ||||
|         } | ||||
|         throw new SmartyException('Missing template specification'); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,119 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetTemplateVars | ||||
|  * | ||||
|  * Smarty::getTemplateVars() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_GetTemplateVars | ||||
| { | ||||
|     /** | ||||
|      * Valid for all objects | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 7; | ||||
|  | ||||
|     /** | ||||
|      * Returns a single or all template variables | ||||
|      * | ||||
|      * @api  Smarty::getTemplateVars() | ||||
|      * @link http://www.smarty.net/docs/en/api.get.template.vars.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $varName       variable name or null | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $_ptr          optional pointer to data object | ||||
|      * @param bool                                                    $searchParents include parent templates? | ||||
|      * | ||||
|      * @return mixed variable value or or array of variables | ||||
|      */ | ||||
|     public function getTemplateVars( | ||||
|         Smarty_Internal_Data $data, | ||||
|         $varName = null, | ||||
|         Smarty_Internal_Data $_ptr = null, | ||||
|         $searchParents = true | ||||
|     ) { | ||||
|         if (isset($varName)) { | ||||
|             $_var = $this->_getVariable($data, $varName, $_ptr, $searchParents, false); | ||||
|             if (is_object($_var)) { | ||||
|                 return $_var->value; | ||||
|             } else { | ||||
|                 return null; | ||||
|             } | ||||
|         } else { | ||||
|             $_result = array(); | ||||
|             if ($_ptr === null) { | ||||
|                 $_ptr = $data; | ||||
|             } | ||||
|             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 ($searchParents && isset($_ptr->parent)) { | ||||
|                     $_ptr = $_ptr->parent; | ||||
|                 } else { | ||||
|                     $_ptr = null; | ||||
|                 } | ||||
|             } | ||||
|             if ($searchParents && 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; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * gets the object of a Smarty variable | ||||
|      * | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $data | ||||
|      * @param string                                                  $varName       the name of the Smarty variable | ||||
|      * @param \Smarty_Internal_Data|\Smarty_Internal_Template|\Smarty $_ptr          optional pointer to data object | ||||
|      * @param bool                                                    $searchParents search also in parent data | ||||
|      * @param bool                                                    $errorEnable | ||||
|      * | ||||
|      * @return \Smarty_Variable | ||||
|      */ | ||||
|     public function _getVariable( | ||||
|         Smarty_Internal_Data $data, | ||||
|         $varName, | ||||
|         Smarty_Internal_Data $_ptr = null, | ||||
|         $searchParents = true, | ||||
|         $errorEnable = true | ||||
|     ) { | ||||
|         if ($_ptr === null) { | ||||
|             $_ptr = $data; | ||||
|         } | ||||
|         while ($_ptr !== null) { | ||||
|             if (isset($_ptr->tpl_vars[ $varName ])) { | ||||
|                 // found it, return it | ||||
|                 return $_ptr->tpl_vars[ $varName ]; | ||||
|             } | ||||
|             // not found, try at parent | ||||
|             if ($searchParents && isset($_ptr->parent)) { | ||||
|                 $_ptr = $_ptr->parent; | ||||
|             } else { | ||||
|                 $_ptr = null; | ||||
|             } | ||||
|         } | ||||
|         if (isset(Smarty::$global_tpl_vars[ $varName ])) { | ||||
|             // found it, return it | ||||
|             return Smarty::$global_tpl_vars[ $varName ]; | ||||
|         } | ||||
|         if ($errorEnable && $data->_getSmartyObj()->error_unassigned) { | ||||
|             // force a notice | ||||
|             $x = $$varName; | ||||
|         } | ||||
|         return new Smarty_Undefined_Variable; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										100
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_literals.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_literals.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method GetLiterals | ||||
|  * | ||||
|  * Smarty::getLiterals() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_Literals | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Get literals | ||||
|      * | ||||
|      * @api Smarty::getLiterals() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * | ||||
|      * @return array list of literals | ||||
|      */ | ||||
|     public function getLiterals(Smarty_Internal_TemplateBase $obj) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         return (array)$smarty->literals; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add literals | ||||
|      * | ||||
|      * @api Smarty::addLiterals() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array|string                                                    $literals literal or list of literals | ||||
|      *                                                                                  to addto add | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function addLiterals(Smarty_Internal_TemplateBase $obj, $literals = null) | ||||
|     { | ||||
|         if (isset($literals)) { | ||||
|             $this->set($obj->_getSmartyObj(), (array)$literals); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set literals | ||||
|      * | ||||
|      * @api Smarty::setLiterals() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array|string                                                    $literals literal or list of literals | ||||
|      *                                                                                  to setto set | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function setLiterals(Smarty_Internal_TemplateBase $obj, $literals = null) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $smarty->literals = array(); | ||||
|         if (!empty($literals)) { | ||||
|             $this->set($smarty, (array)$literals); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * common setter for literals for easier handling of duplicates the | ||||
|      * Smarty::$literals array gets filled with identical key values | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @param array   $literals | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     private function set(Smarty $smarty, $literals) | ||||
|     { | ||||
|         $literals = array_combine($literals, $literals); | ||||
|         $error = isset($literals[ $smarty->left_delimiter ]) ? array($smarty->left_delimiter) : array(); | ||||
|         $error = isset($literals[ $smarty->right_delimiter ]) ? $error[] = $smarty->right_delimiter : $error; | ||||
|         if (!empty($error)) { | ||||
|             throw new SmartyException( | ||||
|                 'User defined literal(s) "' . $error . | ||||
|                 '" may not be identical with left or right delimiter' | ||||
|             ); | ||||
|         } | ||||
|         $smarty->literals = array_merge((array)$smarty->literals, (array)$literals); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,77 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method LoadFilter | ||||
|  * | ||||
|  * Smarty::loadFilter() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_LoadFilter | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Valid filter types | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $filterTypes = array('pre' => true, 'post' => true, 'output' => true, 'variable' => true); | ||||
|  | ||||
|     /** | ||||
|      * load a filter of specified type and name | ||||
|      * | ||||
|      * @api  Smarty::loadFilter() | ||||
|      * | ||||
|      * @link http://www.smarty.net/docs/en/api.load.filter.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type filter type | ||||
|      * @param string                                                          $name filter name | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws SmartyException if filter could not be loaded | ||||
|      */ | ||||
|     public function loadFilter(Smarty_Internal_TemplateBase $obj, $type, $name) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $this->_checkFilterType($type); | ||||
|         $_plugin = "smarty_{$type}filter_{$name}"; | ||||
|         $_filter_name = $_plugin; | ||||
|         if (is_callable($_plugin)) { | ||||
|             $smarty->registered_filters[ $type ][ $_filter_name ] = $_plugin; | ||||
|             return true; | ||||
|         } | ||||
|         if ($smarty->loadPlugin($_plugin)) { | ||||
|             if (class_exists($_plugin, false)) { | ||||
|                 $_plugin = array($_plugin, 'execute'); | ||||
|             } | ||||
|             if (is_callable($_plugin)) { | ||||
|                 $smarty->registered_filters[ $type ][ $_filter_name ] = $_plugin; | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|         throw new SmartyException("{$type}filter '{$name}' not found or callable"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if filter type is valid | ||||
|      * | ||||
|      * @param string $type | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function _checkFilterType($type) | ||||
|     { | ||||
|         if (!isset($this->filterTypes[ $type ])) { | ||||
|             throw new SmartyException("Illegal filter type '{$type}'"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										111
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_loadplugin.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								lib/smarty/libs/sysplugins/smarty_internal_method_loadplugin.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Extension Loadplugin | ||||
|  * | ||||
|  * $smarty->loadPlugin() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_LoadPlugin | ||||
| { | ||||
|     /** | ||||
|      * Cache of searched plugin files | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $plugin_files = array(); | ||||
|  | ||||
|     /** | ||||
|      * Takes unknown classes and loads plugin files for them | ||||
|      * class name format: Smarty_PluginType_PluginName | ||||
|      * plugin filename format: plugintype.pluginname.php | ||||
|      * | ||||
|      * @param \Smarty $smarty | ||||
|      * @param string  $plugin_name class plugin name to load | ||||
|      * @param bool    $check       check if already loaded | ||||
|      * | ||||
|      * @return bool|string | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function loadPlugin(Smarty $smarty, $plugin_name, $check) | ||||
|     { | ||||
|         // if function or class exists, exit silently (already loaded) | ||||
|         if ($check && (is_callable($plugin_name) || class_exists($plugin_name, false))) { | ||||
|             return true; | ||||
|         } | ||||
|         if (!preg_match('#^smarty_((internal)|([^_]+))_(.+)$#i', $plugin_name, $match)) { | ||||
|             throw new SmartyException("plugin {$plugin_name} is not a valid name format"); | ||||
|         } | ||||
|         if (!empty($match[ 2 ])) { | ||||
|             $file = SMARTY_SYSPLUGINS_DIR . strtolower($plugin_name) . '.php'; | ||||
|             if (isset($this->plugin_files[ $file ])) { | ||||
|                 if ($this->plugin_files[ $file ] !== false) { | ||||
|                     return $this->plugin_files[ $file ]; | ||||
|                 } else { | ||||
|                     return false; | ||||
|                 } | ||||
|             } else { | ||||
|                 if (is_file($file)) { | ||||
|                     $this->plugin_files[ $file ] = $file; | ||||
|                     include_once $file; | ||||
|                     return $file; | ||||
|                 } else { | ||||
|                     $this->plugin_files[ $file ] = false; | ||||
|                     return false; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // plugin filename is expected to be: [type].[name].php | ||||
|         $_plugin_filename = "{$match[1]}.{$match[4]}.php"; | ||||
|         $_lower_filename = strtolower($_plugin_filename); | ||||
|         if (isset($this->plugin_files)) { | ||||
|             if (isset($this->plugin_files[ 'plugins_dir' ][ $_lower_filename ])) { | ||||
|                 if (!$smarty->use_include_path || $this->plugin_files[ 'plugins_dir' ][ $_lower_filename ] !== false) { | ||||
|                     return $this->plugin_files[ 'plugins_dir' ][ $_lower_filename ]; | ||||
|                 } | ||||
|             } | ||||
|             if (!$smarty->use_include_path || $smarty->ext->_getIncludePath->isNewIncludePath($smarty)) { | ||||
|                 unset($this->plugin_files[ 'include_path' ]); | ||||
|             } else { | ||||
|                 if (isset($this->plugin_files[ 'include_path' ][ $_lower_filename ])) { | ||||
|                     return $this->plugin_files[ 'include_path' ][ $_lower_filename ]; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         $_file_names = array($_plugin_filename); | ||||
|         if ($_lower_filename !== $_plugin_filename) { | ||||
|             $_file_names[] = $_lower_filename; | ||||
|         } | ||||
|         $_p_dirs = $smarty->getPluginsDir(); | ||||
|         if (!isset($this->plugin_files[ 'plugins_dir' ][ $_lower_filename ])) { | ||||
|             // loop through plugin dirs and find the plugin | ||||
|             foreach ($_p_dirs as $_plugin_dir) { | ||||
|                 foreach ($_file_names as $name) { | ||||
|                     $file = $_plugin_dir . $name; | ||||
|                     if (is_file($file)) { | ||||
|                         $this->plugin_files[ 'plugins_dir' ][ $_lower_filename ] = $file; | ||||
|                         include_once $file; | ||||
|                         return $file; | ||||
|                     } | ||||
|                     $this->plugin_files[ 'plugins_dir' ][ $_lower_filename ] = false; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if ($smarty->use_include_path) { | ||||
|             foreach ($_file_names as $_file_name) { | ||||
|                 // try PHP include_path | ||||
|                 $file = $smarty->ext->_getIncludePath->getIncludePath($_p_dirs, $_file_name, $smarty); | ||||
|                 $this->plugin_files[ 'include_path' ][ $_lower_filename ] = $file; | ||||
|                 if ($file !== false) { | ||||
|                     include_once $file; | ||||
|                     return $file; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // no plugin loaded | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,50 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method MustCompile | ||||
|  * | ||||
|  * Smarty_Internal_Template::mustCompile() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_MustCompile | ||||
| { | ||||
|     /** | ||||
|      * Valid for template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 2; | ||||
|  | ||||
|     /** | ||||
|      * 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 | ||||
|      * | ||||
|      * @param \Smarty_Internal_Template $_template | ||||
|      * | ||||
|      * @return bool | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function mustCompile(Smarty_Internal_Template $_template) | ||||
|     { | ||||
|         if (!$_template->source->exists) { | ||||
|             if ($_template->_isSubTpl()) { | ||||
|                 $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}"); | ||||
|         } | ||||
|         if ($_template->mustCompile === null) { | ||||
|             $_template->mustCompile = (!$_template->source->handler->uncompiled && | ||||
|                                        ($_template->smarty->force_compile || $_template->source->handler->recompiled || | ||||
|                                         !$_template->compiled->exists || ($_template->compile_check && | ||||
|                                                                           $_template->compiled->getTimeStamp() < | ||||
|                                                                           $_template->source->getTimeStamp()))); | ||||
|         } | ||||
|         return $_template->mustCompile; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,42 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterCacheResource | ||||
|  * | ||||
|  * Smarty::registerCacheResource() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterCacheResource | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers a resource to fetch a template | ||||
|      * | ||||
|      * @api  Smarty::registerCacheResource() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.cacheresource.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $name name of resource type | ||||
|      * @param \Smarty_CacheResource                                           $resource_handler | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      */ | ||||
|     public function registerCacheResource( | ||||
|         Smarty_Internal_TemplateBase $obj, | ||||
|         $name, | ||||
|         Smarty_CacheResource $resource_handler | ||||
|     ) { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $smarty->registered_cache_resources[ $name ] = $resource_handler; | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,46 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterClass | ||||
|  * | ||||
|  * Smarty::registerClass() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterClass | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers static classes to be used in templates | ||||
|      * | ||||
|      * @api  Smarty::registerClass() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.class.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $class_name | ||||
|      * @param string                                                          $class_impl the referenced PHP class to | ||||
|      *                                                                                    register | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function registerClass(Smarty_Internal_TemplateBase $obj, $class_name, $class_impl) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         // test if exists | ||||
|         if (!class_exists($class_impl)) { | ||||
|             throw new SmartyException("Undefined class '$class_impl' in register template class"); | ||||
|         } | ||||
|         // register the class | ||||
|         $smarty->registered_classes[ $class_name ] = $class_impl; | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,42 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterDefaultConfigHandler | ||||
|  * | ||||
|  * Smarty::registerDefaultConfigHandler() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterDefaultConfigHandler | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Register config default handler | ||||
|      * | ||||
|      * @api Smarty::registerDefaultConfigHandler() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param callable                                                        $callback class/method name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultConfigHandler(Smarty_Internal_TemplateBase $obj, $callback) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (is_callable($callback)) { | ||||
|             $smarty->default_config_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException('Default config handler not callable'); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,43 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterDefaultPluginHandler | ||||
|  * | ||||
|  * Smarty::registerDefaultPluginHandler() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterDefaultPluginHandler | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers a default plugin handler | ||||
|      * | ||||
|      * @api  Smarty::registerDefaultPluginHandler() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.default.plugin.handler.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param callable                                                        $callback class/method name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultPluginHandler(Smarty_Internal_TemplateBase $obj, $callback) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (is_callable($callback)) { | ||||
|             $smarty->default_plugin_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException("Default plugin handler '$callback' not callable"); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,88 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterDefaultTemplateHandler | ||||
|  * | ||||
|  * Smarty::registerDefaultTemplateHandler() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterDefaultTemplateHandler | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Register template default handler | ||||
|      * | ||||
|      * @api Smarty::registerDefaultTemplateHandler() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param callable                                                        $callback class/method name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws SmartyException              if $callback is not callable | ||||
|      */ | ||||
|     public function registerDefaultTemplateHandler(Smarty_Internal_TemplateBase $obj, $callback) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (is_callable($callback)) { | ||||
|             $smarty->default_template_handler_func = $callback; | ||||
|         } else { | ||||
|             throw new SmartyException('Default template handler not callable'); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * get default content from template or config resource handler | ||||
|      * | ||||
|      * @param Smarty_Template_Source $source | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public static function _getDefaultTemplate(Smarty_Template_Source $source) | ||||
|     { | ||||
|         if ($source->isConfig) { | ||||
|             $default_handler = $source->smarty->default_config_handler_func; | ||||
|         } else { | ||||
|             $default_handler = $source->smarty->default_template_handler_func; | ||||
|         } | ||||
|         $_content = $_timestamp = null; | ||||
|         $_return = call_user_func_array( | ||||
|             $default_handler, | ||||
|             array($source->type, $source->name, &$_content, &$_timestamp, $source->smarty) | ||||
|         ); | ||||
|         if (is_string($_return)) { | ||||
|             $source->exists = is_file($_return); | ||||
|             if ($source->exists) { | ||||
|                 $source->timestamp = filemtime($_return); | ||||
|             } else { | ||||
|                 throw new SmartyException( | ||||
|                     'Default handler: Unable to load ' . | ||||
|                     ($source->isConfig ? 'config' : 'template') . | ||||
|                     " default file '{$_return}' for '{$source->type}:{$source->name}'" | ||||
|                 ); | ||||
|             } | ||||
|             $source->name = $source->filepath = $_return; | ||||
|             $source->uid = sha1($source->filepath); | ||||
|         } elseif ($_return === true) { | ||||
|             $source->content = $_content; | ||||
|             $source->exists = true; | ||||
|             $source->uid = $source->name = sha1($_content); | ||||
|             $source->handler = Smarty_Resource::load($source->smarty, 'eval'); | ||||
|         } else { | ||||
|             $source->exists = false; | ||||
|             throw new SmartyException( | ||||
|                 'Default handler: No ' . ($source->isConfig ? 'config' : 'template') . | ||||
|                 " default content for '{$source->type}:{$source->name}'" | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,87 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterFilter | ||||
|  * | ||||
|  * Smarty::registerFilter() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterFilter | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Valid filter types | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $filterTypes = array('pre' => true, 'post' => true, 'output' => true, 'variable' => true); | ||||
|  | ||||
|     /** | ||||
|      * Registers a filter function | ||||
|      * | ||||
|      * @api  Smarty::registerFilter() | ||||
|      * | ||||
|      * @link http://www.smarty.net/docs/en/api.register.filter.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type filter type | ||||
|      * @param callback                                                        $callback | ||||
|      * @param string|null                                                     $name optional filter name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function registerFilter(Smarty_Internal_TemplateBase $obj, $type, $callback, $name = null) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $this->_checkFilterType($type); | ||||
|         $name = isset($name) ? $name : $this->_getFilterName($callback); | ||||
|         if (!is_callable($callback)) { | ||||
|             throw new SmartyException("{$type}filter '{$name}' not callable"); | ||||
|         } | ||||
|         $smarty->registered_filters[ $type ][ $name ] = $callback; | ||||
|         return $obj; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return internal filter name | ||||
|      * | ||||
|      * @param callback $function_name | ||||
|      * | ||||
|      * @return string   internal filter name | ||||
|      */ | ||||
|     public function _getFilterName($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 ]; | ||||
|         } elseif (is_string($function_name)) { | ||||
|             return $function_name; | ||||
|         } else { | ||||
|             return 'closure'; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if filter type is valid | ||||
|      * | ||||
|      * @param string $type | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function _checkFilterType($type) | ||||
|     { | ||||
|         if (!isset($this->filterTypes[ $type ])) { | ||||
|             throw new SmartyException("Illegal filter type '{$type}'"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,84 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterObject | ||||
|  * | ||||
|  * Smarty::registerObject() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterObject | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers object to be used in templates | ||||
|      * | ||||
|      * @api  Smarty::registerObject() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.object.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $object_name | ||||
|      * @param object                                                          $object                     the | ||||
|      *                                                                                                    referenced | ||||
|      *                                                                                                    PHP | ||||
|      *                                                                                                    object | ||||
|      *                                                                                                    to | ||||
|      *                                                                                                    register | ||||
|      * | ||||
|      * @param array                                                           $allowed_methods_properties list of | ||||
|      *                                                                                                    allowed | ||||
|      *                                                                                                    methods | ||||
|      *                                                                                                    (empty | ||||
|      *                                                                                                    = all) | ||||
|      * | ||||
|      * @param bool                                                            $format                     smarty | ||||
|      *                                                                                                    argument | ||||
|      *                                                                                                    format, | ||||
|      *                                                                                                    else | ||||
|      *                                                                                                    traditional | ||||
|      * | ||||
|      * @param array                                                           $block_methods              list of | ||||
|      *                                                                                                    block-methods | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function registerObject( | ||||
|         Smarty_Internal_TemplateBase $obj, | ||||
|         $object_name, | ||||
|         $object, | ||||
|         $allowed_methods_properties = array(), | ||||
|         $format = true, | ||||
|         $block_methods = array() | ||||
|     ) { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         // test if allowed methods callable | ||||
|         if (!empty($allowed_methods_properties)) { | ||||
|             foreach ((array)$allowed_methods_properties as $method) { | ||||
|                 if (!is_callable(array($object, $method)) && !property_exists($object, $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, $method))) { | ||||
|                     throw new SmartyException("Undefined method '$method' in registered object"); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         // register the object | ||||
|         $smarty->registered_objects[ $object_name ] = | ||||
|             array($object, (array)$allowed_methods_properties, (boolean)$format, (array)$block_methods); | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,58 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterPlugin | ||||
|  * | ||||
|  * Smarty::registerPlugin() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterPlugin | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers plugin to be used in templates | ||||
|      * | ||||
|      * @api  Smarty::registerPlugin() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.plugin.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type       plugin type | ||||
|      * @param string                                                          $name       name of template tag | ||||
|      * @param callback                                                        $callback   PHP callback to register | ||||
|      * @param bool                                                            $cacheable  if true (default) this | ||||
|      *                                                                                    function is cache able | ||||
|      * @param mixed                                                           $cache_attr caching attributes if any | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws SmartyException              when the plugin tag is invalid | ||||
|      */ | ||||
|     public function registerPlugin( | ||||
|         Smarty_Internal_TemplateBase $obj, | ||||
|         $type, | ||||
|         $name, | ||||
|         $callback, | ||||
|         $cacheable = true, | ||||
|         $cache_attr = null | ||||
|     ) { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (isset($smarty->registered_plugins[ $type ][ $name ])) { | ||||
|             throw new SmartyException("Plugin tag '{$name}' already registered"); | ||||
|         } elseif (!is_callable($callback)) { | ||||
|             throw new SmartyException("Plugin '{$name}' not callable"); | ||||
|         } elseif ($cacheable && $cache_attr) { | ||||
|             throw new SmartyException("Cannot set caching attributes for plugin '{$name}' when it is cacheable."); | ||||
|         } else { | ||||
|             $smarty->registered_plugins[ $type ][ $name ] = array($callback, (bool)$cacheable, (array)$cache_attr); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,46 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method RegisterResource | ||||
|  * | ||||
|  * Smarty::registerResource() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_RegisterResource | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers a resource to fetch a template | ||||
|      * | ||||
|      * @api  Smarty::registerResource() | ||||
|      * @link http://www.smarty.net/docs/en/api.register.resource.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $name             name of resource type | ||||
|      * @param Smarty_Resource|array                                           $resource_handler or instance of | ||||
|      *                                                                                          Smarty_Resource, | ||||
|      *                                                                                          or array of | ||||
|      *                                                                                          callbacks to | ||||
|      *                                                                                          handle | ||||
|      *                                                                                          resource | ||||
|      *                                                                                          (deprecated) | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      */ | ||||
|     public function registerResource(Smarty_Internal_TemplateBase $obj, $name, $resource_handler) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $smarty->registered_resources[ $name ] = | ||||
|             $resource_handler instanceof Smarty_Resource ? $resource_handler : array($resource_handler, false); | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,72 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method SetAutoloadFilters | ||||
|  * | ||||
|  * Smarty::setAutoloadFilters() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_SetAutoloadFilters | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Valid filter types | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $filterTypes = array('pre' => true, 'post' => true, 'output' => true, 'variable' => true); | ||||
|  | ||||
|     /** | ||||
|      * Set autoload filters | ||||
|      * | ||||
|      * @api Smarty::setAutoloadFilters() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array                                                           $filters filters to load automatically | ||||
|      * @param string                                                          $type    "pre", "output", … specify | ||||
|      *                                                                                 the filter type to set. | ||||
|      *                                                                                 Defaults to none treating | ||||
|      *                                                                                 $filters' keys as the | ||||
|      *                                                                                 appropriate types | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function setAutoloadFilters(Smarty_Internal_TemplateBase $obj, $filters, $type = null) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if ($type !== null) { | ||||
|             $this->_checkFilterType($type); | ||||
|             $smarty->autoload_filters[ $type ] = (array)$filters; | ||||
|         } else { | ||||
|             foreach ((array)$filters as $type => $value) { | ||||
|                 $this->_checkFilterType($type); | ||||
|             } | ||||
|             $smarty->autoload_filters = (array)$filters; | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if filter type is valid | ||||
|      * | ||||
|      * @param string $type | ||||
|      * | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function _checkFilterType($type) | ||||
|     { | ||||
|         if (!isset($this->filterTypes[ $type ])) { | ||||
|             throw new SmartyException("Illegal filter type '{$type}'"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method SetDebugTemplate | ||||
|  * | ||||
|  * Smarty::setDebugTemplate() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_SetDebugTemplate | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * set the debug template | ||||
|      * | ||||
|      * @api Smarty::setDebugTemplate() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $tpl_name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws SmartyException if file is not readable | ||||
|      */ | ||||
|     public function setDebugTemplate(Smarty_Internal_TemplateBase $obj, $tpl_name) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (!is_readable($tpl_name)) { | ||||
|             throw new SmartyException("Unknown file '{$tpl_name}'"); | ||||
|         } | ||||
|         $smarty->debug_tpl = $tpl_name; | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,38 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method SetDefaultModifiers | ||||
|  * | ||||
|  * Smarty::setDefaultModifiers() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_SetDefaultModifiers | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Set default modifiers | ||||
|      * | ||||
|      * @api Smarty::setDefaultModifiers() | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param array|string                                                    $modifiers modifier or list of modifiers | ||||
|      *                                                                                   to set | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      */ | ||||
|     public function setDefaultModifiers(Smarty_Internal_TemplateBase $obj, $modifiers) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $smarty->default_modifiers = (array)$modifiers; | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,43 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method UnloadFilter | ||||
|  * | ||||
|  * Smarty::unloadFilter() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_UnloadFilter extends Smarty_Internal_Method_LoadFilter | ||||
| { | ||||
|     /** | ||||
|      * load a filter of specified type and name | ||||
|      * | ||||
|      * @api  Smarty::unloadFilter() | ||||
|      * | ||||
|      * @link http://www.smarty.net/docs/en/api.unload.filter.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type filter type | ||||
|      * @param string                                                          $name filter name | ||||
|      * | ||||
|      * @return Smarty_Internal_TemplateBase | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function unloadFilter(Smarty_Internal_TemplateBase $obj, $type, $name) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $this->_checkFilterType($type); | ||||
|         if (isset($smarty->registered_filters[ $type ])) { | ||||
|             $_filter_name = "smarty_{$type}filter_{$name}"; | ||||
|             if (isset($smarty->registered_filters[ $type ][ $_filter_name ])) { | ||||
|                 unset($smarty->registered_filters[ $type ][ $_filter_name ]); | ||||
|                 if (empty($smarty->registered_filters[ $type ])) { | ||||
|                     unset($smarty->registered_filters[ $type ]); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,40 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method UnregisterCacheResource | ||||
|  * | ||||
|  * Smarty::unregisterCacheResource() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_UnregisterCacheResource | ||||
| { | ||||
|     /** | ||||
|      * Valid for Smarty and template object | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     public $objMap = 3; | ||||
|  | ||||
|     /** | ||||
|      * Registers a resource to fetch a template | ||||
|      * | ||||
|      * @api  Smarty::unregisterCacheResource() | ||||
|      * @link http://www.smarty.net/docs/en/api.unregister.cacheresource.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param                                                                 $name | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      */ | ||||
|     public function unregisterCacheResource(Smarty_Internal_TemplateBase $obj, $name) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         if (isset($smarty->registered_cache_resources[ $name ])) { | ||||
|             unset($smarty->registered_cache_resources[ $name ]); | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,43 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Smarty Method UnregisterFilter | ||||
|  * | ||||
|  * Smarty::unregisterFilter() method | ||||
|  * | ||||
|  * @package    Smarty | ||||
|  * @subpackage PluginsInternal | ||||
|  * @author     Uwe Tews | ||||
|  */ | ||||
| class Smarty_Internal_Method_UnregisterFilter extends Smarty_Internal_Method_RegisterFilter | ||||
| { | ||||
|     /** | ||||
|      * Unregisters a filter function | ||||
|      * | ||||
|      * @api  Smarty::unregisterFilter() | ||||
|      * | ||||
|      * @link http://www.smarty.net/docs/en/api.unregister.filter.tpl | ||||
|      * | ||||
|      * @param \Smarty_Internal_TemplateBase|\Smarty_Internal_Template|\Smarty $obj | ||||
|      * @param string                                                          $type filter type | ||||
|      * @param callback|string                                                 $callback | ||||
|      * | ||||
|      * @return \Smarty|\Smarty_Internal_Template | ||||
|      * @throws \SmartyException | ||||
|      */ | ||||
|     public function unregisterFilter(Smarty_Internal_TemplateBase $obj, $type, $callback) | ||||
|     { | ||||
|         $smarty = $obj->_getSmartyObj(); | ||||
|         $this->_checkFilterType($type); | ||||
|         if (isset($smarty->registered_filters[ $type ])) { | ||||
|             $name = is_string($callback) ? $callback : $this->_getFilterName($callback); | ||||
|             if (isset($smarty->registered_filters[ $type ][ $name ])) { | ||||
|                 unset($smarty->registered_filters[ $type ][ $name ]); | ||||
|                 if (empty($smarty->registered_filters[ $type ])) { | ||||
|                     unset($smarty->registered_filters[ $type ]); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $obj; | ||||
|     } | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user