Second pass at adding key files
This commit is contained in:
		
							
								
								
									
										815
									
								
								site/stackreach/libs/Smarty.class.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										815
									
								
								site/stackreach/libs/Smarty.class.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,815 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project:     Smarty: the PHP compiling template engine
 | 
			
		||||
 * File:        Smarty.class.php
 | 
			
		||||
 * SVN:         $Id: Smarty.class.php 3895 2010-12-31 13:47:12Z uwe.tews@googlemail.com $
 | 
			
		||||
 * 
 | 
			
		||||
 * This library is free software; you can redistribute it and/or
 | 
			
		||||
 * modify it under the terms of the GNU Lesser General Public
 | 
			
		||||
 * License as published by the Free Software Foundation; either
 | 
			
		||||
 * version 2.1 of the License, or (at your option) any later version.
 | 
			
		||||
 * 
 | 
			
		||||
 * This library is distributed in the hope that it will be useful,
 | 
			
		||||
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
			
		||||
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
			
		||||
 * Lesser General Public License for more details.
 | 
			
		||||
 * 
 | 
			
		||||
 * You should have received a copy of the GNU Lesser General Public
 | 
			
		||||
 * License along with this library; if not, write to the Free Software
 | 
			
		||||
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | 
			
		||||
 * 
 | 
			
		||||
 * For questions, help, comments, discussion, etc., please join the
 | 
			
		||||
 * Smarty mailing list. Send a blank e-mail to
 | 
			
		||||
 * smarty-discussion-subscribe@googlegroups.com
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://www.smarty.net/
 | 
			
		||||
 * @copyright 2008 New Digital Group, Inc.
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @version 3.0.7
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * define shorthand directory separator constant
 | 
			
		||||
 */
 | 
			
		||||
if (!defined('DS')) {
 | 
			
		||||
    define('DS', DIRECTORY_SEPARATOR);
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * set SMARTY_DIR to absolute path to Smarty library files.
 | 
			
		||||
 * Sets SMARTY_DIR only if user application has not already defined it.
 | 
			
		||||
 */
 | 
			
		||||
if (!defined('SMARTY_DIR')) {
 | 
			
		||||
    define('SMARTY_DIR', dirname(__FILE__) . DS);
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * set SMARTY_SYSPLUGINS_DIR to absolute path to Smarty internal plugins.
 | 
			
		||||
 * Sets SMARTY_SYSPLUGINS_DIR only if user application has not already defined it.
 | 
			
		||||
 */
 | 
			
		||||
if (!defined('SMARTY_SYSPLUGINS_DIR')) {
 | 
			
		||||
    define('SMARTY_SYSPLUGINS_DIR', SMARTY_DIR . 'sysplugins' . DS);
 | 
			
		||||
} 
 | 
			
		||||
if (!defined('SMARTY_PLUGINS_DIR')) {
 | 
			
		||||
    define('SMARTY_PLUGINS_DIR', SMARTY_DIR . 'plugins' . DS);
 | 
			
		||||
} 
 | 
			
		||||
if (!defined('SMARTY_RESOURCE_CHAR_SET')) {
 | 
			
		||||
    define('SMARTY_RESOURCE_CHAR_SET', 'UTF-8');
 | 
			
		||||
} 
 | 
			
		||||
if (!defined('SMARTY_RESOURCE_DATE_FORMAT')) {
 | 
			
		||||
    define('SMARTY_RESOURCE_DATE_FORMAT', '%b %e, %Y');
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * register the class autoloader
 | 
			
		||||
 */
 | 
			
		||||
if (!defined('SMARTY_SPL_AUTOLOAD')) {
 | 
			
		||||
    define('SMARTY_SPL_AUTOLOAD', 0);
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
if (SMARTY_SPL_AUTOLOAD && set_include_path(get_include_path() . PATH_SEPARATOR . SMARTY_SYSPLUGINS_DIR) !== false) {
 | 
			
		||||
    $registeredAutoLoadFunctions = spl_autoload_functions();
 | 
			
		||||
    if (!isset($registeredAutoLoadFunctions['spl_autoload'])) {
 | 
			
		||||
        spl_autoload_register();
 | 
			
		||||
    } 
 | 
			
		||||
} else {
 | 
			
		||||
    spl_autoload_register('smartyAutoload');
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This is the main Smarty class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty extends Smarty_Internal_Data {
 | 
			
		||||
	/**
 | 
			
		||||
	* constant definitions
 | 
			
		||||
	*/
 | 
			
		||||
    // smarty version
 | 
			
		||||
    const SMARTY_VERSION = 'Smarty-3.0.7'; 
 | 
			
		||||
  	//define variable scopes
 | 
			
		||||
	const SCOPE_LOCAL = 0;
 | 
			
		||||
	const SCOPE_PARENT = 1;
 | 
			
		||||
	const SCOPE_ROOT = 2;
 | 
			
		||||
	const SCOPE_GLOBAL = 3;
 | 
			
		||||
	// define caching modes
 | 
			
		||||
	const CACHING_OFF = 0;
 | 
			
		||||
	const CACHING_LIFETIME_CURRENT = 1;
 | 
			
		||||
	const CACHING_LIFETIME_SAVED = 2;
 | 
			
		||||
	/** modes for handling of "<?php ... ?>" tags in templates. **/
 | 
			
		||||
	const PHP_PASSTHRU = 0; //-> print tags as plain text
 | 
			
		||||
	const PHP_QUOTE = 1; //-> escape tags as entities
 | 
			
		||||
	const PHP_REMOVE = 2; //-> escape tags as entities
 | 
			
		||||
	const PHP_ALLOW = 3; //-> escape tags as entities
 | 
			
		||||
	// filter types
 | 
			
		||||
	const FILTER_POST = 'post';
 | 
			
		||||
	const FILTER_PRE = 'pre';
 | 
			
		||||
	const FILTER_OUTPUT = 'output';
 | 
			
		||||
	const FILTER_VARIABLE = 'variable';
 | 
			
		||||
	// plugin types
 | 
			
		||||
	const PLUGIN_FUNCTION = 'function';
 | 
			
		||||
	const PLUGIN_BLOCK = 'block';
 | 
			
		||||
	const PLUGIN_COMPILER = 'compiler';
 | 
			
		||||
	const PLUGIN_MODIFIER = 'modifier';
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* static variables
 | 
			
		||||
	*/
 | 
			
		||||
    // assigned global tpl vars
 | 
			
		||||
    static $global_tpl_vars = array(); 
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* variables
 | 
			
		||||
	*/
 | 
			
		||||
    // auto literal on delimiters with whitspace
 | 
			
		||||
    public $auto_literal = true; 
 | 
			
		||||
    // display error on not assigned variables
 | 
			
		||||
    public $error_unassigned = false; 
 | 
			
		||||
    // template directory
 | 
			
		||||
    public $template_dir = null; 
 | 
			
		||||
    // default template handler
 | 
			
		||||
    public $default_template_handler_func = null; 
 | 
			
		||||
    // compile directory
 | 
			
		||||
    public $compile_dir = null; 
 | 
			
		||||
    // plugins directory
 | 
			
		||||
    public $plugins_dir = null; 
 | 
			
		||||
    // cache directory
 | 
			
		||||
    public $cache_dir = null; 
 | 
			
		||||
    // config directory
 | 
			
		||||
    public $config_dir = null; 
 | 
			
		||||
    // force template compiling?
 | 
			
		||||
    public $force_compile = false; 
 | 
			
		||||
    // check template for modifications?
 | 
			
		||||
    public $compile_check = true; 
 | 
			
		||||
    // locking concurrent compiles
 | 
			
		||||
    public $compile_locking = true; 
 | 
			
		||||
    // use sub dirs for compiled/cached files?
 | 
			
		||||
    public $use_sub_dirs = false; 
 | 
			
		||||
    // compile_error?
 | 
			
		||||
    public $compile_error = false; 
 | 
			
		||||
    // caching enabled
 | 
			
		||||
    public $caching = false; 
 | 
			
		||||
    // merge compiled includes
 | 
			
		||||
    public $merge_compiled_includes = false; 
 | 
			
		||||
    // cache lifetime
 | 
			
		||||
    public $cache_lifetime = 3600; 
 | 
			
		||||
    // force cache file creation
 | 
			
		||||
    public $force_cache = false; 
 | 
			
		||||
    // cache_id
 | 
			
		||||
    public $cache_id = null; 
 | 
			
		||||
    // compile_id
 | 
			
		||||
    public $compile_id = null; 
 | 
			
		||||
    // template delimiters
 | 
			
		||||
    public $left_delimiter = "{";
 | 
			
		||||
    public $right_delimiter = "}"; 
 | 
			
		||||
    // security
 | 
			
		||||
    public $security_class = 'Smarty_Security';
 | 
			
		||||
    public $security_policy = null;
 | 
			
		||||
    public $php_handling = self::PHP_PASSTHRU;
 | 
			
		||||
    public $allow_php_tag = true;
 | 
			
		||||
    public $allow_php_templates = false;
 | 
			
		||||
    public $direct_access_security = true; 
 | 
			
		||||
    public $trusted_dir = array();
 | 
			
		||||
    // debug mode
 | 
			
		||||
    public $debugging = false;
 | 
			
		||||
    public $debugging_ctrl = 'NONE';
 | 
			
		||||
    public $smarty_debug_id = 'SMARTY_DEBUG';
 | 
			
		||||
    public $debug_tpl = null; 
 | 
			
		||||
    // When set, smarty does uses this value as error_reporting-level.
 | 
			
		||||
    public $error_reporting = null; 
 | 
			
		||||
    // config var settings
 | 
			
		||||
    public $config_overwrite = true; //Controls whether variables with the same name overwrite each other.
 | 
			
		||||
    public $config_booleanize = true; //Controls whether config values of on/true/yes and off/false/no get converted to boolean
 | 
			
		||||
    public $config_read_hidden = false; //Controls whether hidden config sections/vars are read from the file.                                                      
 | 
			
		||||
    // config vars
 | 
			
		||||
    public $config_vars = array(); 
 | 
			
		||||
    // assigned tpl vars
 | 
			
		||||
    public $tpl_vars = array(); 
 | 
			
		||||
    // dummy parent object
 | 
			
		||||
    public $parent = null; 
 | 
			
		||||
    // global template functions
 | 
			
		||||
    public $template_functions = array(); 
 | 
			
		||||
    // resource type used if none given
 | 
			
		||||
    public $default_resource_type = 'file'; 
 | 
			
		||||
    // caching type
 | 
			
		||||
    public $caching_type = 'file'; 
 | 
			
		||||
    // internal cache resource types
 | 
			
		||||
    public $cache_resource_types = array('file'); 
 | 
			
		||||
    // internal config properties
 | 
			
		||||
    public $properties = array(); 
 | 
			
		||||
    // config type
 | 
			
		||||
    public $default_config_type = 'file'; 
 | 
			
		||||
    // cached template objects
 | 
			
		||||
    public $template_objects = null; 
 | 
			
		||||
    // check If-Modified-Since headers
 | 
			
		||||
    public $cache_modified_check = false; 
 | 
			
		||||
    // registered plugins
 | 
			
		||||
    public $registered_plugins = array(); 
 | 
			
		||||
    // plugin search order
 | 
			
		||||
    public $plugin_search_order = array('function', 'block', 'compiler', 'class'); 
 | 
			
		||||
    // registered objects
 | 
			
		||||
    public $registered_objects = array(); 
 | 
			
		||||
    // registered classes
 | 
			
		||||
    public $registered_classes = array(); 
 | 
			
		||||
    // registered filters
 | 
			
		||||
    public $registered_filters = array(); 
 | 
			
		||||
    // registered resources
 | 
			
		||||
    public $registered_resources = array(); 
 | 
			
		||||
    // autoload filter
 | 
			
		||||
    public $autoload_filters = array(); 
 | 
			
		||||
    // status of filter on variable output
 | 
			
		||||
    public $variable_filter = true; 
 | 
			
		||||
    // default modifier
 | 
			
		||||
    public $default_modifiers = array(); 
 | 
			
		||||
    // global internal smarty  vars
 | 
			
		||||
    static $_smarty_vars = array(); 
 | 
			
		||||
    // start time for execution time calculation
 | 
			
		||||
    public $start_time = 0; 
 | 
			
		||||
    // default file permissions
 | 
			
		||||
    public $_file_perms = 0644; 
 | 
			
		||||
    // default dir permissions
 | 
			
		||||
    public $_dir_perms = 0771; 
 | 
			
		||||
    // block tag hierarchy
 | 
			
		||||
    public $_tag_stack = array(); 
 | 
			
		||||
    // flag if {block} tag is compiled for template inheritance
 | 
			
		||||
    public $inheritance = false;
 | 
			
		||||
    // generate deprecated function call notices?
 | 
			
		||||
    public $deprecation_notices = true;
 | 
			
		||||
    // Smarty 2 BC
 | 
			
		||||
    public $_version = self::SMARTY_VERSION;
 | 
			
		||||
    // self pointer to Smarty object
 | 
			
		||||
    public $smarty;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Class constructor, initializes basic smarty properties
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct()
 | 
			
		||||
    { 
 | 
			
		||||
		// selfpointer need by some other class methods
 | 
			
		||||
		$this->smarty = $this;
 | 
			
		||||
        if (is_callable('mb_internal_encoding')) {
 | 
			
		||||
            mb_internal_encoding(SMARTY_RESOURCE_CHAR_SET);
 | 
			
		||||
        } 
 | 
			
		||||
        $this->start_time = microtime(true); 
 | 
			
		||||
        // set default dirs
 | 
			
		||||
        $this->template_dir = array('.' . DS . 'templates' . DS);
 | 
			
		||||
        $this->compile_dir = '.' . DS . 'templates_c' . DS;
 | 
			
		||||
        $this->plugins_dir = array(SMARTY_PLUGINS_DIR);
 | 
			
		||||
        $this->cache_dir = '.' . DS . 'cache' . DS;
 | 
			
		||||
        $this->config_dir = '.' . DS . 'configs' . DS;
 | 
			
		||||
        $this->debug_tpl = SMARTY_DIR . 'debug.tpl';
 | 
			
		||||
        if (isset($_SERVER['SCRIPT_NAME'])) {
 | 
			
		||||
            $this->assignGlobal('SCRIPT_NAME', $_SERVER['SCRIPT_NAME']);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Class destructor
 | 
			
		||||
     */
 | 
			
		||||
    public function __destruct()
 | 
			
		||||
    { 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * fetches a rendered Smarty template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $template the resource handle of the template file or template object
 | 
			
		||||
     * @param mixed $cache_id cache id to be used with this template
 | 
			
		||||
     * @param mixed $compile_id compile id to be used with this template
 | 
			
		||||
     * @param object $ |null $parent next higher level of Smarty variables
 | 
			
		||||
     * @return string rendered template output
 | 
			
		||||
     */
 | 
			
		||||
    public function fetch($template, $cache_id = null, $compile_id = null, $parent = null, $display = false)
 | 
			
		||||
    {
 | 
			
		||||
        if (!empty($cache_id) && is_object($cache_id)) {
 | 
			
		||||
            $parent = $cache_id;
 | 
			
		||||
            $cache_id = null;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($parent === null) {
 | 
			
		||||
            // get default Smarty data object
 | 
			
		||||
            $parent = $this;
 | 
			
		||||
        } 
 | 
			
		||||
        // create template object if necessary
 | 
			
		||||
        ($template instanceof $this->template_class)? $_template = $template :
 | 
			
		||||
        $_template = $this->createTemplate ($template, $cache_id, $compile_id, $parent, false);
 | 
			
		||||
        if (isset($this->error_reporting)) {
 | 
			
		||||
        	$_smarty_old_error_level = error_reporting($this->error_reporting);
 | 
			
		||||
    	}
 | 
			
		||||
    	// check URL debugging control
 | 
			
		||||
        if (!$this->debugging && $this->debugging_ctrl == 'URL') {
 | 
			
		||||
            if (isset($_SERVER['QUERY_STRING'])) {
 | 
			
		||||
                $_query_string = $_SERVER['QUERY_STRING'];
 | 
			
		||||
            } else {
 | 
			
		||||
                $_query_string = '';
 | 
			
		||||
            } 
 | 
			
		||||
            if (false !== strpos($_query_string, $this->smarty_debug_id)) {
 | 
			
		||||
                if (false !== strpos($_query_string, $this->smarty_debug_id . '=on')) {
 | 
			
		||||
                    // enable debugging for this browser session
 | 
			
		||||
                    setcookie('SMARTY_DEBUG', true);
 | 
			
		||||
                    $this->debugging = true;
 | 
			
		||||
                } elseif (false !== strpos($_query_string, $this->smarty_debug_id . '=off')) {
 | 
			
		||||
                    // disable debugging for this browser session
 | 
			
		||||
                    setcookie('SMARTY_DEBUG', false);
 | 
			
		||||
                    $this->debugging = false;
 | 
			
		||||
                } else {
 | 
			
		||||
                    // enable debugging for this page
 | 
			
		||||
                    $this->debugging = true;
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                if (isset($_COOKIE['SMARTY_DEBUG'])) {
 | 
			
		||||
                    $this->debugging = true;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // obtain data for cache modified check
 | 
			
		||||
        if ($this->cache_modified_check && $this->caching && $display) {
 | 
			
		||||
            $_isCached = $_template->isCached() && !$_template->has_nocache_code;
 | 
			
		||||
            if ($_isCached) {
 | 
			
		||||
                $_gmt_mtime = gmdate('D, d M Y H:i:s', $_template->getCachedTimestamp()) . ' GMT';
 | 
			
		||||
            } else {
 | 
			
		||||
                $_gmt_mtime = '';
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // return rendered template
 | 
			
		||||
        if ((!$this->caching || $_template->resource_object->isEvaluated) && (isset($this->autoload_filters['output']) || isset($this->registered_filters['output']))) {
 | 
			
		||||
            $_output = Smarty_Internal_Filter_Handler::runFilter('output', $_template->getRenderedTemplate(), $_template);
 | 
			
		||||
        } else {
 | 
			
		||||
            $_output = $_template->getRenderedTemplate();
 | 
			
		||||
        } 
 | 
			
		||||
        $_template->rendered_content = null;
 | 
			
		||||
        if (isset($this->error_reporting)) {
 | 
			
		||||
        	error_reporting($_smarty_old_error_level);
 | 
			
		||||
        } 
 | 
			
		||||
        // display or fetch
 | 
			
		||||
        if ($display) {
 | 
			
		||||
            if ($this->caching && $this->cache_modified_check) {
 | 
			
		||||
                $_last_modified_date = @substr($_SERVER['HTTP_IF_MODIFIED_SINCE'], 0, strpos($_SERVER['HTTP_IF_MODIFIED_SINCE'], 'GMT') + 3);
 | 
			
		||||
                if ($_isCached && $_gmt_mtime == $_last_modified_date) {
 | 
			
		||||
                    if (php_sapi_name() == 'cgi')
 | 
			
		||||
                        header('Status: 304 Not Modified');
 | 
			
		||||
                    else
 | 
			
		||||
                        header('HTTP/1.1 304 Not Modified');
 | 
			
		||||
                } else {
 | 
			
		||||
                    header('Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->getCachedTimestamp()) . ' GMT');
 | 
			
		||||
                    echo $_output;
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                echo $_output;
 | 
			
		||||
            } 
 | 
			
		||||
            // debug output
 | 
			
		||||
            if ($this->debugging) {
 | 
			
		||||
                Smarty_Internal_Debug::display_debug($this);
 | 
			
		||||
            } 
 | 
			
		||||
            return;
 | 
			
		||||
        } else {
 | 
			
		||||
            // return fetched content
 | 
			
		||||
            return $_output;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * displays a Smarty template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $ |object $template the resource handle of the template file  or template object
 | 
			
		||||
     * @param mixed $cache_id cache id to be used with this template
 | 
			
		||||
     * @param mixed $compile_id compile id to be used with this template
 | 
			
		||||
     * @param object $parent next higher level of Smarty variables
 | 
			
		||||
     */
 | 
			
		||||
    public function display($template, $cache_id = null, $compile_id = null, $parent = null)
 | 
			
		||||
    { 
 | 
			
		||||
        // display template
 | 
			
		||||
        $this->fetch ($template, $cache_id, $compile_id, $parent, true);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * test if cache i valid
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $ |object $template the resource handle of the template file or template object
 | 
			
		||||
     * @param mixed $cache_id cache id to be used with this template
 | 
			
		||||
     * @param mixed $compile_id compile id to be used with this template
 | 
			
		||||
     * @param object $parent next higher level of Smarty variables
 | 
			
		||||
     * @return boolean cache status
 | 
			
		||||
     */
 | 
			
		||||
    public function isCached($template, $cache_id = null, $compile_id = null, $parent = null)
 | 
			
		||||
    {
 | 
			
		||||
    	if ($parent === null) {
 | 
			
		||||
    		$parent = $this;
 | 
			
		||||
    	}
 | 
			
		||||
        if (!($template instanceof $this->template_class)) {
 | 
			
		||||
            $template = $this->createTemplate ($template, $cache_id, $compile_id, $parent, false);
 | 
			
		||||
        } 
 | 
			
		||||
        // return cache status of template
 | 
			
		||||
        return $template->isCached();
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates a data object
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $parent next higher level of Smarty variables
 | 
			
		||||
     * @returns object data object
 | 
			
		||||
     */
 | 
			
		||||
    public function createData($parent = null)
 | 
			
		||||
    {
 | 
			
		||||
        return new Smarty_Data($parent, $this);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates a template object
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $template the resource handle of the template file
 | 
			
		||||
     * @param mixed $cache_id cache id to be used with this template
 | 
			
		||||
     * @param mixed $compile_id compile id to be used with this template
 | 
			
		||||
     * @param object $parent next higher level of Smarty variables
 | 
			
		||||
     * @param boolean $do_clone flag is Smarty object shall be cloned
 | 
			
		||||
     * @returns object template object
 | 
			
		||||
     */
 | 
			
		||||
    public function createTemplate($template, $cache_id = null, $compile_id = null, $parent = null, $do_clone = true)
 | 
			
		||||
    {
 | 
			
		||||
        if (!empty($cache_id) && (is_object($cache_id) || is_array($cache_id))) {
 | 
			
		||||
            $parent = $cache_id;
 | 
			
		||||
            $cache_id = null;
 | 
			
		||||
        } 
 | 
			
		||||
        if (!empty($parent) && is_array($parent)) {
 | 
			
		||||
            $data = $parent;
 | 
			
		||||
            $parent = null;
 | 
			
		||||
        } else {
 | 
			
		||||
            $data = null;
 | 
			
		||||
        } 
 | 
			
		||||
        if (!is_object($template)) {
 | 
			
		||||
            // we got a template resource
 | 
			
		||||
            // already in template cache?
 | 
			
		||||
            $_templateId =  sha1($template . $cache_id . $compile_id);
 | 
			
		||||
            if (isset($this->template_objects[$_templateId]) && $this->caching) {
 | 
			
		||||
                // return cached template object
 | 
			
		||||
                $tpl = $this->template_objects[$_templateId];
 | 
			
		||||
            } else {
 | 
			
		||||
                // create new template object
 | 
			
		||||
                if ($do_clone) {
 | 
			
		||||
                	$tpl = new $this->template_class($template, clone $this, $parent, $cache_id, $compile_id);
 | 
			
		||||
                } else {
 | 
			
		||||
                	$tpl = new $this->template_class($template, $this, $parent, $cache_id, $compile_id);
 | 
			
		||||
                }
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            // just return a copy of template class
 | 
			
		||||
            $tpl = $template;
 | 
			
		||||
        } 
 | 
			
		||||
        // fill data if present
 | 
			
		||||
        if (!empty($data) && is_array($data)) {
 | 
			
		||||
            // set up variable values
 | 
			
		||||
            foreach ($data as $_key => $_val) {
 | 
			
		||||
                $tpl->tpl_vars[$_key] = new Smarty_variable($_val);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $tpl;
 | 
			
		||||
    } 
 | 
			
		||||
    
 | 
			
		||||
     
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Check if a template resource exists
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $resource_name template name
 | 
			
		||||
     * @return boolean status
 | 
			
		||||
     */
 | 
			
		||||
    function templateExists($resource_name)
 | 
			
		||||
    { 
 | 
			
		||||
        // create template object
 | 
			
		||||
        $save = $this->template_objects;
 | 
			
		||||
        $tpl = new $this->template_class($resource_name, $this); 
 | 
			
		||||
        // check if it does exists
 | 
			
		||||
        $result = $tpl->isExisting();
 | 
			
		||||
        $this->template_objects = $save;
 | 
			
		||||
        return $result;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns a single or all global  variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $smarty 
 | 
			
		||||
     * @param string $varname variable name or null
 | 
			
		||||
     * @return string variable value or or array of variables
 | 
			
		||||
     */
 | 
			
		||||
    function getGlobal($varname = null)
 | 
			
		||||
    {
 | 
			
		||||
        if (isset($varname)) {
 | 
			
		||||
            if (isset(self::$global_tpl_vars[$varname])) {
 | 
			
		||||
                return self::$global_tpl_vars[$varname]->value;
 | 
			
		||||
            } else {
 | 
			
		||||
                return '';
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            $_result = array();
 | 
			
		||||
            foreach (self::$global_tpl_vars AS $key => $var) {
 | 
			
		||||
                $_result[$key] = $var->value;
 | 
			
		||||
            } 
 | 
			
		||||
            return $_result;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
    * Empty cache folder
 | 
			
		||||
    * 
 | 
			
		||||
    * @param integer $exp_time expiration time
 | 
			
		||||
    * @param string $type resource type
 | 
			
		||||
    * @return integer number of cache files deleted
 | 
			
		||||
    */
 | 
			
		||||
    function clearAllCache($exp_time = null, $type = null)
 | 
			
		||||
    { 
 | 
			
		||||
       // load cache resource and call clearAll
 | 
			
		||||
        return $this->loadCacheResource($type)->clearAll($exp_time);
 | 
			
		||||
    }        
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
    * Empty cache for a specific template
 | 
			
		||||
    * 
 | 
			
		||||
    * @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 integer number of cache files deleted
 | 
			
		||||
    */
 | 
			
		||||
    function clearCache($template_name, $cache_id = null, $compile_id = null, $exp_time = null, $type = null)
 | 
			
		||||
    { 
 | 
			
		||||
       // load cache resource and call clear
 | 
			
		||||
        return $this->loadCacheResource($type)->clear($template_name, $cache_id, $compile_id, $exp_time);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Loads security class and enables security
 | 
			
		||||
     */
 | 
			
		||||
    public function enableSecurity($security_class = null)
 | 
			
		||||
    {
 | 
			
		||||
    	if ($security_class instanceof Smarty_Security) {
 | 
			
		||||
			$this->security_policy = $security_class;
 | 
			
		||||
			return;
 | 
			
		||||
		}
 | 
			
		||||
    	if ($security_class == null) {
 | 
			
		||||
    		$security_class = $this->security_class;
 | 
			
		||||
    	}
 | 
			
		||||
        if (class_exists($security_class)) {
 | 
			
		||||
            $this->security_policy = new $security_class($this);
 | 
			
		||||
        } else {
 | 
			
		||||
            throw new SmartyException("Security class '$security_class' is not defined");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Disable security
 | 
			
		||||
     */
 | 
			
		||||
    public function disableSecurity()
 | 
			
		||||
    {
 | 
			
		||||
       $this->security_policy = null;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
    * Loads cache resource.
 | 
			
		||||
    * 
 | 
			
		||||
    * @param string $type cache resource type
 | 
			
		||||
    * @return object of cache resource
 | 
			
		||||
    */
 | 
			
		||||
    public function loadCacheResource($type = null) {
 | 
			
		||||
        if (!isset($type)) {
 | 
			
		||||
            $type = $this->caching_type;
 | 
			
		||||
        } 
 | 
			
		||||
        if (in_array($type, $this->cache_resource_types)) {
 | 
			
		||||
            $cache_resource_class = 'Smarty_Internal_CacheResource_' . ucfirst($type);
 | 
			
		||||
            return new $cache_resource_class($this);
 | 
			
		||||
        } 
 | 
			
		||||
        else {
 | 
			
		||||
            // try plugins dir
 | 
			
		||||
            $cache_resource_class = 'Smarty_CacheResource_' . ucfirst($type);
 | 
			
		||||
            if ($this->loadPlugin($cache_resource_class)) {
 | 
			
		||||
                return new $cache_resource_class($this);
 | 
			
		||||
            } 
 | 
			
		||||
            else {
 | 
			
		||||
                throw new SmartyException("Unable to load cache resource '{$type}'");
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Set template directory
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $ |array $template_dir folder(s) of template sorces
 | 
			
		||||
     */
 | 
			
		||||
    public function setTemplateDir($template_dir)
 | 
			
		||||
    {
 | 
			
		||||
        $this->template_dir = (array)$template_dir;
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Adds template directory(s) to existing ones
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $ |array $template_dir folder(s) of template sources
 | 
			
		||||
     */
 | 
			
		||||
    public function addTemplateDir($template_dir)
 | 
			
		||||
    {
 | 
			
		||||
        $this->template_dir = array_unique(array_merge((array)$this->template_dir, (array)$template_dir));
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 
 | 
			
		||||
    /**
 | 
			
		||||
     * Adds directory of plugin files
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $smarty 
 | 
			
		||||
     * @param string $ |array $ plugins folder
 | 
			
		||||
     * @return 
 | 
			
		||||
     */
 | 
			
		||||
    function addPluginsDir($plugins_dir)
 | 
			
		||||
    {
 | 
			
		||||
        $this->plugins_dir = array_unique(array_merge((array)$this->plugins_dir, (array)$plugins_dir));
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * return a reference to a registered object
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $name object name
 | 
			
		||||
     * @return object 
 | 
			
		||||
     */
 | 
			
		||||
    function getRegisteredObject($name)
 | 
			
		||||
    {
 | 
			
		||||
        if (!isset($this->registered_objects[$name]))
 | 
			
		||||
            throw new SmartyException("'$name' is not a registered object");
 | 
			
		||||
 | 
			
		||||
        if (!is_object($this->registered_objects[$name][0]))
 | 
			
		||||
            throw new SmartyException("registered '$name' is not an object");
 | 
			
		||||
 | 
			
		||||
        return $this->registered_objects[$name][0];
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * return name of debugging template
 | 
			
		||||
     * 
 | 
			
		||||
     * @return string 
 | 
			
		||||
     */
 | 
			
		||||
    function getDebugTemplate()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->debug_tpl;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * set the debug template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $tpl_name 
 | 
			
		||||
     * @return bool 
 | 
			
		||||
     */
 | 
			
		||||
    function setDebugTemplate($tpl_name)
 | 
			
		||||
    {
 | 
			
		||||
        return $this->debug_tpl = $tpl_name;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Takes unknown classes and loads plugin files for them
 | 
			
		||||
     * class name format: Smarty_PluginType_PluginName
 | 
			
		||||
     * plugin filename format: plugintype.pluginname.php
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $plugin_name class plugin name to load
 | 
			
		||||
     * @return string |boolean filepath of loaded file or false
 | 
			
		||||
     */
 | 
			
		||||
    public function loadPlugin($plugin_name, $check = true)
 | 
			
		||||
    { 
 | 
			
		||||
        // if function or class exists, exit silently (already loaded)
 | 
			
		||||
        if ($check && (is_callable($plugin_name) || class_exists($plugin_name, false)))
 | 
			
		||||
            return true; 
 | 
			
		||||
        // Plugin name is expected to be: Smarty_[Type]_[Name]
 | 
			
		||||
        $_plugin_name = strtolower($plugin_name);
 | 
			
		||||
        $_name_parts = explode('_', $_plugin_name, 3); 
 | 
			
		||||
        // class name must have three parts to be valid plugin
 | 
			
		||||
        if (count($_name_parts) < 3 || $_name_parts[0] !== 'smarty') {
 | 
			
		||||
            throw new SmartyException("plugin {$plugin_name} is not a valid name format");
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
        // if type is "internal", get plugin from sysplugins
 | 
			
		||||
        if ($_name_parts[1] == 'internal') {
 | 
			
		||||
            $file = SMARTY_SYSPLUGINS_DIR . $_plugin_name . '.php';
 | 
			
		||||
            if (file_exists($file)) {
 | 
			
		||||
                require_once($file);
 | 
			
		||||
                return $file;
 | 
			
		||||
            } else {
 | 
			
		||||
                return false;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // plugin filename is expected to be: [type].[name].php
 | 
			
		||||
        $_plugin_filename = "{$_name_parts[1]}.{$_name_parts[2]}.php"; 
 | 
			
		||||
        // loop through plugin dirs and find the plugin
 | 
			
		||||
        foreach((array)$this->plugins_dir as $_plugin_dir) {
 | 
			
		||||
            if (strpos('/\\', substr($_plugin_dir, -1)) === false) {
 | 
			
		||||
                $_plugin_dir .= DS;
 | 
			
		||||
            } 
 | 
			
		||||
            $file = $_plugin_dir . $_plugin_filename;
 | 
			
		||||
            if (file_exists($file)) {
 | 
			
		||||
                require_once($file);
 | 
			
		||||
                return $file;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // no plugin loaded
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
    * clean up properties on cloned object
 | 
			
		||||
     */
 | 
			
		||||
    public function __clone()
 | 
			
		||||
    {
 | 
			
		||||
    	// clear config vars
 | 
			
		||||
    	$this->config_vars = array(); 
 | 
			
		||||
    	// clear assigned tpl vars
 | 
			
		||||
    	$this->tpl_vars = array();
 | 
			
		||||
    	// clear objects for external methods
 | 
			
		||||
    	unset($this->register);  
 | 
			
		||||
    	unset($this->filter);  
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Handle unknown class methods
 | 
			
		||||
	 *
 | 
			
		||||
     * @param string $name unknown methode name
 | 
			
		||||
     * @param array $args aurgument array
 | 
			
		||||
     */
 | 
			
		||||
    public function __call($name, $args)
 | 
			
		||||
    {
 | 
			
		||||
        static $camel_func;
 | 
			
		||||
        if (!isset($camel_func))
 | 
			
		||||
            $camel_func = create_function('$c', 'return "_" . strtolower($c[1]);'); 
 | 
			
		||||
        // see if this is a set/get for a property
 | 
			
		||||
        $first3 = strtolower(substr($name, 0, 3));
 | 
			
		||||
        if (in_array($first3, array('set', 'get')) && substr($name, 3, 1) !== '_') {
 | 
			
		||||
            // try to keep case correct for future PHP 6.0 case-sensitive class methods
 | 
			
		||||
            // lcfirst() not available < PHP 5.3.0, so improvise
 | 
			
		||||
            $property_name = strtolower(substr($name, 3, 1)) . substr($name, 4); 
 | 
			
		||||
            // convert camel case to underscored name
 | 
			
		||||
            $property_name = preg_replace_callback('/([A-Z])/', $camel_func, $property_name);
 | 
			
		||||
            if (!property_exists($this, $property_name)) {
 | 
			
		||||
                throw new SmartyException("property '$property_name' does not exist.");
 | 
			
		||||
                return false;
 | 
			
		||||
            } 
 | 
			
		||||
            if ($first3 == 'get')
 | 
			
		||||
                return $this->$property_name;
 | 
			
		||||
            else
 | 
			
		||||
                return $this->$property_name = $args[0];
 | 
			
		||||
        }
 | 
			
		||||
       // Smarty Backward Compatible wrapper
 | 
			
		||||
		if (strpos($name,'_') !== false) {
 | 
			
		||||
        	if (!isset($this->wrapper)) {
 | 
			
		||||
           	 $this->wrapper = new Smarty_Internal_Wrapper($this);
 | 
			
		||||
        	} 
 | 
			
		||||
        	return $this->wrapper->convert($name, $args);
 | 
			
		||||
        }
 | 
			
		||||
        // external Smarty methods ?
 | 
			
		||||
        foreach(array('filter','register') as $external) {  
 | 
			
		||||
        	if (method_exists("Smarty_Internal_{$external}",$name)) {
 | 
			
		||||
        		if (!isset($this->$external)) {
 | 
			
		||||
        			$class = "Smarty_Internal_{$external}";
 | 
			
		||||
            		$this->$external = new $class($this);
 | 
			
		||||
        		} 
 | 
			
		||||
        		return call_user_func_array(array($this->$external,$name), $args);
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		if (in_array($name,array('clearCompiledTemplate','compileAllTemplates','compileAllConfig','testInstall','getTags'))) {
 | 
			
		||||
       		if (!isset($this->utility)) {
 | 
			
		||||
            	$this->utility = new Smarty_Internal_Utility($this);
 | 
			
		||||
        	} 
 | 
			
		||||
        	return call_user_func_array(array($this->utility,$name), $args);
 | 
			
		||||
		}
 | 
			
		||||
         // PHP4 call to constructor?
 | 
			
		||||
        if (strtolower($name) == 'smarty') {
 | 
			
		||||
            throw new SmartyException('Please use parent::__construct() to call parent constuctor');
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
        throw new SmartyException("Call of unknown function '$name'.");
 | 
			
		||||
   } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Autoloader
 | 
			
		||||
 */
 | 
			
		||||
function smartyAutoload($class)
 | 
			
		||||
{
 | 
			
		||||
    $_class = strtolower($class);
 | 
			
		||||
    if (substr($_class, 0, 16) === 'smarty_internal_' || $_class == 'smarty_security') {
 | 
			
		||||
        include SMARTY_SYSPLUGINS_DIR . $_class . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty exception class
 | 
			
		||||
 */
 | 
			
		||||
Class SmartyException extends Exception {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty compiler exception class
 | 
			
		||||
 */
 | 
			
		||||
Class SmartyCompilerException extends SmartyException  {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										133
									
								
								site/stackreach/libs/debug.tpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								site/stackreach/libs/debug.tpl
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,133 @@
 | 
			
		||||
{capture name='_smarty_debug' assign=debug_output}
 | 
			
		||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
 | 
			
		||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
 | 
			
		||||
<head>
 | 
			
		||||
    <title>Smarty Debug Console</title>
 | 
			
		||||
<style type="text/css">
 | 
			
		||||
{literal}
 | 
			
		||||
body, h1, h2, td, th, p {
 | 
			
		||||
    font-family: sans-serif;
 | 
			
		||||
    font-weight: normal;
 | 
			
		||||
    font-size: 0.9em;
 | 
			
		||||
    margin: 1px;
 | 
			
		||||
    padding: 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
h1 {
 | 
			
		||||
    margin: 0;
 | 
			
		||||
    text-align: left;
 | 
			
		||||
    padding: 2px;
 | 
			
		||||
    background-color: #f0c040;
 | 
			
		||||
    color:  black;
 | 
			
		||||
    font-weight: bold;
 | 
			
		||||
    font-size: 1.2em;
 | 
			
		||||
 }
 | 
			
		||||
 | 
			
		||||
h2 {
 | 
			
		||||
    background-color: #9B410E;
 | 
			
		||||
    color: white;
 | 
			
		||||
    text-align: left;
 | 
			
		||||
    font-weight: bold;
 | 
			
		||||
    padding: 2px;
 | 
			
		||||
    border-top: 1px solid black;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
body {
 | 
			
		||||
    background: black; 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
p, table, div {
 | 
			
		||||
    background: #f0ead8;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
p {
 | 
			
		||||
    margin: 0;
 | 
			
		||||
    font-style: italic;
 | 
			
		||||
    text-align: center;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
table {
 | 
			
		||||
    width: 100%;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
th, td {
 | 
			
		||||
    font-family: monospace;
 | 
			
		||||
    vertical-align: top;
 | 
			
		||||
    text-align: left;
 | 
			
		||||
    width: 50%;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
td {
 | 
			
		||||
    color: green;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.odd {
 | 
			
		||||
    background-color: #eeeeee;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.even {
 | 
			
		||||
    background-color: #fafafa;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.exectime {
 | 
			
		||||
    font-size: 0.8em;
 | 
			
		||||
    font-style: italic;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#table_assigned_vars th {
 | 
			
		||||
    color: blue;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#table_config_vars th {
 | 
			
		||||
    color: maroon;
 | 
			
		||||
}
 | 
			
		||||
{/literal}
 | 
			
		||||
</style>
 | 
			
		||||
</head>
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
<h1>Smarty Debug Console  -  {if isset($template_name)}{$template_name|debug_print_var}{else}Total Time {$execution_time|string_format:"%.5f"}{/if}</h1>
 | 
			
		||||
 | 
			
		||||
{if !empty($template_data)}
 | 
			
		||||
<h2>included templates & config files (load time in seconds)</h2>
 | 
			
		||||
 | 
			
		||||
<div>
 | 
			
		||||
{foreach $template_data as $template}
 | 
			
		||||
  <font color=brown>{$template.name}</font>
 | 
			
		||||
  <span class="exectime">
 | 
			
		||||
   (compile {$template['compile_time']|string_format:"%.5f"}) (render {$template['render_time']|string_format:"%.5f"}) (cache {$template['cache_time']|string_format:"%.5f"})
 | 
			
		||||
  </span>
 | 
			
		||||
  <br>
 | 
			
		||||
{/foreach}
 | 
			
		||||
</div>
 | 
			
		||||
{/if}
 | 
			
		||||
 | 
			
		||||
<h2>assigned template variables</h2>
 | 
			
		||||
 | 
			
		||||
<table id="table_assigned_vars">
 | 
			
		||||
    {foreach $assigned_vars as $vars}
 | 
			
		||||
       <tr class="{if $vars@iteration % 2 eq 0}odd{else}even{/if}">   
 | 
			
		||||
       <th>${$vars@key|escape:'html'}</th>
 | 
			
		||||
       <td>{$vars|debug_print_var}</td></tr>
 | 
			
		||||
    {/foreach}
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<h2>assigned config file variables (outer template scope)</h2>
 | 
			
		||||
 | 
			
		||||
<table id="table_config_vars">
 | 
			
		||||
    {foreach $config_vars as $vars}
 | 
			
		||||
       <tr class="{if $vars@iteration % 2 eq 0}odd{else}even{/if}">   
 | 
			
		||||
       <th>{$vars@key|escape:'html'}</th>
 | 
			
		||||
       <td>{$vars|debug_print_var}</td></tr>
 | 
			
		||||
    {/foreach}
 | 
			
		||||
 | 
			
		||||
</table>
 | 
			
		||||
</body>
 | 
			
		||||
</html>
 | 
			
		||||
{/capture}
 | 
			
		||||
<script type="text/javascript">
 | 
			
		||||
{$id = $template_name|default:''|md5}
 | 
			
		||||
    _smarty_console = window.open("","console{$id}","width=680,height=600,resizable,scrollbars=yes");
 | 
			
		||||
    _smarty_console.document.write("{$debug_output|escape:'javascript'}");
 | 
			
		||||
    _smarty_console.document.close();
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										27
									
								
								site/stackreach/libs/plugins/block.php.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								site/stackreach/libs/plugins/block.php.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,27 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin to execute PHP code
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsBlock
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {php}{/php} block plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @param string $content contents of the block
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @param boolean $ &$repeat repeat flag
 | 
			
		||||
 * @return string content re-formatted
 | 
			
		||||
 */
 | 
			
		||||
function smarty_block_php($params, $content, $template, &$repeat)
 | 
			
		||||
{ 
 | 
			
		||||
    if (!$template->allow_php_tag) {
 | 
			
		||||
        throw new SmartyException("{php} is deprecated, set allow_php_tag = true to enable");
 | 
			
		||||
    } 
 | 
			
		||||
    eval($content);
 | 
			
		||||
    return '';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										102
									
								
								site/stackreach/libs/plugins/block.textformat.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								site/stackreach/libs/plugins/block.textformat.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,102 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin to format text blocks
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsBlock
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {textformat}{/textformat} block plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     block function<br>
 | 
			
		||||
 * Name:     textformat<br>
 | 
			
		||||
 * Purpose:  format text a certain way with preset styles
 | 
			
		||||
 *            or custom wrap/indent settings<br>
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.textformat.php {textformat}
 | 
			
		||||
 *       (Smarty online manual)
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * Params:   style: string (email)
 | 
			
		||||
 *            indent: integer (0)
 | 
			
		||||
 *            wrap: integer (80)
 | 
			
		||||
 *            wrap_char string ("\n")
 | 
			
		||||
 *            indent_char: string (" ")
 | 
			
		||||
 *            wrap_boundary: boolean (true)
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $content contents of the block
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @param boolean &$repeat repeat flag
 | 
			
		||||
 * @return string content re-formatted
 | 
			
		||||
 */
 | 
			
		||||
function smarty_block_textformat($params, $content, $template, &$repeat)
 | 
			
		||||
{
 | 
			
		||||
    if (is_null($content)) {
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $style = null;
 | 
			
		||||
    $indent = 0;
 | 
			
		||||
    $indent_first = 0;
 | 
			
		||||
    $indent_char = ' ';
 | 
			
		||||
    $wrap = 80;
 | 
			
		||||
    $wrap_char = "\n";
 | 
			
		||||
    $wrap_cut = false;
 | 
			
		||||
    $assign = null;
 | 
			
		||||
 | 
			
		||||
    foreach ($params as $_key => $_val) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'style':
 | 
			
		||||
            case 'indent_char':
 | 
			
		||||
            case 'wrap_char':
 | 
			
		||||
            case 'assign':
 | 
			
		||||
                $$_key = (string)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'indent':
 | 
			
		||||
            case 'indent_first':
 | 
			
		||||
            case 'wrap':
 | 
			
		||||
                $$_key = (int)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'wrap_cut':
 | 
			
		||||
                $$_key = (bool)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                trigger_error("textformat: unknown attribute '$_key'");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($style == 'email') {
 | 
			
		||||
        $wrap = 72;
 | 
			
		||||
    } 
 | 
			
		||||
    // split into paragraphs
 | 
			
		||||
    $_paragraphs = preg_split('![\r\n][\r\n]!', $content);
 | 
			
		||||
    $_output = '';
 | 
			
		||||
 | 
			
		||||
    for($_x = 0, $_y = count($_paragraphs); $_x < $_y; $_x++) {
 | 
			
		||||
        if ($_paragraphs[$_x] == '') {
 | 
			
		||||
            continue;
 | 
			
		||||
        } 
 | 
			
		||||
        // convert mult. spaces & special chars to single space
 | 
			
		||||
        $_paragraphs[$_x] = preg_replace(array('!\s+!', '!(^\s+)|(\s+$)!'), array(' ', ''), $_paragraphs[$_x]); 
 | 
			
		||||
        // indent first line
 | 
			
		||||
        if ($indent_first > 0) {
 | 
			
		||||
            $_paragraphs[$_x] = str_repeat($indent_char, $indent_first) . $_paragraphs[$_x];
 | 
			
		||||
        } 
 | 
			
		||||
        // wordwrap sentences
 | 
			
		||||
        $_paragraphs[$_x] = wordwrap($_paragraphs[$_x], $wrap - $indent, $wrap_char, $wrap_cut); 
 | 
			
		||||
        // indent lines
 | 
			
		||||
        if ($indent > 0) {
 | 
			
		||||
            $_paragraphs[$_x] = preg_replace('!^!m', str_repeat($indent_char, $indent), $_paragraphs[$_x]);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    $_output = implode($wrap_char . $wrap_char, $_paragraphs);
 | 
			
		||||
    
 | 
			
		||||
    return $assign ? $template->assign($assign, $_output) : $_output;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										78
									
								
								site/stackreach/libs/plugins/function.counter.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								site/stackreach/libs/plugins/function.counter.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,78 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {counter} function plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     counter<br>
 | 
			
		||||
 * Purpose:  print out a counter value
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.counter.php {counter}
 | 
			
		||||
 *       (Smarty online manual)
 | 
			
		||||
 * @param array parameters
 | 
			
		||||
 * @param Smarty
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string|null
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_counter($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    static $counters = array();
 | 
			
		||||
 | 
			
		||||
    $name = (isset($params['name'])) ? $params['name'] : 'default';
 | 
			
		||||
    if (!isset($counters[$name])) {
 | 
			
		||||
        $counters[$name] = array(
 | 
			
		||||
            'start'=>1,
 | 
			
		||||
            'skip'=>1,
 | 
			
		||||
            'direction'=>'up',
 | 
			
		||||
            'count'=>1
 | 
			
		||||
            );
 | 
			
		||||
    }
 | 
			
		||||
    $counter =& $counters[$name];
 | 
			
		||||
 | 
			
		||||
    if (isset($params['start'])) {
 | 
			
		||||
        $counter['start'] = $counter['count'] = (int)$params['start'];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!empty($params['assign'])) {
 | 
			
		||||
        $counter['assign'] = $params['assign'];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (isset($counter['assign'])) {
 | 
			
		||||
        $template->assign($counter['assign'], $counter['count']);
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if (isset($params['print'])) {
 | 
			
		||||
        $print = (bool)$params['print'];
 | 
			
		||||
    } else {
 | 
			
		||||
        $print = empty($counter['assign']);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if ($print) {
 | 
			
		||||
        $retval = $counter['count'];
 | 
			
		||||
    } else {
 | 
			
		||||
        $retval = null;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (isset($params['skip'])) {
 | 
			
		||||
        $counter['skip'] = $params['skip'];
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if (isset($params['direction'])) {
 | 
			
		||||
        $counter['direction'] = $params['direction'];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if ($counter['direction'] == "down")
 | 
			
		||||
        $counter['count'] -= $counter['skip'];
 | 
			
		||||
    else
 | 
			
		||||
        $counter['count'] += $counter['skip'];
 | 
			
		||||
    
 | 
			
		||||
    return $retval;
 | 
			
		||||
    
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										106
									
								
								site/stackreach/libs/plugins/function.cycle.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								site/stackreach/libs/plugins/function.cycle.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,106 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {cycle} function plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     cycle<br>
 | 
			
		||||
 * Date:     May 3, 2002<br>
 | 
			
		||||
 * Purpose:  cycle through given values<br>
 | 
			
		||||
 * Input:
 | 
			
		||||
 *         - name = name of cycle (optional)
 | 
			
		||||
 *         - values = comma separated list of values to cycle,
 | 
			
		||||
 *                    or an array of values to cycle
 | 
			
		||||
 *                    (this can be left out for subsequent calls)
 | 
			
		||||
 *         - reset = boolean - resets given var to true
 | 
			
		||||
 *         - print = boolean - print var or not. default is true
 | 
			
		||||
 *         - advance = boolean - whether or not to advance the cycle
 | 
			
		||||
 *         - delimiter = the value delimiter, default is ","
 | 
			
		||||
 *         - assign = boolean, assigns to template var instead of
 | 
			
		||||
 *                    printed.
 | 
			
		||||
 *
 | 
			
		||||
 * Examples:<br>
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * {cycle values="#eeeeee,#d0d0d0d"}
 | 
			
		||||
 * {cycle name=row values="one,two,three" reset=true}
 | 
			
		||||
 * {cycle name=row}
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.cycle.php {cycle}
 | 
			
		||||
 *       (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @author credit to Mark Priatel <mpriatel@rogers.com>
 | 
			
		||||
 * @author credit to Gerard <gerard@interfold.com>
 | 
			
		||||
 * @author credit to Jason Sweat <jsweat_php@yahoo.com>
 | 
			
		||||
 * @version  1.3
 | 
			
		||||
 * @param array
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string|null
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_function_cycle($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    static $cycle_vars;
 | 
			
		||||
    
 | 
			
		||||
    $name = (empty($params['name'])) ? 'default' : $params['name'];
 | 
			
		||||
    $print = (isset($params['print'])) ? (bool)$params['print'] : true;
 | 
			
		||||
    $advance = (isset($params['advance'])) ? (bool)$params['advance'] : true;
 | 
			
		||||
    $reset = (isset($params['reset'])) ? (bool)$params['reset'] : false;
 | 
			
		||||
            
 | 
			
		||||
    if (!in_array('values', array_keys($params))) {
 | 
			
		||||
        if(!isset($cycle_vars[$name]['values'])) {
 | 
			
		||||
            trigger_error("cycle: missing 'values' parameter");
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
    } else {
 | 
			
		||||
        if(isset($cycle_vars[$name]['values'])
 | 
			
		||||
            && $cycle_vars[$name]['values'] != $params['values'] ) {
 | 
			
		||||
            $cycle_vars[$name]['index'] = 0;
 | 
			
		||||
        }
 | 
			
		||||
        $cycle_vars[$name]['values'] = $params['values'];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (isset($params['delimiter'])) {
 | 
			
		||||
        $cycle_vars[$name]['delimiter'] = $params['delimiter'];
 | 
			
		||||
    } elseif (!isset($cycle_vars[$name]['delimiter'])) {
 | 
			
		||||
        $cycle_vars[$name]['delimiter'] = ',';       
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if(is_array($cycle_vars[$name]['values'])) {
 | 
			
		||||
        $cycle_array = $cycle_vars[$name]['values'];
 | 
			
		||||
    } else {
 | 
			
		||||
        $cycle_array = explode($cycle_vars[$name]['delimiter'],$cycle_vars[$name]['values']);
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if(!isset($cycle_vars[$name]['index']) || $reset ) {
 | 
			
		||||
        $cycle_vars[$name]['index'] = 0;
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if (isset($params['assign'])) {
 | 
			
		||||
        $print = false;
 | 
			
		||||
        $template->assign($params['assign'], $cycle_array[$cycle_vars[$name]['index']]);
 | 
			
		||||
    }
 | 
			
		||||
        
 | 
			
		||||
    if($print) {
 | 
			
		||||
        $retval = $cycle_array[$cycle_vars[$name]['index']];
 | 
			
		||||
    } else {
 | 
			
		||||
        $retval = null;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if($advance) {
 | 
			
		||||
        if ( $cycle_vars[$name]['index'] >= count($cycle_array) -1 ) {
 | 
			
		||||
            $cycle_vars[$name]['index'] = 0;
 | 
			
		||||
        } else {
 | 
			
		||||
            $cycle_vars[$name]['index']++;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    return $retval;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										216
									
								
								site/stackreach/libs/plugins/function.fetch.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										216
									
								
								site/stackreach/libs/plugins/function.fetch.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,216 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {fetch} plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     fetch<br>
 | 
			
		||||
 * Purpose:  fetch file, web or ftp data and display results
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.fetch.php {fetch}
 | 
			
		||||
 *       (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string|null if the assign parameter is passed, Smarty assigns the
 | 
			
		||||
 *                     result to a template variable
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_fetch($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    if (empty($params['file'])) {
 | 
			
		||||
        trigger_error("[plugin] fetch parameter 'file' cannot be empty",E_USER_NOTICE);
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    $content = '';
 | 
			
		||||
    if (isset($template->security_policy) && !preg_match('!^(http|ftp)://!i', $params['file'])) {
 | 
			
		||||
        if(!$template->security_policy->isTrustedResourceDir($params['file'])) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        // fetch the file
 | 
			
		||||
        if($fp = @fopen($params['file'],'r')) {
 | 
			
		||||
            while(!feof($fp)) {
 | 
			
		||||
                $content .= fgets ($fp,4096);
 | 
			
		||||
            }
 | 
			
		||||
            fclose($fp);
 | 
			
		||||
        } else {
 | 
			
		||||
            trigger_error('[plugin] fetch cannot read file \'' . $params['file'] . '\'',E_USER_NOTICE);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
    } else {
 | 
			
		||||
        // not a local file
 | 
			
		||||
        if(preg_match('!^http://!i',$params['file'])) {
 | 
			
		||||
            // http fetch
 | 
			
		||||
            if($uri_parts = parse_url($params['file'])) {
 | 
			
		||||
                // set defaults
 | 
			
		||||
                $host = $server_name = $uri_parts['host'];
 | 
			
		||||
                $timeout = 30;
 | 
			
		||||
                $accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*";
 | 
			
		||||
                $agent = "Smarty Template Engine ".$template->_version;
 | 
			
		||||
                $referer = "";
 | 
			
		||||
                $uri = !empty($uri_parts['path']) ? $uri_parts['path'] : '/';
 | 
			
		||||
                $uri .= !empty($uri_parts['query']) ? '?' . $uri_parts['query'] : '';
 | 
			
		||||
                $_is_proxy = false;
 | 
			
		||||
                if(empty($uri_parts['port'])) {
 | 
			
		||||
                    $port = 80;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $port = $uri_parts['port'];
 | 
			
		||||
                }
 | 
			
		||||
                if(!empty($uri_parts['user'])) {
 | 
			
		||||
                    $user = $uri_parts['user'];
 | 
			
		||||
                }
 | 
			
		||||
                if(!empty($uri_parts['pass'])) {
 | 
			
		||||
                    $pass = $uri_parts['pass'];
 | 
			
		||||
                }
 | 
			
		||||
                // loop through parameters, setup headers
 | 
			
		||||
                foreach($params as $param_key => $param_value) {
 | 
			
		||||
                    switch($param_key) {
 | 
			
		||||
                        case "file":
 | 
			
		||||
                        case "assign":
 | 
			
		||||
                        case "assign_headers":
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "user":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $user = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "pass":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $pass = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "accept":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $accept = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "header":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                if(!preg_match('![\w\d-]+: .+!',$param_value)) {
 | 
			
		||||
                                    trigger_error("[plugin] invalid header format '".$param_value."'",E_USER_NOTICE);
 | 
			
		||||
                                    return;
 | 
			
		||||
                                } else {
 | 
			
		||||
                                    $extra_headers[] = $param_value;
 | 
			
		||||
                                }
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "proxy_host":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $proxy_host = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "proxy_port":
 | 
			
		||||
                            if(!preg_match('!\D!', $param_value)) {
 | 
			
		||||
                                $proxy_port = (int) $param_value;
 | 
			
		||||
                            } else {
 | 
			
		||||
                                trigger_error("[plugin] invalid value for attribute '".$param_key."'",E_USER_NOTICE);
 | 
			
		||||
                                return;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "agent":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $agent = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "referer":
 | 
			
		||||
                            if(!empty($param_value)) {
 | 
			
		||||
                                $referer = $param_value;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        case "timeout":
 | 
			
		||||
                            if(!preg_match('!\D!', $param_value)) {
 | 
			
		||||
                                $timeout = (int) $param_value;
 | 
			
		||||
                            } else {
 | 
			
		||||
                                trigger_error("[plugin] invalid value for attribute '".$param_key."'",E_USER_NOTICE);
 | 
			
		||||
                                return;
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        default:
 | 
			
		||||
                            trigger_error("[plugin] unrecognized attribute '".$param_key."'",E_USER_NOTICE);
 | 
			
		||||
                            return;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
                if(!empty($proxy_host) && !empty($proxy_port)) {
 | 
			
		||||
                    $_is_proxy = true;
 | 
			
		||||
                    $fp = fsockopen($proxy_host,$proxy_port,$errno,$errstr,$timeout);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $fp = fsockopen($server_name,$port,$errno,$errstr,$timeout);
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                if(!$fp) {
 | 
			
		||||
                    trigger_error("[plugin] unable to fetch: $errstr ($errno)",E_USER_NOTICE);
 | 
			
		||||
                    return;
 | 
			
		||||
                } else {
 | 
			
		||||
                    if($_is_proxy) {
 | 
			
		||||
                        fputs($fp, 'GET ' . $params['file'] . " HTTP/1.0\r\n");
 | 
			
		||||
                    } else {
 | 
			
		||||
                        fputs($fp, "GET $uri HTTP/1.0\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
                    if(!empty($host)) {
 | 
			
		||||
                        fputs($fp, "Host: $host\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
                    if(!empty($accept)) {
 | 
			
		||||
                        fputs($fp, "Accept: $accept\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
                    if(!empty($agent)) {
 | 
			
		||||
                        fputs($fp, "User-Agent: $agent\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
                    if(!empty($referer)) {
 | 
			
		||||
                        fputs($fp, "Referer: $referer\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
                    if(isset($extra_headers) && is_array($extra_headers)) {
 | 
			
		||||
                        foreach($extra_headers as $curr_header) {
 | 
			
		||||
                            fputs($fp, $curr_header."\r\n");
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                    if(!empty($user) && !empty($pass)) {
 | 
			
		||||
                        fputs($fp, "Authorization: BASIC ".base64_encode("$user:$pass")."\r\n");
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    fputs($fp, "\r\n");
 | 
			
		||||
                    while(!feof($fp)) {
 | 
			
		||||
                        $content .= fgets($fp,4096);
 | 
			
		||||
                    }
 | 
			
		||||
                    fclose($fp);
 | 
			
		||||
                    $csplit = preg_split("!\r\n\r\n!",$content,2);
 | 
			
		||||
 | 
			
		||||
                    $content = $csplit[1];
 | 
			
		||||
 | 
			
		||||
                    if(!empty($params['assign_headers'])) {
 | 
			
		||||
                        $template->assign($params['assign_headers'],preg_split("!\r\n!",$csplit[0]));
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            } else {
 | 
			
		||||
                trigger_error("[plugin fetch] unable to parse URL, check syntax",E_USER_NOTICE);
 | 
			
		||||
                return;
 | 
			
		||||
            }
 | 
			
		||||
        } else {
 | 
			
		||||
            // ftp fetch
 | 
			
		||||
            if($fp = @fopen($params['file'],'r')) {
 | 
			
		||||
                while(!feof($fp)) {
 | 
			
		||||
                    $content .= fgets ($fp,4096);
 | 
			
		||||
                }
 | 
			
		||||
                fclose($fp);
 | 
			
		||||
            } else {
 | 
			
		||||
                trigger_error('[plugin] fetch cannot read file \'' . $params['file'] .'\'',E_USER_NOTICE);
 | 
			
		||||
                return;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    if (!empty($params['assign'])) {
 | 
			
		||||
        $template->assign($params['assign'],$content);
 | 
			
		||||
    } else {
 | 
			
		||||
        return $content;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										143
									
								
								site/stackreach/libs/plugins/function.html_checkboxes.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								site/stackreach/libs/plugins/function.html_checkboxes.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,143 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_checkboxes} function plugin
 | 
			
		||||
 *
 | 
			
		||||
 * File:       function.html_checkboxes.php<br>
 | 
			
		||||
 * Type:       function<br>
 | 
			
		||||
 * Name:       html_checkboxes<br>
 | 
			
		||||
 * Date:       24.Feb.2003<br>
 | 
			
		||||
 * Purpose:    Prints out a list of checkbox input types<br>
 | 
			
		||||
 * Examples:
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * {html_checkboxes values=$ids output=$names}
 | 
			
		||||
 * {html_checkboxes values=$ids name='box' separator='<br>' output=$names}
 | 
			
		||||
 * {html_checkboxes values=$ids checked=$checked separator='<br>' output=$names}
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.checkboxes.php {html_checkboxes}
 | 
			
		||||
 *      (Smarty online manual)
 | 
			
		||||
 * @author     Christopher Kvarme <christopher.kvarme@flashjab.com>
 | 
			
		||||
 * @author credits to Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @version    1.0
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *           - name       (optional) - string default "checkbox"
 | 
			
		||||
 *           - values     (required) - array
 | 
			
		||||
 *           - options    (optional) - associative array
 | 
			
		||||
 *           - checked    (optional) - array default not set
 | 
			
		||||
 *           - separator  (optional) - ie <br> or  
 | 
			
		||||
 *           - output     (optional) - the output next to each checkbox
 | 
			
		||||
 *           - assign     (optional) - assign the output as an array to this variable
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string
 | 
			
		||||
 * @uses smarty_function_escape_special_chars()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_checkboxes($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
 | 
			
		||||
 | 
			
		||||
    $name = 'checkbox';
 | 
			
		||||
    $values = null;
 | 
			
		||||
    $options = null;
 | 
			
		||||
    $selected = null;
 | 
			
		||||
    $separator = '';
 | 
			
		||||
    $labels = true;
 | 
			
		||||
    $output = null;
 | 
			
		||||
 | 
			
		||||
    $extra = '';
 | 
			
		||||
 | 
			
		||||
    foreach($params as $_key => $_val) {
 | 
			
		||||
        switch($_key) {
 | 
			
		||||
            case 'name':
 | 
			
		||||
            case 'separator':
 | 
			
		||||
                $$_key = $_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'labels':
 | 
			
		||||
                $$_key = (bool)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'options':
 | 
			
		||||
                $$_key = (array)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'values':
 | 
			
		||||
            case 'output':
 | 
			
		||||
                $$_key = array_values((array)$_val);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'checked':
 | 
			
		||||
            case 'selected':
 | 
			
		||||
                $selected = array_map('strval', array_values((array)$_val));
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'checkboxes':
 | 
			
		||||
                trigger_error('html_checkboxes: the use of the "checkboxes" attribute is deprecated, use "options" instead', E_USER_WARNING);
 | 
			
		||||
                $options = (array)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'assign':
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                if(!is_array($_val)) {
 | 
			
		||||
                    $extra .= ' '.$_key.'="'.smarty_function_escape_special_chars($_val).'"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    trigger_error("html_checkboxes: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                }
 | 
			
		||||
                break;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!isset($options) && !isset($values))
 | 
			
		||||
        return ''; /* raise error here? */
 | 
			
		||||
 | 
			
		||||
    settype($selected, 'array');
 | 
			
		||||
    $_html_result = array();
 | 
			
		||||
 | 
			
		||||
    if (isset($options)) {
 | 
			
		||||
 | 
			
		||||
        foreach ($options as $_key=>$_val)
 | 
			
		||||
            $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    } else {
 | 
			
		||||
        foreach ($values as $_i=>$_key) {
 | 
			
		||||
            $_val = isset($output[$_i]) ? $output[$_i] : '';
 | 
			
		||||
            $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if(!empty($params['assign'])) {
 | 
			
		||||
        $template->assign($params['assign'], $_html_result);
 | 
			
		||||
    } else {
 | 
			
		||||
        return implode("\n",$_html_result);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function smarty_function_html_checkboxes_output($name, $value, $output, $selected, $extra, $separator, $labels) {
 | 
			
		||||
    $_output = '';
 | 
			
		||||
    if ($labels) $_output .= '<label>';
 | 
			
		||||
    $_output .= '<input type="checkbox" name="'
 | 
			
		||||
        . smarty_function_escape_special_chars($name) . '[]" value="'
 | 
			
		||||
        . smarty_function_escape_special_chars($value) . '"';
 | 
			
		||||
 | 
			
		||||
    if (in_array((string)$value, $selected)) {
 | 
			
		||||
        $_output .= ' checked="checked"';
 | 
			
		||||
    }
 | 
			
		||||
    $_output .= $extra . ' />' . $output;
 | 
			
		||||
    if ($labels) $_output .= '</label>';
 | 
			
		||||
    $_output .=  $separator;
 | 
			
		||||
 | 
			
		||||
    return $_output;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										137
									
								
								site/stackreach/libs/plugins/function.html_image.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								site/stackreach/libs/plugins/function.html_image.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,137 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_image} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     html_image<br>
 | 
			
		||||
 * Date:     Feb 24, 2003<br>
 | 
			
		||||
 * Purpose:  format HTML tags for the image<br>
 | 
			
		||||
 * Examples: {html_image file="/images/masthead.gif"}
 | 
			
		||||
 * Output:   <img src="/images/masthead.gif" width=400 height=23>
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.image.php {html_image}
 | 
			
		||||
 *      (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author credits to Duda <duda@big.hu> 
 | 
			
		||||
 * @version 1.0
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *          - file = file (and path) of image (required)
 | 
			
		||||
 *          - height = image height (optional, default actual height)
 | 
			
		||||
 *          - width = image width (optional, default actual width)
 | 
			
		||||
 *          - basedir = base directory for absolute paths, default
 | 
			
		||||
 *                      is environment variable DOCUMENT_ROOT
 | 
			
		||||
 *          - path_prefix = prefix for path output (optional, default empty)
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 * @uses smarty_function_escape_special_chars()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_image($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
 | 
			
		||||
 
 | 
			
		||||
    $alt = '';
 | 
			
		||||
    $file = '';
 | 
			
		||||
    $height = '';
 | 
			
		||||
    $width = '';
 | 
			
		||||
    $extra = '';
 | 
			
		||||
    $prefix = '';
 | 
			
		||||
    $suffix = '';
 | 
			
		||||
    $path_prefix = '';
 | 
			
		||||
    $server_vars = $_SERVER;
 | 
			
		||||
    $basedir = isset($server_vars['DOCUMENT_ROOT']) ? $server_vars['DOCUMENT_ROOT'] : '';
 | 
			
		||||
    foreach($params as $_key => $_val) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'file':
 | 
			
		||||
            case 'height':
 | 
			
		||||
            case 'width':
 | 
			
		||||
            case 'dpi':
 | 
			
		||||
            case 'path_prefix':
 | 
			
		||||
            case 'basedir':
 | 
			
		||||
                $$_key = $_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'alt':
 | 
			
		||||
                if (!is_array($_val)) {
 | 
			
		||||
                    $$_key = smarty_function_escape_special_chars($_val);
 | 
			
		||||
                } else {
 | 
			
		||||
                    throw new SmartyException ("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'link':
 | 
			
		||||
            case 'href':
 | 
			
		||||
                $prefix = '<a href="' . $_val . '">';
 | 
			
		||||
                $suffix = '</a>';
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                if (!is_array($_val)) {
 | 
			
		||||
                    $extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    throw new SmartyException ("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (empty($file)) {
 | 
			
		||||
        trigger_error("html_image: missing 'file' parameter", E_USER_NOTICE);
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (substr($file, 0, 1) == '/') {
 | 
			
		||||
        $_image_path = $basedir . $file;
 | 
			
		||||
    } else {
 | 
			
		||||
        $_image_path = $file;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (!isset($params['width']) || !isset($params['height'])) {
 | 
			
		||||
        if (!$_image_data = @getimagesize($_image_path)) {
 | 
			
		||||
            if (!file_exists($_image_path)) {
 | 
			
		||||
                trigger_error("html_image: unable to find '$_image_path'", E_USER_NOTICE);
 | 
			
		||||
                return;
 | 
			
		||||
            } else if (!is_readable($_image_path)) {
 | 
			
		||||
                trigger_error("html_image: unable to read '$_image_path'", E_USER_NOTICE);
 | 
			
		||||
                return;
 | 
			
		||||
            } else {
 | 
			
		||||
                trigger_error("html_image: '$_image_path' is not a valid image file", E_USER_NOTICE);
 | 
			
		||||
                return;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($template->security_policy)) {
 | 
			
		||||
            if (!$template->security_policy->isTrustedResourceDir($_image_path)) {
 | 
			
		||||
                return;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (!isset($params['width'])) {
 | 
			
		||||
            $width = $_image_data[0];
 | 
			
		||||
        } 
 | 
			
		||||
        if (!isset($params['height'])) {
 | 
			
		||||
            $height = $_image_data[1];
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (isset($params['dpi'])) {
 | 
			
		||||
        if (strstr($server_vars['HTTP_USER_AGENT'], 'Mac')) {
 | 
			
		||||
            $dpi_default = 72;
 | 
			
		||||
        } else {
 | 
			
		||||
            $dpi_default = 96;
 | 
			
		||||
        } 
 | 
			
		||||
        $_resize = $dpi_default / $params['dpi'];
 | 
			
		||||
        $width = round($width * $_resize);
 | 
			
		||||
        $height = round($height * $_resize);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return $prefix . '<img src="' . $path_prefix . $file . '" alt="' . $alt . '" width="' . $width . '" height="' . $height . '"' . $extra . ' />' . $suffix;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										133
									
								
								site/stackreach/libs/plugins/function.html_options.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								site/stackreach/libs/plugins/function.html_options.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,133 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_options} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     html_options<br>
 | 
			
		||||
 * Purpose:  Prints the list of <option> tags generated from
 | 
			
		||||
 *            the passed parameters
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.options.php {html_image}
 | 
			
		||||
 *      (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *            - name       (optional) - string default "select"
 | 
			
		||||
 *            - values     (required if no options supplied) - array
 | 
			
		||||
 *            - options    (required if no values supplied) - associative array
 | 
			
		||||
 *            - selected   (optional) - string default not set
 | 
			
		||||
 *            - output     (required if not options supplied) - array
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 * @uses smarty_function_escape_special_chars()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_options($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
 | 
			
		||||
 | 
			
		||||
    $name = null;
 | 
			
		||||
    $values = null;
 | 
			
		||||
    $options = null;
 | 
			
		||||
    $selected = array();
 | 
			
		||||
    $output = null;
 | 
			
		||||
    $id = null;
 | 
			
		||||
    $class = null;
 | 
			
		||||
 | 
			
		||||
    $extra = '';
 | 
			
		||||
    $options_extra = '';
 | 
			
		||||
 | 
			
		||||
    foreach($params as $_key => $_val) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'name':
 | 
			
		||||
            case 'class':
 | 
			
		||||
            case 'id':
 | 
			
		||||
                $$_key = (string)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'options':
 | 
			
		||||
                $$_key = (array)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'values':
 | 
			
		||||
            case 'output':
 | 
			
		||||
                $$_key = array_values((array)$_val);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'selected':
 | 
			
		||||
                $$_key = array_map('strval', array_values((array)$_val));
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                if (!is_array($_val)) {
 | 
			
		||||
                    $extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    trigger_error("html_options: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (!isset($options) && !isset($values))
 | 
			
		||||
        return '';
 | 
			
		||||
    /* raise error here? */
 | 
			
		||||
 | 
			
		||||
    $_html_result = '';
 | 
			
		||||
    $_idx = 0;
 | 
			
		||||
 | 
			
		||||
    if (isset($options)) {
 | 
			
		||||
        foreach ($options as $_key => $_val) {
 | 
			
		||||
          $_html_result .= smarty_function_html_options_optoutput($_key, $_val, $selected, $id, $class, $_idx);
 | 
			
		||||
        }
 | 
			
		||||
    } else {
 | 
			
		||||
        foreach ($values as $_i => $_key) {
 | 
			
		||||
            $_val = isset($output[$_i]) ? $output[$_i] : '';
 | 
			
		||||
            $_html_result .= smarty_function_html_options_optoutput($_key, $_val, $selected, $id, $class, $_idx);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (!empty($name)) {
 | 
			
		||||
        $_html_class = !empty($class) ? ' class="'.$class.'"' : '';
 | 
			
		||||
        $_html_id = !empty($id) ? ' id="'.$id.'"' : '';
 | 
			
		||||
        $_html_result = '<select name="' . $name . '"' . $_html_class . $_html_id . $extra . '>' . "\n" . $_html_result . '</select>' . "\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return $_html_result;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
function smarty_function_html_options_optoutput($key, $value, $selected, $id, $class, &$idx)
 | 
			
		||||
{
 | 
			
		||||
    if (!is_array($value)) {
 | 
			
		||||
        $_html_result = '<option value="' .
 | 
			
		||||
        smarty_function_escape_special_chars($key) . '"';
 | 
			
		||||
        if (in_array((string)$key, $selected))
 | 
			
		||||
            $_html_result .= ' selected="selected"';
 | 
			
		||||
        $_html_class = !empty($class) ? ' class="'.$class.' option"' : '';
 | 
			
		||||
        $_html_id = !empty($id) ? ' id="'.$id.'-'.$idx.'"' : '';
 | 
			
		||||
        $_html_result .= $_html_class . $_html_id . '>' . smarty_function_escape_special_chars($value) . '</option>' . "\n";
 | 
			
		||||
        $idx++;
 | 
			
		||||
    } else {
 | 
			
		||||
        $_idx = 0;
 | 
			
		||||
        $_html_result = smarty_function_html_options_optgroup($key, $value, $selected, $id.'-'.$idx, $class, $_idx);
 | 
			
		||||
        $idx++;
 | 
			
		||||
    }
 | 
			
		||||
    return $_html_result;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
function smarty_function_html_options_optgroup($key, $values, $selected, $id, $class, &$idx)
 | 
			
		||||
{
 | 
			
		||||
    $optgroup_html = '<optgroup label="' . smarty_function_escape_special_chars($key) . '">' . "\n";
 | 
			
		||||
    foreach ($values as $key => $value) {
 | 
			
		||||
        $optgroup_html .= smarty_function_html_options_optoutput($key, $value, $selected, $id, $class, $idx);
 | 
			
		||||
    } 
 | 
			
		||||
    $optgroup_html .= "</optgroup>\n";
 | 
			
		||||
    return $optgroup_html;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										154
									
								
								site/stackreach/libs/plugins/function.html_radios.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								site/stackreach/libs/plugins/function.html_radios.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,154 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_radios} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * File:       function.html_radios.php<br>
 | 
			
		||||
 * Type:       function<br>
 | 
			
		||||
 * Name:       html_radios<br>
 | 
			
		||||
 * Date:       24.Feb.2003<br>
 | 
			
		||||
 * Purpose:    Prints out a list of radio input types<br>
 | 
			
		||||
 * Examples:
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * {html_radios values=$ids output=$names}
 | 
			
		||||
 * {html_radios values=$ids name='box' separator='<br>' output=$names}
 | 
			
		||||
 * {html_radios values=$ids checked=$checked separator='<br>' output=$names}
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.radios.php {html_radios}
 | 
			
		||||
 *      (Smarty online manual)
 | 
			
		||||
 * @author Christopher Kvarme <christopher.kvarme@flashjab.com> 
 | 
			
		||||
 * @author credits to Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @version 1.0
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *            - name       (optional) - string default "radio"
 | 
			
		||||
 *            - values     (required) - array
 | 
			
		||||
 *            - options    (optional) - associative array
 | 
			
		||||
 *            - checked    (optional) - array default not set
 | 
			
		||||
 *            - separator  (optional) - ie <br> or  
 | 
			
		||||
 *            - output     (optional) - the output next to each radio button
 | 
			
		||||
 *            - assign     (optional) - assign the output as an array to this variable
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 * @uses smarty_function_escape_special_chars()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_radios($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
 | 
			
		||||
 | 
			
		||||
    $name = 'radio';
 | 
			
		||||
    $values = null;
 | 
			
		||||
    $options = null;
 | 
			
		||||
    $selected = null;
 | 
			
		||||
    $separator = '';
 | 
			
		||||
    $labels = true;
 | 
			
		||||
    $label_ids = false;
 | 
			
		||||
    $output = null;
 | 
			
		||||
    $extra = '';
 | 
			
		||||
 | 
			
		||||
    foreach($params as $_key => $_val) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'name':
 | 
			
		||||
            case 'separator':
 | 
			
		||||
                $$_key = (string)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'checked':
 | 
			
		||||
            case 'selected':
 | 
			
		||||
                if (is_array($_val)) {
 | 
			
		||||
                    trigger_error('html_radios: the "' . $_key . '" attribute cannot be an array', E_USER_WARNING);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $selected = (string)$_val;
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'labels':
 | 
			
		||||
            case 'label_ids':
 | 
			
		||||
                $$_key = (bool)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'options':
 | 
			
		||||
                $$_key = (array)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'values':
 | 
			
		||||
            case 'output':
 | 
			
		||||
                $$_key = array_values((array)$_val);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'radios':
 | 
			
		||||
                trigger_error('html_radios: the use of the "radios" attribute is deprecated, use "options" instead', E_USER_WARNING);
 | 
			
		||||
                $options = (array)$_val;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'assign':
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                if (!is_array($_val)) {
 | 
			
		||||
                    $extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    trigger_error("html_radios: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (!isset($options) && !isset($values))
 | 
			
		||||
        return '';
 | 
			
		||||
    /* raise error here? */
 | 
			
		||||
 | 
			
		||||
    $_html_result = array();
 | 
			
		||||
 | 
			
		||||
    if (isset($options)) {
 | 
			
		||||
        foreach ($options as $_key => $_val)
 | 
			
		||||
        $_html_result[] = smarty_function_html_radios_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids);
 | 
			
		||||
    } else {
 | 
			
		||||
        foreach ($values as $_i => $_key) {
 | 
			
		||||
            $_val = isset($output[$_i]) ? $output[$_i] : '';
 | 
			
		||||
            $_html_result[] = smarty_function_html_radios_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (!empty($params['assign'])) {
 | 
			
		||||
        $template->assign($params['assign'], $_html_result);
 | 
			
		||||
    } else {
 | 
			
		||||
        return implode("\n", $_html_result);
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
function smarty_function_html_radios_output($name, $value, $output, $selected, $extra, $separator, $labels, $label_ids)
 | 
			
		||||
{
 | 
			
		||||
    $_output = '';
 | 
			
		||||
    if ($labels) {
 | 
			
		||||
        if ($label_ids) {
 | 
			
		||||
            $_id = smarty_function_escape_special_chars(preg_replace('![^\w\-\.]!', '_', $name . '_' . $value));
 | 
			
		||||
            $_output .= '<label for="' . $_id . '">';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_output .= '<label>';
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    $_output .= '<input type="radio" name="'
 | 
			
		||||
     . smarty_function_escape_special_chars($name) . '" value="'
 | 
			
		||||
     . smarty_function_escape_special_chars($value) . '"';
 | 
			
		||||
 | 
			
		||||
    if ($labels && $label_ids) $_output .= ' id="' . $_id . '"';
 | 
			
		||||
 | 
			
		||||
    if ((string)$value == $selected) {
 | 
			
		||||
        $_output .= ' checked="checked"';
 | 
			
		||||
    } 
 | 
			
		||||
    $_output .= $extra . ' />' . $output;
 | 
			
		||||
    if ($labels) $_output .= '</label>';
 | 
			
		||||
    $_output .= $separator;
 | 
			
		||||
 | 
			
		||||
    return $_output;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										330
									
								
								site/stackreach/libs/plugins/function.html_select_date.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										330
									
								
								site/stackreach/libs/plugins/function.html_select_date.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,330 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_select_date} plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     html_select_date<br>
 | 
			
		||||
 * Purpose:  Prints the dropdowns for date selection.
 | 
			
		||||
 * 
 | 
			
		||||
 * ChangeLog:<br>
 | 
			
		||||
 *            - 1.0 initial release
 | 
			
		||||
 *            - 1.1 added support for +/- N syntax for begin
 | 
			
		||||
 *                 and end year values. (Monte)
 | 
			
		||||
 *            - 1.2 added support for yyyy-mm-dd syntax for
 | 
			
		||||
 *                 time value. (Jan Rosier)
 | 
			
		||||
 *            - 1.3 added support for choosing format for
 | 
			
		||||
 *                 month values (Gary Loescher)
 | 
			
		||||
 *            - 1.3.1 added support for choosing format for
 | 
			
		||||
 *                 day values (Marcus Bointon)
 | 
			
		||||
 *            - 1.3.2 support negative timestamps, force year
 | 
			
		||||
 *              dropdown to include given date unless explicitly set (Monte)
 | 
			
		||||
 *            - 1.3.4 fix behaviour of 0000-00-00 00:00:00 dates to match that
 | 
			
		||||
 *              of 0000-00-00 dates (cybot, boots)
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.select.date.php {html_select_date}
 | 
			
		||||
 *      (Smarty online manual)
 | 
			
		||||
 * @version 1.3.4
 | 
			
		||||
 * @author Andrei Zmievski 
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_select_date($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.make_timestamp.php');
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'function.html_options.php');
 | 
			
		||||
 | 
			
		||||
    /* Default values. */
 | 
			
		||||
    $prefix = "Date_";
 | 
			
		||||
    $start_year = strftime("%Y");
 | 
			
		||||
    $end_year = $start_year;
 | 
			
		||||
    $display_days = true;
 | 
			
		||||
    $display_months = true;
 | 
			
		||||
    $display_years = true;
 | 
			
		||||
    $month_format = "%B";
 | 
			
		||||
    /* Write months as numbers by default  GL */
 | 
			
		||||
    $month_value_format = "%m";
 | 
			
		||||
    $day_format = "%02d";
 | 
			
		||||
    /* Write day values using this format MB */
 | 
			
		||||
    $day_value_format = "%d";
 | 
			
		||||
    $year_as_text = false;
 | 
			
		||||
    /* Display years in reverse order? Ie. 2000,1999,.... */
 | 
			
		||||
    $reverse_years = false;
 | 
			
		||||
    /* Should the select boxes be part of an array when returned from PHP?
 | 
			
		||||
       e.g. setting it to "birthday", would create "birthday[Day]",
 | 
			
		||||
       "birthday[Month]" & "birthday[Year]". Can be combined with prefix */
 | 
			
		||||
    $field_array = null;
 | 
			
		||||
    /* <select size>'s of the different <select> tags.
 | 
			
		||||
       If not set, uses default dropdown. */
 | 
			
		||||
    $day_size = null;
 | 
			
		||||
    $month_size = null;
 | 
			
		||||
    $year_size = null;
 | 
			
		||||
    /* Unparsed attributes common to *ALL* the <select>/<input> tags.
 | 
			
		||||
       An example might be in the template: all_extra ='class ="foo"'. */
 | 
			
		||||
    $all_extra = null;
 | 
			
		||||
    /* Separate attributes for the tags. */
 | 
			
		||||
    $day_extra = null;
 | 
			
		||||
    $month_extra = null;
 | 
			
		||||
    $year_extra = null;
 | 
			
		||||
    /* Order in which to display the fields.
 | 
			
		||||
       "D" -> day, "M" -> month, "Y" -> year. */
 | 
			
		||||
    $field_order = 'MDY';
 | 
			
		||||
    /* String printed between the different fields. */
 | 
			
		||||
    $field_separator = "\n";
 | 
			
		||||
    $time = time();
 | 
			
		||||
    $all_empty = null;
 | 
			
		||||
    $day_empty = null;
 | 
			
		||||
    $month_empty = null;
 | 
			
		||||
    $year_empty = null;
 | 
			
		||||
    $extra_attrs = '';
 | 
			
		||||
 | 
			
		||||
    foreach ($params as $_key => $_value) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'prefix':
 | 
			
		||||
            case 'time':
 | 
			
		||||
            case 'start_year':
 | 
			
		||||
            case 'end_year':
 | 
			
		||||
            case 'month_format':
 | 
			
		||||
            case 'day_format':
 | 
			
		||||
            case 'day_value_format':
 | 
			
		||||
            case 'field_array':
 | 
			
		||||
            case 'day_size':
 | 
			
		||||
            case 'month_size':
 | 
			
		||||
            case 'year_size':
 | 
			
		||||
            case 'all_extra':
 | 
			
		||||
            case 'day_extra':
 | 
			
		||||
            case 'month_extra':
 | 
			
		||||
            case 'year_extra':
 | 
			
		||||
            case 'field_order':
 | 
			
		||||
            case 'field_separator':
 | 
			
		||||
            case 'month_value_format':
 | 
			
		||||
            case 'month_empty':
 | 
			
		||||
            case 'day_empty':
 | 
			
		||||
            case 'year_empty':
 | 
			
		||||
                $$_key = (string)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'all_empty':
 | 
			
		||||
                $$_key = (string)$_value;
 | 
			
		||||
                $day_empty = $month_empty = $year_empty = $all_empty;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'display_days':
 | 
			
		||||
            case 'display_months':
 | 
			
		||||
            case 'display_years':
 | 
			
		||||
            case 'year_as_text':
 | 
			
		||||
            case 'reverse_years':
 | 
			
		||||
                $$_key = (bool)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                if (!is_array($_value)) {
 | 
			
		||||
                    $extra_attrs .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_value) . '"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    trigger_error("html_select_date: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (preg_match('!^-\d+$!', $time)) {
 | 
			
		||||
        // negative timestamp, use date()
 | 
			
		||||
        $time = date('Y-m-d', $time);
 | 
			
		||||
    } 
 | 
			
		||||
    // If $time is not in format yyyy-mm-dd
 | 
			
		||||
    if (preg_match('/^(\d{0,4}-\d{0,2}-\d{0,2})/', $time, $found)) {
 | 
			
		||||
        $time = $found[1];
 | 
			
		||||
    } else {
 | 
			
		||||
        // use smarty_make_timestamp to get an unix timestamp and
 | 
			
		||||
        // strftime to make yyyy-mm-dd
 | 
			
		||||
        $time = strftime('%Y-%m-%d', smarty_make_timestamp($time));
 | 
			
		||||
    } 
 | 
			
		||||
    // Now split this in pieces, which later can be used to set the select
 | 
			
		||||
    $time = explode("-", $time); 
 | 
			
		||||
    // make syntax "+N" or "-N" work with start_year and end_year
 | 
			
		||||
    if (preg_match('!^(\+|\-)\s*(\d+)$!', $end_year, $match)) {
 | 
			
		||||
        if ($match[1] == '+') {
 | 
			
		||||
            $end_year = strftime('%Y') + $match[2];
 | 
			
		||||
        } else {
 | 
			
		||||
            $end_year = strftime('%Y') - $match[2];
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    if (preg_match('!^(\+|\-)\s*(\d+)$!', $start_year, $match)) {
 | 
			
		||||
        if ($match[1] == '+') {
 | 
			
		||||
            $start_year = strftime('%Y') + $match[2];
 | 
			
		||||
        } else {
 | 
			
		||||
            $start_year = strftime('%Y') - $match[2];
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    if (strlen($time[0]) > 0) {
 | 
			
		||||
        if ($start_year > $time[0] && !isset($params['start_year'])) {
 | 
			
		||||
            // force start year to include given date if not explicitly set
 | 
			
		||||
            $start_year = $time[0];
 | 
			
		||||
        } 
 | 
			
		||||
        if ($end_year < $time[0] && !isset($params['end_year'])) {
 | 
			
		||||
            // force end year to include given date if not explicitly set
 | 
			
		||||
            $end_year = $time[0];
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $field_order = strtoupper($field_order);
 | 
			
		||||
 | 
			
		||||
    $html_result = $month_result = $day_result = $year_result = "";
 | 
			
		||||
 | 
			
		||||
    $field_separator_count = -1;
 | 
			
		||||
    if ($display_months) {
 | 
			
		||||
        $field_separator_count++;
 | 
			
		||||
        $month_names = array();
 | 
			
		||||
        $month_values = array();
 | 
			
		||||
        if (isset($month_empty)) {
 | 
			
		||||
            $month_names[''] = $month_empty;
 | 
			
		||||
            $month_values[''] = '';
 | 
			
		||||
        } 
 | 
			
		||||
        for ($i = 1; $i <= 12; $i++) {
 | 
			
		||||
            $month_names[$i] = strftime($month_format, mktime(0, 0, 0, $i, 1, 2000));
 | 
			
		||||
            $month_values[$i] = strftime($month_value_format, mktime(0, 0, 0, $i, 1, 2000));
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $month_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $month_result .= '"' . $field_array . '[' . $prefix . 'Month]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $month_result .= '"' . $prefix . 'Month"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $month_size) {
 | 
			
		||||
            $month_result .= ' size="' . $month_size . '"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $month_extra) {
 | 
			
		||||
            $month_result .= ' ' . $month_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $month_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $month_result .= $extra_attrs . '>' . "\n";
 | 
			
		||||
 | 
			
		||||
        $month_result .= smarty_function_html_options(array('output' => $month_names,
 | 
			
		||||
                'values' => $month_values,
 | 
			
		||||
                'selected' => (int)$time[1] ? strftime($month_value_format, mktime(0, 0, 0, (int)$time[1], 1, 2000)) : '',
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
                 $template);
 | 
			
		||||
        $month_result .= '</select>';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($display_days) {
 | 
			
		||||
        $field_separator_count++;
 | 
			
		||||
        $days = array();
 | 
			
		||||
        if (isset($day_empty)) {
 | 
			
		||||
            $days[''] = $day_empty;
 | 
			
		||||
            $day_values[''] = '';
 | 
			
		||||
        } 
 | 
			
		||||
        for ($i = 1; $i <= 31; $i++) {
 | 
			
		||||
            $days[] = sprintf($day_format, $i);
 | 
			
		||||
            $day_values[] = sprintf($day_value_format, $i);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $day_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $day_result .= '"' . $field_array . '[' . $prefix . 'Day]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $day_result .= '"' . $prefix . 'Day"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $day_size) {
 | 
			
		||||
            $day_result .= ' size="' . $day_size . '"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $day_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $day_extra) {
 | 
			
		||||
            $day_result .= ' ' . $day_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $day_result .= $extra_attrs . '>' . "\n";
 | 
			
		||||
        $day_result .= smarty_function_html_options(array('output' => $days,
 | 
			
		||||
                'values' => $day_values,
 | 
			
		||||
                'selected' => $time[2],
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
             $template);
 | 
			
		||||
        $day_result .= '</select>';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($display_years) {
 | 
			
		||||
        $field_separator_count++;
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $year_name = $field_array . '[' . $prefix . 'Year]';
 | 
			
		||||
        } else {
 | 
			
		||||
            $year_name = $prefix . 'Year';
 | 
			
		||||
        } 
 | 
			
		||||
        if ($year_as_text) {
 | 
			
		||||
            $year_result .= '<input type="text" name="' . $year_name . '" value="' . $time[0] . '" size="4" maxlength="4"';
 | 
			
		||||
            if (null !== $all_extra) {
 | 
			
		||||
                $year_result .= ' ' . $all_extra;
 | 
			
		||||
            } 
 | 
			
		||||
            if (null !== $year_extra) {
 | 
			
		||||
                $year_result .= ' ' . $year_extra;
 | 
			
		||||
            } 
 | 
			
		||||
            $year_result .= ' />';
 | 
			
		||||
        } else {
 | 
			
		||||
            $years = range((int)$start_year, (int)$end_year);
 | 
			
		||||
            if ($reverse_years) {
 | 
			
		||||
                rsort($years, SORT_NUMERIC);
 | 
			
		||||
            } else {
 | 
			
		||||
                sort($years, SORT_NUMERIC);
 | 
			
		||||
            } 
 | 
			
		||||
            $yearvals = $years;
 | 
			
		||||
            if (isset($year_empty)) {
 | 
			
		||||
                array_unshift($years, $year_empty);
 | 
			
		||||
                array_unshift($yearvals, '');
 | 
			
		||||
            } 
 | 
			
		||||
            $year_result .= '<select name="' . $year_name . '"';
 | 
			
		||||
            if (null !== $year_size) {
 | 
			
		||||
                $year_result .= ' size="' . $year_size . '"';
 | 
			
		||||
            } 
 | 
			
		||||
            if (null !== $all_extra) {
 | 
			
		||||
                $year_result .= ' ' . $all_extra;
 | 
			
		||||
            } 
 | 
			
		||||
            if (null !== $year_extra) {
 | 
			
		||||
                $year_result .= ' ' . $year_extra;
 | 
			
		||||
            } 
 | 
			
		||||
            $year_result .= $extra_attrs . '>' . "\n";
 | 
			
		||||
            $year_result .= smarty_function_html_options(array('output' => $years,
 | 
			
		||||
                    'values' => $yearvals,
 | 
			
		||||
                    'selected' => $time[0],
 | 
			
		||||
                    'print_result' => false),
 | 
			
		||||
                   $template);
 | 
			
		||||
            $year_result .= '</select>';
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    // Loop thru the field_order field
 | 
			
		||||
    for ($i = 0; $i <= 2; $i++) {
 | 
			
		||||
        $c = substr($field_order, $i, 1);
 | 
			
		||||
        switch ($c) {
 | 
			
		||||
            case 'D':
 | 
			
		||||
                $html_result .= $day_result;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'M':
 | 
			
		||||
                $html_result .= $month_result;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'Y':
 | 
			
		||||
                $html_result .= $year_result;
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
        // Add the field seperator
 | 
			
		||||
        if ($i < $field_separator_count) {
 | 
			
		||||
            $html_result .= $field_separator;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return $html_result;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										194
									
								
								site/stackreach/libs/plugins/function.html_select_time.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								site/stackreach/libs/plugins/function.html_select_time.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,194 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_select_time} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     html_select_time<br>
 | 
			
		||||
 * Purpose:  Prints the dropdowns for time selection
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.select.time.php {html_select_time}
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @author Roberto Berto <roberto@berto.net> 
 | 
			
		||||
 * @credits Monte Ohrt <monte AT ohrt DOT com>
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 * @uses smarty_make_timestamp()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_select_time($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.make_timestamp.php');
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'function.html_options.php');
 | 
			
		||||
 | 
			
		||||
    /* Default values. */
 | 
			
		||||
    $prefix = "Time_";
 | 
			
		||||
    $time = time();
 | 
			
		||||
    $display_hours = true;
 | 
			
		||||
    $display_minutes = true;
 | 
			
		||||
    $display_seconds = true;
 | 
			
		||||
    $display_meridian = true;
 | 
			
		||||
    $use_24_hours = true;
 | 
			
		||||
    $minute_interval = 1;
 | 
			
		||||
    $second_interval = 1;
 | 
			
		||||
    /* Should the select boxes be part of an array when returned from PHP?
 | 
			
		||||
       e.g. setting it to "birthday", would create "birthday[Hour]",
 | 
			
		||||
       "birthday[Minute]", "birthday[Seconds]" & "birthday[Meridian]".
 | 
			
		||||
       Can be combined with prefix. */
 | 
			
		||||
    $field_array = null;
 | 
			
		||||
    $all_extra = null;
 | 
			
		||||
    $hour_extra = null;
 | 
			
		||||
    $minute_extra = null;
 | 
			
		||||
    $second_extra = null;
 | 
			
		||||
    $meridian_extra = null;
 | 
			
		||||
 | 
			
		||||
    foreach ($params as $_key => $_value) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'prefix':
 | 
			
		||||
            case 'time':
 | 
			
		||||
            case 'field_array':
 | 
			
		||||
            case 'all_extra':
 | 
			
		||||
            case 'hour_extra':
 | 
			
		||||
            case 'minute_extra':
 | 
			
		||||
            case 'second_extra':
 | 
			
		||||
            case 'meridian_extra':
 | 
			
		||||
                $$_key = (string)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'display_hours':
 | 
			
		||||
            case 'display_minutes':
 | 
			
		||||
            case 'display_seconds':
 | 
			
		||||
            case 'display_meridian':
 | 
			
		||||
            case 'use_24_hours':
 | 
			
		||||
                $$_key = (bool)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'minute_interval':
 | 
			
		||||
            case 'second_interval':
 | 
			
		||||
                $$_key = (int)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                trigger_error("[html_select_time] unknown parameter $_key", E_USER_WARNING);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $time = smarty_make_timestamp($time);
 | 
			
		||||
 | 
			
		||||
    $html_result = '';
 | 
			
		||||
 | 
			
		||||
    if ($display_hours) {
 | 
			
		||||
        $hours = $use_24_hours ? range(0, 23) : range(1, 12);
 | 
			
		||||
        $hour_fmt = $use_24_hours ? '%H' : '%I';
 | 
			
		||||
        for ($i = 0, $for_max = count($hours); $i < $for_max; $i++)
 | 
			
		||||
        $hours[$i] = sprintf('%02d', $hours[$i]);
 | 
			
		||||
        $html_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $html_result .= '"' . $field_array . '[' . $prefix . 'Hour]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $html_result .= '"' . $prefix . 'Hour"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $hour_extra) {
 | 
			
		||||
            $html_result .= ' ' . $hour_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $html_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $html_result .= '>' . "\n";
 | 
			
		||||
        $html_result .= smarty_function_html_options(array('output' => $hours,
 | 
			
		||||
                'values' => $hours,
 | 
			
		||||
                'selected' => strftime($hour_fmt, $time),
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
            $template);
 | 
			
		||||
        $html_result .= "</select>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($display_minutes) {
 | 
			
		||||
        $all_minutes = range(0, 59);
 | 
			
		||||
        for ($i = 0, $for_max = count($all_minutes); $i < $for_max; $i += $minute_interval)
 | 
			
		||||
        $minutes[] = sprintf('%02d', $all_minutes[$i]);
 | 
			
		||||
        $selected = intval(floor(strftime('%M', $time) / $minute_interval) * $minute_interval);
 | 
			
		||||
        $html_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $html_result .= '"' . $field_array . '[' . $prefix . 'Minute]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $html_result .= '"' . $prefix . 'Minute"';
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $minute_extra) {
 | 
			
		||||
            $html_result .= ' ' . $minute_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $html_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $html_result .= '>' . "\n";
 | 
			
		||||
 | 
			
		||||
        $html_result .= smarty_function_html_options(array('output' => $minutes,
 | 
			
		||||
                'values' => $minutes,
 | 
			
		||||
                'selected' => $selected,
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
              $template);
 | 
			
		||||
        $html_result .= "</select>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($display_seconds) {
 | 
			
		||||
        $all_seconds = range(0, 59);
 | 
			
		||||
        for ($i = 0, $for_max = count($all_seconds); $i < $for_max; $i += $second_interval)
 | 
			
		||||
        $seconds[] = sprintf('%02d', $all_seconds[$i]);
 | 
			
		||||
        $selected = intval(floor(strftime('%S', $time) / $second_interval) * $second_interval);
 | 
			
		||||
        $html_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $html_result .= '"' . $field_array . '[' . $prefix . 'Second]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $html_result .= '"' . $prefix . 'Second"';
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (null !== $second_extra) {
 | 
			
		||||
            $html_result .= ' ' . $second_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $html_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $html_result .= '>' . "\n";
 | 
			
		||||
 | 
			
		||||
        $html_result .= smarty_function_html_options(array('output' => $seconds,
 | 
			
		||||
                'values' => $seconds,
 | 
			
		||||
                'selected' => $selected,
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
             $template);
 | 
			
		||||
        $html_result .= "</select>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($display_meridian && !$use_24_hours) {
 | 
			
		||||
        $html_result .= '<select name=';
 | 
			
		||||
        if (null !== $field_array) {
 | 
			
		||||
            $html_result .= '"' . $field_array . '[' . $prefix . 'Meridian]"';
 | 
			
		||||
        } else {
 | 
			
		||||
            $html_result .= '"' . $prefix . 'Meridian"';
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (null !== $meridian_extra) {
 | 
			
		||||
            $html_result .= ' ' . $meridian_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        if (null !== $all_extra) {
 | 
			
		||||
            $html_result .= ' ' . $all_extra;
 | 
			
		||||
        } 
 | 
			
		||||
        $html_result .= '>' . "\n";
 | 
			
		||||
 | 
			
		||||
        $html_result .= smarty_function_html_options(array('output' => array('AM', 'PM'),
 | 
			
		||||
                'values' => array('am', 'pm'),
 | 
			
		||||
                'selected' => strtolower(strftime('%p', $time)),
 | 
			
		||||
                'print_result' => false),
 | 
			
		||||
            $template);
 | 
			
		||||
        $html_result .= "</select>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return $html_result;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										177
									
								
								site/stackreach/libs/plugins/function.html_table.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								site/stackreach/libs/plugins/function.html_table.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,177 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {html_table} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     html_table<br>
 | 
			
		||||
 * Date:     Feb 17, 2003<br>
 | 
			
		||||
 * Purpose:  make an html table from an array of data<br>
 | 
			
		||||
 * 
 | 
			
		||||
 * 
 | 
			
		||||
 * Examples:
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * {table loop=$data}
 | 
			
		||||
 * {table loop=$data cols=4 tr_attr='"bgcolor=red"'}
 | 
			
		||||
 * {table loop=$data cols="first,second,third" tr_attr=$colors}
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * 
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author credit to Messju Mohr <messju at lammfellpuschen dot de> 
 | 
			
		||||
 * @author credit to boots <boots dot smarty at yahoo dot com> 
 | 
			
		||||
 * @version 1.1
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.html.table.php {html_table}
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *          - loop = array to loop through
 | 
			
		||||
 *          - cols = number of columns, comma separated list of column names
 | 
			
		||||
 *                   or array of column names
 | 
			
		||||
 *          - rows = number of rows
 | 
			
		||||
 *          - table_attr = table attributes
 | 
			
		||||
 *          - th_attr = table heading attributes (arrays are cycled)
 | 
			
		||||
 *          - tr_attr = table row attributes (arrays are cycled)
 | 
			
		||||
 *          - td_attr = table cell attributes (arrays are cycled)
 | 
			
		||||
 *          - trailpad = value to pad trailing cells with
 | 
			
		||||
 *          - caption = text for caption element 
 | 
			
		||||
 *          - vdir = vertical direction (default: "down", means top-to-bottom)
 | 
			
		||||
 *          - hdir = horizontal direction (default: "right", means left-to-right)
 | 
			
		||||
 *          - inner = inner loop (default "cols": print $loop line by line,
 | 
			
		||||
 *                    $loop will be printed column by column otherwise)
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_html_table($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    $table_attr = 'border="1"';
 | 
			
		||||
    $tr_attr = '';
 | 
			
		||||
    $th_attr = '';
 | 
			
		||||
    $td_attr = '';
 | 
			
		||||
    $cols = $cols_count = 3;
 | 
			
		||||
    $rows = 3;
 | 
			
		||||
    $trailpad = ' ';
 | 
			
		||||
    $vdir = 'down';
 | 
			
		||||
    $hdir = 'right';
 | 
			
		||||
    $inner = 'cols';
 | 
			
		||||
    $caption = '';
 | 
			
		||||
    $loop = null;
 | 
			
		||||
 | 
			
		||||
    if (!isset($params['loop'])) {
 | 
			
		||||
        trigger_error("html_table: missing 'loop' parameter",E_USER_WARNING);
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    foreach ($params as $_key => $_value) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'loop':
 | 
			
		||||
                $$_key = (array)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'cols':
 | 
			
		||||
                if (is_array($_value) && !empty($_value)) {
 | 
			
		||||
                    $cols = $_value;
 | 
			
		||||
                    $cols_count = count($_value);
 | 
			
		||||
                } elseif (!is_numeric($_value) && is_string($_value) && !empty($_value)) {
 | 
			
		||||
                    $cols = explode(',', $_value);
 | 
			
		||||
                    $cols_count = count($cols);
 | 
			
		||||
                } elseif (!empty($_value)) {
 | 
			
		||||
                    $cols_count = (int)$_value;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $cols_count = $cols;
 | 
			
		||||
                } 
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'rows':
 | 
			
		||||
                $$_key = (int)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'table_attr':
 | 
			
		||||
            case 'trailpad':
 | 
			
		||||
            case 'hdir':
 | 
			
		||||
            case 'vdir':
 | 
			
		||||
            case 'inner':
 | 
			
		||||
            case 'caption':
 | 
			
		||||
                $$_key = (string)$_value;
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'tr_attr':
 | 
			
		||||
            case 'td_attr':
 | 
			
		||||
            case 'th_attr':
 | 
			
		||||
                $$_key = $_value;
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $loop_count = count($loop);
 | 
			
		||||
    if (empty($params['rows'])) {
 | 
			
		||||
        /* no rows specified */
 | 
			
		||||
        $rows = ceil($loop_count / $cols_count);
 | 
			
		||||
    } elseif (empty($params['cols'])) {
 | 
			
		||||
        if (!empty($params['rows'])) {
 | 
			
		||||
            /* no cols specified, but rows */
 | 
			
		||||
            $cols_count = ceil($loop_count / $rows);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $output = "<table $table_attr>\n";
 | 
			
		||||
 | 
			
		||||
    if (!empty($caption)) {
 | 
			
		||||
        $output .= '<caption>' . $caption . "</caption>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if (is_array($cols)) {
 | 
			
		||||
        $cols = ($hdir == 'right') ? $cols : array_reverse($cols);
 | 
			
		||||
        $output .= "<thead><tr>\n";
 | 
			
		||||
 | 
			
		||||
        for ($r = 0; $r < $cols_count; $r++) {
 | 
			
		||||
            $output .= '<th' . smarty_function_html_table_cycle('th', $th_attr, $r) . '>';
 | 
			
		||||
            $output .= $cols[$r];
 | 
			
		||||
            $output .= "</th>\n";
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= "</tr></thead>\n";
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $output .= "<tbody>\n";
 | 
			
		||||
    for ($r = 0; $r < $rows; $r++) {
 | 
			
		||||
        $output .= "<tr" . smarty_function_html_table_cycle('tr', $tr_attr, $r) . ">\n";
 | 
			
		||||
        $rx = ($vdir == 'down') ? $r * $cols_count : ($rows-1 - $r) * $cols_count;
 | 
			
		||||
 | 
			
		||||
        for ($c = 0; $c < $cols_count; $c++) {
 | 
			
		||||
            $x = ($hdir == 'right') ? $rx + $c : $rx + $cols_count-1 - $c;
 | 
			
		||||
            if ($inner != 'cols') {
 | 
			
		||||
                /* shuffle x to loop over rows*/
 | 
			
		||||
                $x = floor($x / $cols_count) + ($x % $cols_count) * $rows;
 | 
			
		||||
            } 
 | 
			
		||||
 | 
			
		||||
            if ($x < $loop_count) {
 | 
			
		||||
                $output .= "<td" . smarty_function_html_table_cycle('td', $td_attr, $c) . ">" . $loop[$x] . "</td>\n";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output .= "<td" . smarty_function_html_table_cycle('td', $td_attr, $c) . ">$trailpad</td>\n";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= "</tr>\n";
 | 
			
		||||
    } 
 | 
			
		||||
    $output .= "</tbody>\n";
 | 
			
		||||
    $output .= "</table>\n";
 | 
			
		||||
 | 
			
		||||
    return $output;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
function smarty_function_html_table_cycle($name, $var, $no)
 | 
			
		||||
{
 | 
			
		||||
    if (!is_array($var)) {
 | 
			
		||||
        $ret = $var;
 | 
			
		||||
    } else {
 | 
			
		||||
        $ret = $var[$no % count($var)];
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return ($ret) ? ' ' . $ret : '';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										156
									
								
								site/stackreach/libs/plugins/function.mailto.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										156
									
								
								site/stackreach/libs/plugins/function.mailto.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,156 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {mailto} function plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     mailto<br>
 | 
			
		||||
 * Date:     May 21, 2002
 | 
			
		||||
 * Purpose:  automate mailto address link creation, and optionally
 | 
			
		||||
 *            encode them.<br>
 | 
			
		||||
 * 
 | 
			
		||||
 * Examples:
 | 
			
		||||
 * <pre>
 | 
			
		||||
 * {mailto address="me@domain.com"}
 | 
			
		||||
 * {mailto address="me@domain.com" encode="javascript"}
 | 
			
		||||
 * {mailto address="me@domain.com" encode="hex"}
 | 
			
		||||
 * {mailto address="me@domain.com" subject="Hello to you!"}
 | 
			
		||||
 * {mailto address="me@domain.com" cc="you@domain.com,they@domain.com"}
 | 
			
		||||
 * {mailto address="me@domain.com" extra='class="mailto"'}
 | 
			
		||||
 * </pre>
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.mailto.php {mailto}
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @version 1.2
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author credits to Jason Sweat (added cc, bcc and subject functionality) 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *          - address = e-mail address
 | 
			
		||||
 *          - text = (optional) text to display, default is address
 | 
			
		||||
 *          - encode = (optional) can be one of:
 | 
			
		||||
 *                 * none : no encoding (default)
 | 
			
		||||
 *                 * javascript : encode with javascript
 | 
			
		||||
 *                 * javascript_charcode : encode with javascript charcode
 | 
			
		||||
 *                 * hex : encode with hexidecimal (no javascript)
 | 
			
		||||
 *          - cc = (optional) address(es) to carbon copy
 | 
			
		||||
 *          - bcc = (optional) address(es) to blind carbon copy
 | 
			
		||||
 *          - subject = (optional) e-mail subject
 | 
			
		||||
 *          - newsgroups = (optional) newsgroup(s) to post to
 | 
			
		||||
 *          - followupto = (optional) address(es) to follow up to
 | 
			
		||||
 *          - extra = (optional) extra tags for the href link
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_mailto($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    $extra = '';
 | 
			
		||||
 | 
			
		||||
    if (empty($params['address'])) {
 | 
			
		||||
        trigger_error("mailto: missing 'address' parameter",E_USER_WARNING);
 | 
			
		||||
        return;
 | 
			
		||||
    } else {
 | 
			
		||||
        $address = $params['address'];
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $text = $address; 
 | 
			
		||||
    // netscape and mozilla do not decode %40 (@) in BCC field (bug?)
 | 
			
		||||
    // so, don't encode it.
 | 
			
		||||
    $search = array('%40', '%2C');
 | 
			
		||||
    $replace = array('@', ',');
 | 
			
		||||
    $mail_parms = array();
 | 
			
		||||
    foreach ($params as $var => $value) {
 | 
			
		||||
        switch ($var) {
 | 
			
		||||
            case 'cc':
 | 
			
		||||
            case 'bcc':
 | 
			
		||||
            case 'followupto':
 | 
			
		||||
                if (!empty($value))
 | 
			
		||||
                    $mail_parms[] = $var . '=' . str_replace($search, $replace, rawurlencode($value));
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'subject':
 | 
			
		||||
            case 'newsgroups':
 | 
			
		||||
                $mail_parms[] = $var . '=' . rawurlencode($value);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'extra':
 | 
			
		||||
            case 'text':
 | 
			
		||||
                $$var = $value;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    $mail_parm_vals = '';
 | 
			
		||||
    for ($i = 0; $i < count($mail_parms); $i++) {
 | 
			
		||||
        $mail_parm_vals .= (0 == $i) ? '?' : '&';
 | 
			
		||||
        $mail_parm_vals .= $mail_parms[$i];
 | 
			
		||||
    } 
 | 
			
		||||
    $address .= $mail_parm_vals;
 | 
			
		||||
 | 
			
		||||
    $encode = (empty($params['encode'])) ? 'none' : $params['encode'];
 | 
			
		||||
    if (!in_array($encode, array('javascript', 'javascript_charcode', 'hex', 'none'))) {
 | 
			
		||||
        trigger_error("mailto: 'encode' parameter must be none, javascript or hex",E_USER_WARNING);
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    if ($encode == 'javascript') {
 | 
			
		||||
        $string = 'document.write(\'<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>\');';
 | 
			
		||||
 | 
			
		||||
        $js_encode = '';
 | 
			
		||||
        for ($x = 0; $x < strlen($string); $x++) {
 | 
			
		||||
            $js_encode .= '%' . bin2hex($string[$x]);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        return '<script type="text/javascript">eval(unescape(\'' . $js_encode . '\'))</script>';
 | 
			
		||||
    } elseif ($encode == 'javascript_charcode') {
 | 
			
		||||
        $string = '<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>';
 | 
			
		||||
 | 
			
		||||
        for($x = 0, $y = strlen($string); $x < $y; $x++) {
 | 
			
		||||
            $ord[] = ord($string[$x]);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $_ret = "<script type=\"text/javascript\" language=\"javascript\">\n";
 | 
			
		||||
        $_ret .= "<!--\n";
 | 
			
		||||
        $_ret .= "{document.write(String.fromCharCode(";
 | 
			
		||||
        $_ret .= implode(',', $ord);
 | 
			
		||||
        $_ret .= "))";
 | 
			
		||||
        $_ret .= "}\n";
 | 
			
		||||
        $_ret .= "//-->\n";
 | 
			
		||||
        $_ret .= "</script>\n";
 | 
			
		||||
 | 
			
		||||
        return $_ret;
 | 
			
		||||
    } elseif ($encode == 'hex') {
 | 
			
		||||
        preg_match('!^(.*)(\?.*)$!', $address, $match);
 | 
			
		||||
        if (!empty($match[2])) {
 | 
			
		||||
            trigger_error("mailto: hex encoding does not work with extra attributes. Try javascript.",E_USER_WARNING);
 | 
			
		||||
            return;
 | 
			
		||||
        } 
 | 
			
		||||
        $address_encode = '';
 | 
			
		||||
        for ($x = 0; $x < strlen($address); $x++) {
 | 
			
		||||
            if (preg_match('!\w!', $address[$x])) {
 | 
			
		||||
                $address_encode .= '%' . bin2hex($address[$x]);
 | 
			
		||||
            } else {
 | 
			
		||||
                $address_encode .= $address[$x];
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $text_encode = '';
 | 
			
		||||
        for ($x = 0; $x < strlen($text); $x++) {
 | 
			
		||||
            $text_encode .= '&#x' . bin2hex($text[$x]) . ';';
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $mailto = "mailto:";
 | 
			
		||||
        return '<a href="' . $mailto . $address_encode . '" ' . $extra . '>' . $text_encode . '</a>';
 | 
			
		||||
    } else {
 | 
			
		||||
        // no encoding
 | 
			
		||||
        return '<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										83
									
								
								site/stackreach/libs/plugins/function.math.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								site/stackreach/libs/plugins/function.math.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,83 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * This plugin is only for Smarty2 BC
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {math} function plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     math<br>
 | 
			
		||||
 * Purpose:  handle math computations in template<br>
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.math.php {math}
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string|null
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_math($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    // be sure equation parameter is present
 | 
			
		||||
    if (empty($params['equation'])) {
 | 
			
		||||
        trigger_error("math: missing equation parameter",E_USER_WARNING);
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    $equation = $params['equation'];
 | 
			
		||||
 | 
			
		||||
    // make sure parenthesis are balanced
 | 
			
		||||
    if (substr_count($equation,"(") != substr_count($equation,")")) {
 | 
			
		||||
        trigger_error("math: unbalanced parenthesis",E_USER_WARNING);
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // match all vars in equation, make sure all are passed
 | 
			
		||||
    preg_match_all("!(?:0x[a-fA-F0-9]+)|([a-zA-Z][a-zA-Z0-9_]*)!",$equation, $match);
 | 
			
		||||
    $allowed_funcs = array('int','abs','ceil','cos','exp','floor','log','log10',
 | 
			
		||||
                           'max','min','pi','pow','rand','round','sin','sqrt','srand','tan');
 | 
			
		||||
    
 | 
			
		||||
    foreach($match[1] as $curr_var) {
 | 
			
		||||
        if ($curr_var && !in_array($curr_var, array_keys($params)) && !in_array($curr_var, $allowed_funcs)) {
 | 
			
		||||
            trigger_error("math: function call $curr_var not allowed",E_USER_WARNING);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    foreach($params as $key => $val) {
 | 
			
		||||
        if ($key != "equation" && $key != "format" && $key != "assign") {
 | 
			
		||||
            // make sure value is not empty
 | 
			
		||||
            if (strlen($val)==0) {
 | 
			
		||||
                trigger_error("math: parameter $key is empty",E_USER_WARNING);
 | 
			
		||||
                return;
 | 
			
		||||
            }
 | 
			
		||||
            if (!is_numeric($val)) {
 | 
			
		||||
                trigger_error("math: parameter $key: is not numeric",E_USER_WARNING);
 | 
			
		||||
                return;
 | 
			
		||||
            }
 | 
			
		||||
            $equation = preg_replace("/\b$key\b/", " \$params['$key'] ", $equation);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    $smarty_math_result = null;
 | 
			
		||||
    eval("\$smarty_math_result = ".$equation.";");
 | 
			
		||||
 | 
			
		||||
    if (empty($params['format'])) {
 | 
			
		||||
        if (empty($params['assign'])) {
 | 
			
		||||
            return $smarty_math_result;
 | 
			
		||||
        } else {
 | 
			
		||||
            $template->assign($params['assign'],$smarty_math_result);
 | 
			
		||||
        }
 | 
			
		||||
    } else {
 | 
			
		||||
        if (empty($params['assign'])){
 | 
			
		||||
            printf($params['format'],$smarty_math_result);
 | 
			
		||||
        } else {
 | 
			
		||||
            $template->assign($params['assign'],sprintf($params['format'],$smarty_math_result));
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										118
									
								
								site/stackreach/libs/plugins/function.popup.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								site/stackreach/libs/plugins/function.popup.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,118 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFunction
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty {popup} function plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     function<br>
 | 
			
		||||
 * Name:     popup<br>
 | 
			
		||||
 * Purpose:  make text pop up in windows via overlib
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.function.popup.php {popup}
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @param object $template template object
 | 
			
		||||
 * @return string
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_popup($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    $append = '';
 | 
			
		||||
    foreach ($params as $_key=>$_value) {
 | 
			
		||||
        switch ($_key) {
 | 
			
		||||
            case 'text':
 | 
			
		||||
            case 'trigger':
 | 
			
		||||
            case 'function':
 | 
			
		||||
            case 'inarray':
 | 
			
		||||
                $$_key = (string)$_value;
 | 
			
		||||
                if ($_key == 'function' || $_key == 'inarray')
 | 
			
		||||
                    $append .= ',' . strtoupper($_key) . ",'$_value'";
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'caption':
 | 
			
		||||
            case 'closetext':
 | 
			
		||||
            case 'status':
 | 
			
		||||
                $append .= ',' . strtoupper($_key) . ",'" . str_replace("'","\'",$_value) . "'";
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'fgcolor':
 | 
			
		||||
            case 'bgcolor':
 | 
			
		||||
            case 'textcolor':
 | 
			
		||||
            case 'capcolor':
 | 
			
		||||
            case 'closecolor':
 | 
			
		||||
            case 'textfont':
 | 
			
		||||
            case 'captionfont':
 | 
			
		||||
            case 'closefont':
 | 
			
		||||
            case 'fgbackground':
 | 
			
		||||
            case 'bgbackground':
 | 
			
		||||
            case 'caparray':
 | 
			
		||||
            case 'capicon':
 | 
			
		||||
            case 'background':
 | 
			
		||||
            case 'frame':
 | 
			
		||||
                $append .= ',' . strtoupper($_key) . ",'$_value'";
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'textsize':
 | 
			
		||||
            case 'captionsize':
 | 
			
		||||
            case 'closesize':
 | 
			
		||||
            case 'width':
 | 
			
		||||
            case 'height':
 | 
			
		||||
            case 'border':
 | 
			
		||||
            case 'offsetx':
 | 
			
		||||
            case 'offsety':
 | 
			
		||||
            case 'snapx':
 | 
			
		||||
            case 'snapy':
 | 
			
		||||
            case 'fixx':
 | 
			
		||||
            case 'fixy':
 | 
			
		||||
            case 'padx':
 | 
			
		||||
            case 'pady':
 | 
			
		||||
            case 'timeout':
 | 
			
		||||
            case 'delay':
 | 
			
		||||
                $append .= ',' . strtoupper($_key) . ",$_value";
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'sticky':
 | 
			
		||||
            case 'left':
 | 
			
		||||
            case 'right':
 | 
			
		||||
            case 'center':
 | 
			
		||||
            case 'above':
 | 
			
		||||
            case 'below':
 | 
			
		||||
            case 'noclose':
 | 
			
		||||
            case 'autostatus':
 | 
			
		||||
            case 'autostatuscap':
 | 
			
		||||
            case 'fullhtml':
 | 
			
		||||
            case 'hauto':
 | 
			
		||||
            case 'vauto':
 | 
			
		||||
            case 'mouseoff':
 | 
			
		||||
            case 'followmouse':
 | 
			
		||||
            case 'closeclick':
 | 
			
		||||
            case 'wrap':
 | 
			
		||||
                if ($_value) $append .= ',' . strtoupper($_key);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                trigger_error("[popup] unknown parameter $_key", E_USER_WARNING);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (empty($text) && !isset($inarray) && empty($function)) {
 | 
			
		||||
        trigger_error("overlib: attribute 'text' or 'inarray' or 'function' required",E_USER_WARNING);
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (empty($trigger)) { $trigger = "onmouseover"; }
 | 
			
		||||
 | 
			
		||||
    $retval = $trigger . '="return overlib(\''.preg_replace(array("!'!",'!"!',"![\r\n]!"),array("\'","\'",'\r'),$text).'\'';
 | 
			
		||||
    $retval .= $append . ');"';
 | 
			
		||||
    if ($trigger == 'onmouseover')
 | 
			
		||||
       $retval .= ' onmouseout="nd();"';
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    return $retval;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										39
									
								
								site/stackreach/libs/plugins/function.popup_init.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								site/stackreach/libs/plugins/function.popup_init.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
  * Smarty plugin
 | 
			
		||||
  *
 | 
			
		||||
  * @package Smarty
 | 
			
		||||
  * @subpackage PluginsFunction
 | 
			
		||||
  */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
  * Smarty {popup_init} function plugin
 | 
			
		||||
  *
 | 
			
		||||
  * Type:     function<br>
 | 
			
		||||
  * Name:     popup_init<br>
 | 
			
		||||
  * Purpose:  initialize overlib
 | 
			
		||||
  * @link http://smarty.php.net/manual/en/language.function.popup.init.php {popup_init}
 | 
			
		||||
  *          (Smarty online manual)
 | 
			
		||||
  * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
  * @param array $params parameters
 | 
			
		||||
  * @param object $template template object
 | 
			
		||||
  * @return string 
 | 
			
		||||
  */
 | 
			
		||||
 | 
			
		||||
function smarty_function_popup_init($params, $template)
 | 
			
		||||
{
 | 
			
		||||
    $zindex = 1000;
 | 
			
		||||
    
 | 
			
		||||
    if (!empty($params['zindex'])) {
 | 
			
		||||
        $zindex = $params['zindex'];
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    if (!empty($params['src'])) {
 | 
			
		||||
        return '<div id="overDiv" style="position:absolute; visibility:hidden; z-index:'.$zindex.';"></div>' . "\n"
 | 
			
		||||
         . '<script type="text/javascript" language="JavaScript" src="'.$params['src'].'"></script>' . "\n";
 | 
			
		||||
    } else {
 | 
			
		||||
        trigger_error("popup_init: missing src parameter",E_USER_WARNING);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										37
									
								
								site/stackreach/libs/plugins/modifier.capitalize.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								site/stackreach/libs/plugins/modifier.capitalize.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,37 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty capitalize modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     capitalize<br>
 | 
			
		||||
 * Purpose:  capitalize words in the string
 | 
			
		||||
 * 
 | 
			
		||||
 * @link 
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_capitalize($string, $uc_digits = false)
 | 
			
		||||
{ 
 | 
			
		||||
    // uppercase with php function ucwords
 | 
			
		||||
    $upper_string = ucwords($string); 
 | 
			
		||||
    // check for any missed hyphenated words
 | 
			
		||||
    $upper_string = preg_replace("!(^|[^\p{L}'])([\p{Ll}])!ue", "'\\1'.ucfirst('\\2')", $upper_string); 
 | 
			
		||||
    // check uc_digits case
 | 
			
		||||
    if (!$uc_digits) {
 | 
			
		||||
        if (preg_match_all("!\b([\p{L}]*[\p{N}]+[\p{L}]*)\b!u", $string, $matches, PREG_OFFSET_CAPTURE)) {
 | 
			
		||||
            foreach($matches[1] as $match)
 | 
			
		||||
            $upper_string = substr_replace($upper_string, $match[0], $match[1], strlen($match[0]));
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    return $upper_string;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										61
									
								
								site/stackreach/libs/plugins/modifier.date_format.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								site/stackreach/libs/plugins/modifier.date_format.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,61 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty date_format modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     date_format<br>
 | 
			
		||||
 * Purpose:  format datestamps via strftime<br>
 | 
			
		||||
 * Input:<br>
 | 
			
		||||
 *          - string: input date string
 | 
			
		||||
 *          - format: strftime format for output
 | 
			
		||||
 *          - default_date: default date if $string is empty
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.date.format.php date_format (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @return string |void
 | 
			
		||||
 * @uses smarty_make_timestamp()
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_date_format($string, $format = SMARTY_RESOURCE_DATE_FORMAT, $default_date = '',$formatter='auto')
 | 
			
		||||
{
 | 
			
		||||
    /**
 | 
			
		||||
    * Include the {@link shared.make_timestamp.php} plugin
 | 
			
		||||
    */
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.make_timestamp.php');
 | 
			
		||||
    if ($string != '') {
 | 
			
		||||
        $timestamp = smarty_make_timestamp($string);
 | 
			
		||||
    } elseif ($default_date != '') {
 | 
			
		||||
        $timestamp = smarty_make_timestamp($default_date);
 | 
			
		||||
    } else {
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
    if($formatter=='strftime'||($formatter=='auto'&&strpos($format,'%')!==false)) {
 | 
			
		||||
        if (DS == '\\') {
 | 
			
		||||
            $_win_from = array('%D', '%h', '%n', '%r', '%R', '%t', '%T');
 | 
			
		||||
            $_win_to = array('%m/%d/%y', '%b', "\n", '%I:%M:%S %p', '%H:%M', "\t", '%H:%M:%S');
 | 
			
		||||
            if (strpos($format, '%e') !== false) {
 | 
			
		||||
                $_win_from[] = '%e';
 | 
			
		||||
                $_win_to[] = sprintf('%\' 2d', date('j', $timestamp));
 | 
			
		||||
            } 
 | 
			
		||||
            if (strpos($format, '%l') !== false) {
 | 
			
		||||
                $_win_from[] = '%l';
 | 
			
		||||
                $_win_to[] = sprintf('%\' 2d', date('h', $timestamp));
 | 
			
		||||
            } 
 | 
			
		||||
            $format = str_replace($_win_from, $_win_to, $format);
 | 
			
		||||
        } 
 | 
			
		||||
        return strftime($format, $timestamp);
 | 
			
		||||
    } else {
 | 
			
		||||
        return date($format, $timestamp);
 | 
			
		||||
    }
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										87
									
								
								site/stackreach/libs/plugins/modifier.debug_print_var.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								site/stackreach/libs/plugins/modifier.debug_print_var.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,87 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Debug
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty debug_print_var modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     debug_print_var<br>
 | 
			
		||||
 * Purpose:  formats variable contents for display in the console
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.debug.print.var.php debug_print_var (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param array $ |object
 | 
			
		||||
 * @param integer $ 
 | 
			
		||||
 * @param integer $ 
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_debug_print_var ($var, $depth = 0, $length = 40)
 | 
			
		||||
{
 | 
			
		||||
    $_replace = array("\n" => '<i>\n</i>',
 | 
			
		||||
        "\r" => '<i>\r</i>',
 | 
			
		||||
        "\t" => '<i>\t</i>'
 | 
			
		||||
        );
 | 
			
		||||
 | 
			
		||||
    switch (gettype($var)) {
 | 
			
		||||
        case 'array' :
 | 
			
		||||
            $results = '<b>Array (' . count($var) . ')</b>';
 | 
			
		||||
            foreach ($var as $curr_key => $curr_val) {
 | 
			
		||||
                $results .= '<br>' . str_repeat(' ', $depth * 2)
 | 
			
		||||
                 . '<b>' . strtr($curr_key, $_replace) . '</b> => '
 | 
			
		||||
                 . smarty_modifier_debug_print_var($curr_val, ++$depth, $length);
 | 
			
		||||
                $depth--;
 | 
			
		||||
            } 
 | 
			
		||||
            break;
 | 
			
		||||
        case 'object' :
 | 
			
		||||
            $object_vars = get_object_vars($var);
 | 
			
		||||
            $results = '<b>' . get_class($var) . ' Object (' . count($object_vars) . ')</b>';
 | 
			
		||||
            foreach ($object_vars as $curr_key => $curr_val) {
 | 
			
		||||
                $results .= '<br>' . str_repeat(' ', $depth * 2)
 | 
			
		||||
                 . '<b> ->' . strtr($curr_key, $_replace) . '</b> = '
 | 
			
		||||
                 . smarty_modifier_debug_print_var($curr_val, ++$depth, $length);
 | 
			
		||||
                $depth--;
 | 
			
		||||
            } 
 | 
			
		||||
            break;
 | 
			
		||||
        case 'boolean' :
 | 
			
		||||
        case 'NULL' :
 | 
			
		||||
        case 'resource' :
 | 
			
		||||
            if (true === $var) {
 | 
			
		||||
                $results = 'true';
 | 
			
		||||
            } elseif (false === $var) {
 | 
			
		||||
                $results = 'false';
 | 
			
		||||
            } elseif (null === $var) {
 | 
			
		||||
                $results = 'null';
 | 
			
		||||
            } else {
 | 
			
		||||
                $results = htmlspecialchars((string) $var);
 | 
			
		||||
            } 
 | 
			
		||||
            $results = '<i>' . $results . '</i>';
 | 
			
		||||
            break;
 | 
			
		||||
        case 'integer' :
 | 
			
		||||
        case 'float' :
 | 
			
		||||
            $results = htmlspecialchars((string) $var);
 | 
			
		||||
            break;
 | 
			
		||||
        case 'string' :
 | 
			
		||||
            $results = strtr($var, $_replace);
 | 
			
		||||
            if (strlen($var) > $length) {
 | 
			
		||||
                $results = substr($var, 0, $length - 3) . '...';
 | 
			
		||||
            } 
 | 
			
		||||
            $results = htmlspecialchars('"' . $results . '"');
 | 
			
		||||
            break;
 | 
			
		||||
        case 'unknown type' :
 | 
			
		||||
        default :
 | 
			
		||||
            $results = strtr((string) $var, $_replace);
 | 
			
		||||
            if (strlen($results) > $length) {
 | 
			
		||||
                $results = substr($results, 0, $length - 3) . '...';
 | 
			
		||||
            } 
 | 
			
		||||
            $results = htmlspecialchars($results);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    return $results;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										91
									
								
								site/stackreach/libs/plugins/modifier.escape.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								site/stackreach/libs/plugins/modifier.escape.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,91 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty escape modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     escape<br>
 | 
			
		||||
 * Purpose:  escape string for output
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.count.characters.php count_characters (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $string input string
 | 
			
		||||
 * @param string $esc_type escape type
 | 
			
		||||
 * @param string $char_set character set
 | 
			
		||||
 * @return string escaped input string
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_escape($string, $esc_type = 'html', $char_set = SMARTY_RESOURCE_CHAR_SET)
 | 
			
		||||
{
 | 
			
		||||
    switch ($esc_type) {
 | 
			
		||||
        case 'html':
 | 
			
		||||
            return htmlspecialchars($string, ENT_QUOTES, $char_set);
 | 
			
		||||
 | 
			
		||||
        case 'htmlall':
 | 
			
		||||
            return htmlentities($string, ENT_QUOTES, $char_set);
 | 
			
		||||
 | 
			
		||||
        case 'url':
 | 
			
		||||
            return rawurlencode($string);
 | 
			
		||||
 | 
			
		||||
        case 'urlpathinfo':
 | 
			
		||||
            return str_replace('%2F', '/', rawurlencode($string));
 | 
			
		||||
 | 
			
		||||
        case 'quotes': 
 | 
			
		||||
            // escape unescaped single quotes
 | 
			
		||||
            return preg_replace("%(?<!\\\\)'%", "\\'", $string);
 | 
			
		||||
 | 
			
		||||
        case 'hex': 
 | 
			
		||||
            // escape every character into hex
 | 
			
		||||
            $return = '';
 | 
			
		||||
            for ($x = 0; $x < strlen($string); $x++) {
 | 
			
		||||
                $return .= '%' . bin2hex($string[$x]);
 | 
			
		||||
            } 
 | 
			
		||||
            return $return;
 | 
			
		||||
 | 
			
		||||
        case 'hexentity':
 | 
			
		||||
            $return = '';
 | 
			
		||||
            for ($x = 0; $x < strlen($string); $x++) {
 | 
			
		||||
                $return .= '&#x' . bin2hex($string[$x]) . ';';
 | 
			
		||||
            } 
 | 
			
		||||
            return $return;
 | 
			
		||||
 | 
			
		||||
        case 'decentity':
 | 
			
		||||
            $return = '';
 | 
			
		||||
            for ($x = 0; $x < strlen($string); $x++) {
 | 
			
		||||
                $return .= '&#' . ord($string[$x]) . ';';
 | 
			
		||||
            } 
 | 
			
		||||
            return $return;
 | 
			
		||||
 | 
			
		||||
        case 'javascript': 
 | 
			
		||||
            // escape quotes and backslashes, newlines, etc.
 | 
			
		||||
            return strtr($string, array('\\' => '\\\\', "'" => "\\'", '"' => '\\"', "\r" => '\\r', "\n" => '\\n', '</' => '<\/'));
 | 
			
		||||
 | 
			
		||||
        case 'mail': 
 | 
			
		||||
          require_once(SMARTY_PLUGINS_DIR . 'shared.mb_str_replace.php');
 | 
			
		||||
          return smarty_mb_str_replace(array('@', '.'), array(' [AT] ', ' [DOT] '), $string);
 | 
			
		||||
 | 
			
		||||
        case 'nonstd': 
 | 
			
		||||
            // escape non-standard chars, such as ms document quotes
 | 
			
		||||
            $_res = '';
 | 
			
		||||
            for($_i = 0, $_len = strlen($string); $_i < $_len; $_i++) {
 | 
			
		||||
                $_ord = ord(substr($string, $_i, 1)); 
 | 
			
		||||
                // non-standard char, escape it
 | 
			
		||||
                if ($_ord >= 126) {
 | 
			
		||||
                    $_res .= '&#' . $_ord . ';';
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_res .= substr($string, $_i, 1);
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            return $_res;
 | 
			
		||||
 | 
			
		||||
        default:
 | 
			
		||||
            return $string;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										46
									
								
								site/stackreach/libs/plugins/modifier.regex_replace.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								site/stackreach/libs/plugins/modifier.regex_replace.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,46 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty regex_replace modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     regex_replace<br>
 | 
			
		||||
 * Purpose:  regular expression search/replace
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.regex.replace.php
 | 
			
		||||
 *          regex_replace (Smarty online manual)
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param string
 | 
			
		||||
 * @param string|array
 | 
			
		||||
 * @param string|array
 | 
			
		||||
 * @return string
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_regex_replace($string, $search, $replace)
 | 
			
		||||
{
 | 
			
		||||
    if(is_array($search)) {
 | 
			
		||||
      foreach($search as $idx => $s)
 | 
			
		||||
        $search[$idx] = _smarty_regex_replace_check($s);
 | 
			
		||||
    } else {
 | 
			
		||||
      $search = _smarty_regex_replace_check($search);
 | 
			
		||||
    }       
 | 
			
		||||
 | 
			
		||||
    return preg_replace($search, $replace, $string);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _smarty_regex_replace_check($search)
 | 
			
		||||
{
 | 
			
		||||
    if (($pos = strpos($search,"\0")) !== false)
 | 
			
		||||
      $search = substr($search,0,$pos);
 | 
			
		||||
    if (preg_match('!([a-zA-Z\s]+)$!s', $search, $match) && (strpos($match[1], 'e') !== false)) {
 | 
			
		||||
        /* remove eval-modifier from $search */
 | 
			
		||||
        $search = substr($search, 0, -strlen($match[1])) . preg_replace('![e\s]+!', '', $match[1]);
 | 
			
		||||
    }
 | 
			
		||||
    return $search;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										29
									
								
								site/stackreach/libs/plugins/modifier.replace.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								site/stackreach/libs/plugins/modifier.replace.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty replace modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     replace<br>
 | 
			
		||||
 * Purpose:  simple search/replace
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.replace.php replace (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_replace($string, $search, $replace)
 | 
			
		||||
{
 | 
			
		||||
    require_once(SMARTY_PLUGINS_DIR . 'shared.mb_str_replace.php');
 | 
			
		||||
    return smarty_mb_str_replace($search, $replace, $string);
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										37
									
								
								site/stackreach/libs/plugins/modifier.spacify.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								site/stackreach/libs/plugins/modifier.spacify.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,37 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty spacify modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     spacify<br>
 | 
			
		||||
 * Purpose:  add spaces between characters in a string
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.spacify.php spacify (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @param string $ 
 | 
			
		||||
 * @return string 
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_spacify($string, $spacify_char = ' ')
 | 
			
		||||
{ 
 | 
			
		||||
    // mb_ functions available?
 | 
			
		||||
    if (function_exists('mb_strlen') && mb_detect_encoding($string, 'UTF-8, ISO-8859-1') === 'UTF-8') {
 | 
			
		||||
        $strlen = mb_strlen($string);
 | 
			
		||||
        while ($strlen) {
 | 
			
		||||
            $array[] = mb_substr($string, 0, 1, "UTF-8");
 | 
			
		||||
            $string = mb_substr($string, 1, $strlen, "UTF-8");
 | 
			
		||||
            $strlen = mb_strlen($string);
 | 
			
		||||
        } 
 | 
			
		||||
        return implode($spacify_char, $array);
 | 
			
		||||
    } else {
 | 
			
		||||
        return implode($spacify_char, preg_split('//', $string, -1));
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										67
									
								
								site/stackreach/libs/plugins/modifier.truncate.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								site/stackreach/libs/plugins/modifier.truncate.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,67 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifier
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty truncate modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     truncate<br>
 | 
			
		||||
 * Purpose:  Truncate a string to a certain length if necessary,
 | 
			
		||||
 *               optionally splitting in the middle of a word, and
 | 
			
		||||
 *               appending the $etc string or inserting $etc into the middle.
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.truncate.php truncate (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @param string $string input string
 | 
			
		||||
 * @param integer $length lenght of truncated text
 | 
			
		||||
 * @param string $etc end string
 | 
			
		||||
 * @param boolean $break_words truncate at word boundary
 | 
			
		||||
 * @param boolean $middle truncate in the middle of text
 | 
			
		||||
 * @return string truncated string
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifier_truncate($string, $length = 80, $etc = '...',
 | 
			
		||||
    $break_words = false, $middle = false)
 | 
			
		||||
{
 | 
			
		||||
    if ($length == 0)
 | 
			
		||||
        return '';
 | 
			
		||||
 | 
			
		||||
    if (is_callable('mb_strlen')) {
 | 
			
		||||
        if (mb_detect_encoding($string, 'UTF-8, ISO-8859-1') === 'UTF-8') {
 | 
			
		||||
            // $string has utf-8 encoding
 | 
			
		||||
            if (mb_strlen($string) > $length) {
 | 
			
		||||
                $length -= min($length, mb_strlen($etc));
 | 
			
		||||
                if (!$break_words && !$middle) {
 | 
			
		||||
                    $string = preg_replace('/\s+?(\S+)?$/u', '', mb_substr($string, 0, $length + 1));
 | 
			
		||||
                } 
 | 
			
		||||
                if (!$middle) {
 | 
			
		||||
                    return mb_substr($string, 0, $length) . $etc;
 | 
			
		||||
                } else {
 | 
			
		||||
                    return mb_substr($string, 0, $length / 2) . $etc . mb_substr($string, - $length / 2);
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                return $string;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    // $string has no utf-8 encoding
 | 
			
		||||
    if (strlen($string) > $length) {
 | 
			
		||||
        $length -= min($length, strlen($etc));
 | 
			
		||||
        if (!$break_words && !$middle) {
 | 
			
		||||
            $string = preg_replace('/\s+?(\S+)?$/', '', substr($string, 0, $length + 1));
 | 
			
		||||
        } 
 | 
			
		||||
        if (!$middle) {
 | 
			
		||||
            return substr($string, 0, $length) . $etc;
 | 
			
		||||
        } else {
 | 
			
		||||
            return substr($string, 0, $length / 2) . $etc . substr($string, - $length / 2);
 | 
			
		||||
        } 
 | 
			
		||||
    } else {
 | 
			
		||||
        return $string;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										29
									
								
								site/stackreach/libs/plugins/modifiercompiler.cat.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								site/stackreach/libs/plugins/modifiercompiler.cat.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty cat modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     cat<br>
 | 
			
		||||
 * Date:     Feb 24, 2003
 | 
			
		||||
 * Purpose:  catenate a value to a variable
 | 
			
		||||
 * Input:    string to catenate
 | 
			
		||||
 * Example:  {$var|cat:"foo"}
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.cat.php cat
 | 
			
		||||
 *          (Smarty online manual)
 | 
			
		||||
 * @author   Uwe Tews
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_cat($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    return '('.implode(').(', $params).')';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,39 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty count_characters modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     count_characteres<br>
 | 
			
		||||
 * Purpose:  count the number of characters in a text
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.count.characters.php count_characters (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_count_characters($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    // mb_ functions available?
 | 
			
		||||
    if (function_exists('mb_strlen')) {
 | 
			
		||||
        // count also spaces?
 | 
			
		||||
        if (isset($params[1]) && $params[1] == 'true') {
 | 
			
		||||
            return '((mb_detect_encoding(' . $params[0] . ', \'UTF-8, ISO-8859-1\') === \'UTF-8\') ? mb_strlen(' . $params[0] . ', SMARTY_RESOURCE_CHAR_SET) : strlen(' . $params[0] . '))';
 | 
			
		||||
        } 
 | 
			
		||||
        return '((mb_detect_encoding(' . $params[0] . ', \'UTF-8, ISO-8859-1\') === \'UTF-8\') ? preg_match_all(\'#[^\s\pZ]#u\', ' . $params[0] . ', $tmp) : preg_match_all(\'/[^\s]/\',' . $params[0] . ', $tmp))';
 | 
			
		||||
    } else {
 | 
			
		||||
        // count also spaces?
 | 
			
		||||
        if (isset($params[1]) && $params[1] == 'true') {
 | 
			
		||||
            return 'strlen(' . $params[0] . ')';
 | 
			
		||||
        } 
 | 
			
		||||
        return 'preg_match_all(\'/[^\s]/\',' . $params[0] . ', $tmp)';
 | 
			
		||||
    } 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,27 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty count_paragraphs modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     count_paragraphs<br>
 | 
			
		||||
 * Purpose:  count the number of paragraphs in a text
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.count.paragraphs.php
 | 
			
		||||
 *          count_paragraphs (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_count_paragraphs($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    // count \r or \n characters
 | 
			
		||||
    return '(preg_match_all(\'#[\r\n]+#\', ' . $params[0] . ', $tmp)+1)';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,27 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty count_sentences modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     count_sentences
 | 
			
		||||
 * Purpose:  count the number of sentences in a text
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.count.paragraphs.php
 | 
			
		||||
 *          count_sentences (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_count_sentences($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    // find periods with a word before but not after.
 | 
			
		||||
    return 'preg_match_all(\'/[^\s]\.(?!\w)/\', ' . $params[0] . ', $tmp)';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,31 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty count_words modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     count_words<br>
 | 
			
		||||
 * Purpose:  count the number of words in a text
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.count.words.php count_words (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
*/
 | 
			
		||||
function smarty_modifiercompiler_count_words($params, $compiler)
 | 
			
		||||
{ 
 | 
			
		||||
    // mb_ functions available?
 | 
			
		||||
    if (function_exists('mb_strlen')) {
 | 
			
		||||
        return '((mb_detect_encoding(' . $params[0] . ', \'UTF-8, ISO-8859-1\') === \'UTF-8\') ? preg_match_all(\'#[\w\pL]+#u\', ' . $params[0] . ', $tmp) : preg_match_all(\'#\w+#\',' . $params[0] . ', $tmp))';
 | 
			
		||||
    } else {
 | 
			
		||||
        return 'str_word_count(' . $params[0] . ')';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										33
									
								
								site/stackreach/libs/plugins/modifiercompiler.default.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								site/stackreach/libs/plugins/modifiercompiler.default.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,33 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty default modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     default<br>
 | 
			
		||||
 * Purpose:  designate default value for empty variables
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.default.php default (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_default ($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    $output = $params[0];
 | 
			
		||||
    if (!isset($params[1])) {
 | 
			
		||||
        $params[1] = "''";
 | 
			
		||||
    } 
 | 
			
		||||
    for ($i = 1, $cnt = count($params); $i < $cnt; $i++) {
 | 
			
		||||
        $output = '(($tmp = @' . $output . ')===null||$tmp===\'\' ? ' . $params[$i] . ' : $tmp)';
 | 
			
		||||
    } 
 | 
			
		||||
    return $output;
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										32
									
								
								site/stackreach/libs/plugins/modifiercompiler.indent.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								site/stackreach/libs/plugins/modifiercompiler.indent.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,32 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty indent modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     indent<br>
 | 
			
		||||
 * Purpose:  indent lines of text
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.indent.php
 | 
			
		||||
 *          indent (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_modifiercompiler_indent($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    if (!isset($params[1])) {
 | 
			
		||||
        $params[1] = 4;
 | 
			
		||||
    } 
 | 
			
		||||
    if (!isset($params[2])) {
 | 
			
		||||
        $params[2] = "' '";
 | 
			
		||||
    } 
 | 
			
		||||
    return 'preg_replace(\'!^!m\',str_repeat(' . $params[2] . ',' . $params[1] . '),' . $params[0] . ')';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										31
									
								
								site/stackreach/libs/plugins/modifiercompiler.lower.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								site/stackreach/libs/plugins/modifiercompiler.lower.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,31 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty lower modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     lower<br>
 | 
			
		||||
 * Purpose:  convert string to lowercase
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.lower.php lower (Smarty online manual)
 | 
			
		||||
 * @author Monte Ohrt <monte at ohrt dot com> 
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_modifiercompiler_lower($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    if (function_exists('mb_strtolower')) {
 | 
			
		||||
        return '((mb_detect_encoding(' . $params[0] . ', \'UTF-8, ISO-8859-1\') === \'UTF-8\') ? mb_strtolower(' . $params[0] . ',SMARTY_RESOURCE_CHAR_SET) : strtolower(' . $params[0] . '))' ;
 | 
			
		||||
    } else {
 | 
			
		||||
        return 'strtolower(' . $params[0] . ')';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										24
									
								
								site/stackreach/libs/plugins/modifiercompiler.noprint.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								site/stackreach/libs/plugins/modifiercompiler.noprint.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,24 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty noprint modifier plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     noprint<br>
 | 
			
		||||
 * Purpose:  return an empty string
 | 
			
		||||
 * @author   Uwe Tews
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_noprint($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    return "''";
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,26 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty string_format modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     string_format<br>
 | 
			
		||||
 * Purpose:  format strings via sprintf
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.string.format.php string_format (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_string_format($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    return 'sprintf(' . $params[1] . ',' . $params[0] . ')';
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										33
									
								
								site/stackreach/libs/plugins/modifiercompiler.strip.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								site/stackreach/libs/plugins/modifiercompiler.strip.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,33 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty strip modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     strip<br>
 | 
			
		||||
 * Purpose:  Replace all repeated spaces, newlines, tabs
 | 
			
		||||
 *              with a single space or supplied replacement string.<br>
 | 
			
		||||
 * Example:  {$var|strip} {$var|strip:" "}
 | 
			
		||||
 * Date:     September 25th, 2002
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.strip.php strip (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_modifiercompiler_strip($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    if (!isset($params[1])) {
 | 
			
		||||
        $params[1] = "' '";
 | 
			
		||||
    } 
 | 
			
		||||
    return "preg_replace('!\s+!', {$params[1]},{$params[0]})";
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										34
									
								
								site/stackreach/libs/plugins/modifiercompiler.strip_tags.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								site/stackreach/libs/plugins/modifiercompiler.strip_tags.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty strip_tags modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     strip_tags<br>
 | 
			
		||||
 * Purpose:  strip html tags from text
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.strip.tags.php strip_tags (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_modifiercompiler_strip_tags($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
   if (!isset($params[1])) {
 | 
			
		||||
        $params[1] = true;
 | 
			
		||||
    } 
 | 
			
		||||
    if ($params[1] === true) {
 | 
			
		||||
        return "preg_replace('!<[^>]*?>!', ' ', {$params[0]})";
 | 
			
		||||
    } else {
 | 
			
		||||
        return 'strip_tags(' . $params[0] . ')';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										30
									
								
								site/stackreach/libs/plugins/modifiercompiler.upper.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								site/stackreach/libs/plugins/modifiercompiler.upper.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,30 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty upper modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     lower<br>
 | 
			
		||||
 * Purpose:  convert string to uppercase
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.upper.php lower (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_upper($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    if (function_exists('mb_strtoupper')) {
 | 
			
		||||
        return '((mb_detect_encoding(' . $params[0] . ', \'UTF-8, ISO-8859-1\') === \'UTF-8\') ? mb_strtoupper(' . $params[0] . ',SMARTY_RESOURCE_CHAR_SET) : strtoupper(' . $params[0] . '))' ;
 | 
			
		||||
    } else {
 | 
			
		||||
        return 'strtoupper(' . $params[0] . ')';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										35
									
								
								site/stackreach/libs/plugins/modifiercompiler.wordwrap.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								site/stackreach/libs/plugins/modifiercompiler.wordwrap.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,35 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsModifierCompiler
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty wordwrap modifier plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Type:     modifier<br>
 | 
			
		||||
 * Name:     wordwrap<br>
 | 
			
		||||
 * Purpose:  wrap a string of text at a given length
 | 
			
		||||
 * 
 | 
			
		||||
 * @link http://smarty.php.net/manual/en/language.modifier.wordwrap.php wordwrap (Smarty online manual)
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 * @param array $params parameters
 | 
			
		||||
 * @return string with compiled code
 | 
			
		||||
 */
 | 
			
		||||
function smarty_modifiercompiler_wordwrap($params, $compiler)
 | 
			
		||||
{
 | 
			
		||||
    if (!isset($params[1])) {
 | 
			
		||||
        $params[1] = 80;
 | 
			
		||||
    } 
 | 
			
		||||
    if (!isset($params[2])) {
 | 
			
		||||
        $params[2] = '"\n"';
 | 
			
		||||
    } 
 | 
			
		||||
    if (!isset($params[3])) {
 | 
			
		||||
        $params[3] = 'false';
 | 
			
		||||
    } 
 | 
			
		||||
    return 'wordwrap(' . $params[0] . ',' . $params[1] . ',' . $params[2] . ',' . $params[3] . ')';
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										77
									
								
								site/stackreach/libs/plugins/outputfilter.trimwhitespace.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								site/stackreach/libs/plugins/outputfilter.trimwhitespace.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,77 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFilter
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty trimwhitespace outputfilter plugin
 | 
			
		||||
 *
 | 
			
		||||
 * File:     outputfilter.trimwhitespace.php<br>
 | 
			
		||||
 * Type:     outputfilter<br>
 | 
			
		||||
 * Name:     trimwhitespace<br>
 | 
			
		||||
 * Date:     Jan 25, 2003<br>
 | 
			
		||||
 * Purpose:  trim leading white space and blank lines from
 | 
			
		||||
 *           template source after it gets interpreted, cleaning
 | 
			
		||||
 *           up code and saving bandwidth. Does not affect
 | 
			
		||||
 *           <<PRE>></PRE> and <SCRIPT></SCRIPT> blocks.<br>
 | 
			
		||||
 * Install:  Drop into the plugin directory, call
 | 
			
		||||
 *           <code>$smarty->load_filter('output','trimwhitespace');</code>
 | 
			
		||||
 *           from application.
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @author Contributions from Lars Noschinski <lars@usenet.noschinski.de>
 | 
			
		||||
 * @version  1.3
 | 
			
		||||
 * @param string $source input string
 | 
			
		||||
 * @param object &$smarty Smarty object
 | 
			
		||||
 * @return string filtered output
 | 
			
		||||
 */
 | 
			
		||||
function smarty_outputfilter_trimwhitespace($source, $smarty)
 | 
			
		||||
{
 | 
			
		||||
    // Pull out the script blocks
 | 
			
		||||
    preg_match_all("!<script[^>]*?>.*?</script>!is", $source, $match);
 | 
			
		||||
    $_script_blocks = $match[0];
 | 
			
		||||
    $source = preg_replace("!<script[^>]*?>.*?</script>!is",
 | 
			
		||||
                           '@@@SMARTY:TRIM:SCRIPT@@@', $source);
 | 
			
		||||
 | 
			
		||||
    // Pull out the pre blocks
 | 
			
		||||
    preg_match_all("!<pre[^>]*?>.*?</pre>!is", $source, $match);
 | 
			
		||||
    $_pre_blocks = $match[0];
 | 
			
		||||
    $source = preg_replace("!<pre[^>]*?>.*?</pre>!is",
 | 
			
		||||
                           '@@@SMARTY:TRIM:PRE@@@', $source);
 | 
			
		||||
    
 | 
			
		||||
    // Pull out the textarea blocks
 | 
			
		||||
    preg_match_all("!<textarea[^>]*?>.*?</textarea>!is", $source, $match);
 | 
			
		||||
    $_textarea_blocks = $match[0];
 | 
			
		||||
    $source = preg_replace("!<textarea[^>]*?>.*?</textarea>!is",
 | 
			
		||||
                           '@@@SMARTY:TRIM:TEXTAREA@@@', $source);
 | 
			
		||||
 | 
			
		||||
    // remove all leading spaces, tabs and carriage returns NOT
 | 
			
		||||
    // preceeded by a php close tag.
 | 
			
		||||
    $source = trim(preg_replace('/((?<!\?>)\n)[\s]+/m', '\1', $source));
 | 
			
		||||
 | 
			
		||||
    // replace textarea blocks
 | 
			
		||||
    smarty_outputfilter_trimwhitespace_replace("@@@SMARTY:TRIM:TEXTAREA@@@",$_textarea_blocks, $source);
 | 
			
		||||
 | 
			
		||||
    // replace pre blocks
 | 
			
		||||
    smarty_outputfilter_trimwhitespace_replace("@@@SMARTY:TRIM:PRE@@@",$_pre_blocks, $source);
 | 
			
		||||
 | 
			
		||||
    // replace script blocks
 | 
			
		||||
    smarty_outputfilter_trimwhitespace_replace("@@@SMARTY:TRIM:SCRIPT@@@",$_script_blocks, $source);
 | 
			
		||||
 | 
			
		||||
    return $source;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function smarty_outputfilter_trimwhitespace_replace($search_str, $replace, &$subject) {
 | 
			
		||||
    $_len = strlen($search_str);
 | 
			
		||||
    $_pos = 0;
 | 
			
		||||
    for ($_i=0, $_count=count($replace); $_i<$_count; $_i++)
 | 
			
		||||
        if (($_pos=strpos($subject, $search_str, $_pos))!==false)
 | 
			
		||||
            $subject = substr_replace($subject, $replace[$_i], $_pos, $_len);
 | 
			
		||||
        else
 | 
			
		||||
            break;
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										29
									
								
								site/stackreach/libs/plugins/shared.escape_special_chars.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								site/stackreach/libs/plugins/shared.escape_special_chars.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty shared plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsShared
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * escape_special_chars common function
 | 
			
		||||
 *
 | 
			
		||||
 * Function: smarty_function_escape_special_chars<br>
 | 
			
		||||
 * Purpose:  used by other smarty functions to escape
 | 
			
		||||
 *           special chars except for already escaped ones
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param string
 | 
			
		||||
 * @return string
 | 
			
		||||
 */
 | 
			
		||||
function smarty_function_escape_special_chars($string)
 | 
			
		||||
{
 | 
			
		||||
    if(!is_array($string)) {
 | 
			
		||||
        $string = preg_replace('!&(#?\w+);!', '%%%SMARTY_START%%%\\1%%%SMARTY_END%%%', $string);
 | 
			
		||||
        $string = htmlspecialchars($string);
 | 
			
		||||
        $string = str_replace(array('%%%SMARTY_START%%%','%%%SMARTY_END%%%'), array('&',';'), $string);
 | 
			
		||||
    }
 | 
			
		||||
    return $string;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										43
									
								
								site/stackreach/libs/plugins/shared.make_timestamp.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								site/stackreach/libs/plugins/shared.make_timestamp.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty shared plugin
 | 
			
		||||
 *
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsShared
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Function: smarty_make_timestamp<br>
 | 
			
		||||
 * Purpose:  used by other smarty functions to make a timestamp
 | 
			
		||||
 *           from a string.
 | 
			
		||||
 * @author   Monte Ohrt <monte at ohrt dot com>
 | 
			
		||||
 * @param string $string
 | 
			
		||||
 * @return string
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_make_timestamp($string)
 | 
			
		||||
{
 | 
			
		||||
    if(empty($string)) {
 | 
			
		||||
        // use "now":
 | 
			
		||||
        return time();
 | 
			
		||||
    } elseif ($string instanceof DateTime) {
 | 
			
		||||
        return $string->getTimestamp();
 | 
			
		||||
    } elseif (strlen($string)==14 && ctype_digit($string)) {
 | 
			
		||||
        // it is mysql timestamp format of YYYYMMDDHHMMSS?            
 | 
			
		||||
        return mktime(substr($string, 8, 2),substr($string, 10, 2),substr($string, 12, 2),
 | 
			
		||||
                       substr($string, 4, 2),substr($string, 6, 2),substr($string, 0, 4));
 | 
			
		||||
    } elseif (is_numeric($string)) {
 | 
			
		||||
        // it is a numeric string, we handle it as timestamp
 | 
			
		||||
        return (int)$string;
 | 
			
		||||
    } else {
 | 
			
		||||
        // strtotime should handle it
 | 
			
		||||
        $time = strtotime($string);
 | 
			
		||||
        if ($time == -1 || $time === false) {
 | 
			
		||||
            // strtotime() was not able to parse $string, use "now":
 | 
			
		||||
            return time();
 | 
			
		||||
        }
 | 
			
		||||
        return $time;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										38
									
								
								site/stackreach/libs/plugins/shared.mb_str_replace.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								site/stackreach/libs/plugins/shared.mb_str_replace.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,38 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
if(!function_exists('smarty_mb_str_replace')) {
 | 
			
		||||
  function smarty_mb_str_replace($search, $replace, $subject, &$count=0) { 
 | 
			
		||||
      if (!is_array($search) && is_array($replace)) { 
 | 
			
		||||
          return false; 
 | 
			
		||||
      } 
 | 
			
		||||
      if (is_array($subject)) { 
 | 
			
		||||
          // call mb_replace for each single string in $subject 
 | 
			
		||||
          foreach ($subject as &$string) { 
 | 
			
		||||
              $string = &smarty_mb_str_replace($search, $replace, $string, $c); 
 | 
			
		||||
              $count += $c; 
 | 
			
		||||
          } 
 | 
			
		||||
      } elseif (is_array($search)) { 
 | 
			
		||||
          if (!is_array($replace)) { 
 | 
			
		||||
              foreach ($search as &$string) { 
 | 
			
		||||
                  $subject = smarty_mb_str_replace($string, $replace, $subject, $c); 
 | 
			
		||||
                  $count += $c; 
 | 
			
		||||
              } 
 | 
			
		||||
          } else { 
 | 
			
		||||
              $n = max(count($search), count($replace)); 
 | 
			
		||||
              while ($n--) { 
 | 
			
		||||
                  $subject = smarty_mb_str_replace(current($search), current($replace), $subject, $c); 
 | 
			
		||||
                  $count += $c; 
 | 
			
		||||
                  next($search); 
 | 
			
		||||
                  next($replace); 
 | 
			
		||||
              } 
 | 
			
		||||
          } 
 | 
			
		||||
      } else { 
 | 
			
		||||
          $parts = mb_split(preg_quote($search), $subject); 
 | 
			
		||||
          $count = count($parts)-1; 
 | 
			
		||||
          $subject = implode($replace, $parts); 
 | 
			
		||||
      } 
 | 
			
		||||
      return $subject; 
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,22 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsFilter
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty htmlspecialchars variablefilter plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @param string $source input string
 | 
			
		||||
 * @param object $ &$smarty Smarty object
 | 
			
		||||
 * @return string filtered output
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function smarty_variablefilter_htmlspecialchars($source, $smarty)
 | 
			
		||||
{
 | 
			
		||||
    return htmlspecialchars($source, ENT_QUOTES);
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,205 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin CacheResource File
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the file system as resource for the HTML cache
 | 
			
		||||
 * Version ussing nocache inserts
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Cacher
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This class does contain all necessary methods for the HTML cache on file system
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_CacheResource_File {
 | 
			
		||||
    function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the filepath of the cached template output
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template current template
 | 
			
		||||
     * @return string the cache filepath
 | 
			
		||||
     */
 | 
			
		||||
    public function getCachedFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_source_file_path = str_replace(':', '.', $_template->getTemplateFilepath());
 | 
			
		||||
        $_cache_id = isset($_template->cache_id) ? preg_replace('![^\w\|]+!', '_', $_template->cache_id) : null;
 | 
			
		||||
        $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
 | 
			
		||||
        $_filepath = $_template->templateUid; 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($this->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $this->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_cache_id)) {
 | 
			
		||||
            $_cache_id = str_replace('|', $_compile_dir_sep, $_cache_id) . $_compile_dir_sep;
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache_id = '';
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_compile_id = $_compile_id . $_compile_dir_sep;
 | 
			
		||||
        } else {
 | 
			
		||||
            $_compile_id = '';
 | 
			
		||||
        } 
 | 
			
		||||
        $_cache_dir = $this->smarty->cache_dir;
 | 
			
		||||
        if (strpos('/\\', substr($_cache_dir, -1)) === false) {
 | 
			
		||||
            $_cache_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_cache_dir . $_cache_id . $_compile_id . $_filepath . '.' . basename($_source_file_path) . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the timpestamp of the cached template output
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template current template
 | 
			
		||||
     * @return integer |booelan the template timestamp or false if the file does not exist
 | 
			
		||||
     */
 | 
			
		||||
    public function getCachedTimestamp($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return @filemtime ($_template->getCachedFilepath());
 | 
			
		||||
        return ($_template->getCachedFilepath() && file_exists($_template->getCachedFilepath())) ? filemtime($_template->getCachedFilepath()) : false ;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the cached template output
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template current template
 | 
			
		||||
     * @return string |booelan the template content or false if the file does not exist
 | 
			
		||||
     */
 | 
			
		||||
    public function getCachedContents($_template, $no_render = false)
 | 
			
		||||
    {
 | 
			
		||||
    	if (!$no_render) {
 | 
			
		||||
        	ob_start();
 | 
			
		||||
    	}
 | 
			
		||||
        $_smarty_tpl = $_template;
 | 
			
		||||
        include $_template->getCachedFilepath();
 | 
			
		||||
        if ($no_render) {
 | 
			
		||||
        	return null;
 | 
			
		||||
        } else {
 | 
			
		||||
          return ob_get_clean();
 | 
			
		||||
        }
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Writes the rendered template output to cache file
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template current template
 | 
			
		||||
     * @return boolean status
 | 
			
		||||
     */
 | 
			
		||||
    public function writeCachedContent($_template, $content)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$_template->resource_object->isEvaluated) {
 | 
			
		||||
            if (Smarty_Internal_Write_File::writeFile($_template->getCachedFilepath(), $content, $this->smarty) === true) {
 | 
			
		||||
                $_template->cached_timestamp = filemtime($_template->getCachedFilepath());
 | 
			
		||||
                return true;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Empty cache folder
 | 
			
		||||
     * 
 | 
			
		||||
     * @param integer $exp_time expiration time
 | 
			
		||||
     * @return integer number of cache files deleted
 | 
			
		||||
     */
 | 
			
		||||
    public function clearAll($exp_time = null)
 | 
			
		||||
    {
 | 
			
		||||
        return $this->clear(null, null, null, $exp_time);
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Empty cache for a specific template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $resource_name template name
 | 
			
		||||
     * @param string $cache_id cache id
 | 
			
		||||
     * @param string $compile_id compile id
 | 
			
		||||
     * @param integer $exp_time expiration time
 | 
			
		||||
     * @return integer number of cache files deleted
 | 
			
		||||
     */
 | 
			
		||||
    public function clear($resource_name, $cache_id, $compile_id, $exp_time)
 | 
			
		||||
    {
 | 
			
		||||
        $_cache_id = isset($cache_id) ? preg_replace('![^\w\|]+!', '_', $cache_id) : null;
 | 
			
		||||
        $_compile_id = isset($compile_id) ? preg_replace('![^\w\|]+!', '_', $compile_id) : null;
 | 
			
		||||
        $_dir_sep = $this->smarty->use_sub_dirs ? '/' : '^';
 | 
			
		||||
        $_compile_id_offset = $this->smarty->use_sub_dirs ? 3 : 0;
 | 
			
		||||
        $_dir = rtrim($this->smarty->cache_dir, '/\\') . DS;
 | 
			
		||||
        $_dir_length = strlen($_dir);
 | 
			
		||||
        if (isset($_cache_id)) {
 | 
			
		||||
            $_cache_id_parts = explode('|', $_cache_id);
 | 
			
		||||
            $_cache_id_parts_count = count($_cache_id_parts);
 | 
			
		||||
            if ($this->smarty->use_sub_dirs) {
 | 
			
		||||
                foreach ($_cache_id_parts as $id_part) {
 | 
			
		||||
                    $_dir .= $id_part . DS;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($resource_name)) {
 | 
			
		||||
            $_save_stat = $this->smarty->caching;
 | 
			
		||||
            $this->smarty->caching = true;
 | 
			
		||||
            $tpl = new $this->smarty->template_class($resource_name, $this->smarty); 
 | 
			
		||||
            // remove from template cache
 | 
			
		||||
            unset($this->smarty->template_objects[crc32($tpl->template_resource . $tpl->cache_id . $tpl->compile_id)]);
 | 
			
		||||
            $this->smarty->caching = $_save_stat;
 | 
			
		||||
            if ($tpl->isExisting()) {
 | 
			
		||||
                $_resourcename_parts = basename(str_replace('^', '/', $tpl->getCachedFilepath()));
 | 
			
		||||
            } else {
 | 
			
		||||
                return 0;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_count = 0;
 | 
			
		||||
        if (file_exists($_dir)) {
 | 
			
		||||
            $_cacheDirs = new RecursiveDirectoryIterator($_dir);
 | 
			
		||||
            $_cache = new RecursiveIteratorIterator($_cacheDirs, RecursiveIteratorIterator::CHILD_FIRST);
 | 
			
		||||
            foreach ($_cache as $_file) {
 | 
			
		||||
                if (strpos($_file, '.svn') !== false) continue; 
 | 
			
		||||
                // directory ?
 | 
			
		||||
                if ($_file->isDir()) {
 | 
			
		||||
                    if (!$_cache->isDot()) {
 | 
			
		||||
                        // delete folder if empty
 | 
			
		||||
                        @rmdir($_file->getPathname());
 | 
			
		||||
                    } 
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_parts = explode($_dir_sep, str_replace('\\', '/', substr((string)$_file, $_dir_length)));
 | 
			
		||||
                    $_parts_count = count($_parts); 
 | 
			
		||||
                    // check name
 | 
			
		||||
                    if (isset($resource_name)) {
 | 
			
		||||
                        if ($_parts[$_parts_count-1] != $_resourcename_parts) {
 | 
			
		||||
                            continue;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                    // check compile id
 | 
			
		||||
                    if (isset($_compile_id) && (!isset($_parts[$_parts_count-2 - $_compile_id_offset]) || $_parts[$_parts_count-2 - $_compile_id_offset] != $_compile_id)) {
 | 
			
		||||
                        continue;
 | 
			
		||||
                    } 
 | 
			
		||||
                    // check cache id
 | 
			
		||||
                    if (isset($_cache_id)) {
 | 
			
		||||
                        // count of cache id parts
 | 
			
		||||
                        $_parts_count = (isset($_compile_id)) ? $_parts_count - 2 - $_compile_id_offset : $_parts_count - 1 - $_compile_id_offset;
 | 
			
		||||
                        if ($_parts_count < $_cache_id_parts_count) {
 | 
			
		||||
                            continue;
 | 
			
		||||
                        } 
 | 
			
		||||
                        for ($i = 0; $i < $_cache_id_parts_count; $i++) {
 | 
			
		||||
                            if ($_parts[$i] != $_cache_id_parts[$i]) continue 2;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                    // expired ?
 | 
			
		||||
                    if (isset($exp_time) && time() - @filemtime($_file) < $exp_time) {
 | 
			
		||||
                        continue;
 | 
			
		||||
                    } 
 | 
			
		||||
                    $_count += @unlink((string) $_file) ? 1 : 0;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $_count;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,50 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Append
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {append} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Append Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Append extends Smarty_Internal_Compile_Assign {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {append} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // the following must be assigned at runtime because it will be overwritten in parent class
 | 
			
		||||
        $this->required_attributes = array('var', 'value');
 | 
			
		||||
        $this->shorttag_order = array('var', 'value');
 | 
			
		||||
        $this->optional_attributes = array('scope','index');
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($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,64 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Assign
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {assign} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Assign Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Assign extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {assign} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // the following must be assigned at runtime because it will be overwritten in Smarty_Internal_Compile_Append
 | 
			
		||||
        $this->required_attributes = array('var', 'value');
 | 
			
		||||
        $this->shorttag_order = array('var', 'value');
 | 
			
		||||
        $this->optional_attributes = array('scope');
 | 
			
		||||
        $_nocache = 'null';
 | 
			
		||||
        $_scope = 'null'; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
		// nocache ?
 | 
			
		||||
        if ($this->compiler->tag_nocache || $this->compiler->nocache) {
 | 
			
		||||
            $_nocache = 'true'; 
 | 
			
		||||
            // create nocache var to make it know for further compiling
 | 
			
		||||
            $compiler->template->tpl_vars[trim($_attr['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
        } 
 | 
			
		||||
        // scope setup
 | 
			
		||||
        if (isset($_attr['scope'])) {
 | 
			
		||||
            $_attr['scope'] = trim($_attr['scope'], "'\"");
 | 
			
		||||
            if ($_attr['scope'] == 'parent') {
 | 
			
		||||
                $_scope = Smarty::SCOPE_PARENT;
 | 
			
		||||
            } elseif ($_attr['scope'] == 'root') {
 | 
			
		||||
                $_scope = Smarty::SCOPE_ROOT;
 | 
			
		||||
            } elseif ($_attr['scope'] == 'global') {
 | 
			
		||||
                $_scope = Smarty::SCOPE_GLOBAL;
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->compiler->trigger_template_error('illegal value for "scope" attribute', $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // compiled output
 | 
			
		||||
        if (isset($parameter['smarty_internal_index'])) {
 | 
			
		||||
            return "<?php if (!isset(\$_smarty_tpl->tpl_vars[$_attr[var]]) || !is_array(\$_smarty_tpl->tpl_vars[$_attr[var]]->value)) \$_smarty_tpl->createLocalArrayVariable($_attr[var], $_nocache, $_scope);\n\$_smarty_tpl->tpl_vars[$_attr[var]]->value$parameter[smarty_internal_index] = $_attr[value];?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            return "<?php \$_smarty_tpl->tpl_vars[$_attr[var]] = new Smarty_variable($_attr[value], $_nocache, $_scope);?>";
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,187 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Block
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {block}{/block} tags
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Block Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Block extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('name');
 | 
			
		||||
    public $shorttag_order = array('name');
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {block} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $save = array($_attr, $compiler->parser->current_buffer, $this->compiler->nocache, $this->compiler->smarty->merge_compiled_includes, $compiler->smarty->inheritance);
 | 
			
		||||
        $this->_open_tag('block', $save);
 | 
			
		||||
        if ($_attr['nocache'] == true) {
 | 
			
		||||
            $compiler->nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
        // set flag for {block} tag
 | 
			
		||||
        $compiler->smarty->inheritance = true;
 | 
			
		||||
        // must merge includes
 | 
			
		||||
        $this->compiler->smarty->merge_compiled_includes = true; 
 | 
			
		||||
 | 
			
		||||
        $compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser);
 | 
			
		||||
        $compiler->has_code = false;
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    static function saveBlockData($block_content, $block_tag, $template, $filepath)
 | 
			
		||||
    {
 | 
			
		||||
    	$_rdl = preg_quote($template->smarty->right_delimiter);
 | 
			
		||||
        $_ldl = preg_quote($template->smarty->left_delimiter);
 | 
			
		||||
 | 
			
		||||
        if (0 == preg_match("!({$_ldl}block\s+)(name=)?(\w+|'.*'|\".*\")(\s*?)?((append|prepend|nocache)(=true)?)?(\s*{$_rdl})!", $block_tag, $_match)) {
 | 
			
		||||
            $error_text = 'Syntax Error in template "' . $template->getTemplateFilepath() . '"   "' . htmlspecialchars($block_tag) . '" illegal options';
 | 
			
		||||
            throw new SmartyCompilerException($error_text);
 | 
			
		||||
        } else {
 | 
			
		||||
            $_name = trim($_match[3], '\'"'); 
 | 
			
		||||
            // replace {$smarty.block.child}
 | 
			
		||||
            if (strpos($block_content, $template->smarty->left_delimiter . '$smarty.block.child' . $template->smarty->right_delimiter) !== false) {
 | 
			
		||||
                if (isset($template->block_data[$_name])) {
 | 
			
		||||
                    $block_content = str_replace($template->smarty->left_delimiter . '$smarty.block.child' . $template->smarty->right_delimiter,
 | 
			
		||||
                        $template->block_data[$_name]['source'], $block_content);
 | 
			
		||||
                    unset($template->block_data[$_name]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $block_content = str_replace($template->smarty->left_delimiter . '$smarty.block.child' . $template->smarty->right_delimiter,
 | 
			
		||||
                        '', $block_content);
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            if (isset($template->block_data[$_name])) {
 | 
			
		||||
                if (strpos($template->block_data[$_name]['source'], '%%%%SMARTY_PARENT%%%%') !== false) {
 | 
			
		||||
                    $template->block_data[$_name]['source'] =
 | 
			
		||||
                    str_replace('%%%%SMARTY_PARENT%%%%', $block_content, $template->block_data[$_name]['source']);
 | 
			
		||||
                } elseif ($template->block_data[$_name]['mode'] == 'prepend') {
 | 
			
		||||
                    $template->block_data[$_name]['source'] .= $block_content;
 | 
			
		||||
                } elseif ($template->block_data[$_name]['mode'] == 'append') {
 | 
			
		||||
                    $template->block_data[$_name]['source'] = $block_content . $template->block_data[$_name]['source'];
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                $template->block_data[$_name]['source'] = $block_content;
 | 
			
		||||
            } 
 | 
			
		||||
            if ($_match[6] == 'append') {
 | 
			
		||||
                $template->block_data[$_name]['mode'] = 'append';
 | 
			
		||||
            } elseif ($_match[6] == 'prepend') {
 | 
			
		||||
                $template->block_data[$_name]['mode'] = 'prepend';
 | 
			
		||||
            } else {
 | 
			
		||||
                $template->block_data[$_name]['mode'] = 'replace';
 | 
			
		||||
            } 
 | 
			
		||||
            $template->block_data[$_name]['file'] = $filepath;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
	static function compileChildBlock ($compiler, $_name = null)
 | 
			
		||||
	{
 | 
			
		||||
		$_output = '';
 | 
			
		||||
        // if called by {$smarty.block.child} we must search the name of enclosing {block}
 | 
			
		||||
		if ($_name == null) {
 | 
			
		||||
        	$stack_count = count($compiler->_tag_stack);
 | 
			
		||||
            while (--$stack_count >= 0) {
 | 
			
		||||
            	if ($compiler->_tag_stack[$stack_count][0] == 'block') {
 | 
			
		||||
                	$_name = trim($compiler->_tag_stack[$stack_count][1][0]['name'] ,"'\"");
 | 
			
		||||
                	break;
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
		// flag that child is already compile by {$smarty.block.child} inclusion
 | 
			
		||||
        $compiler->template->block_data[$_name]['compiled'] = true;
 | 
			
		||||
        }
 | 
			
		||||
		if ($_name == null) {
 | 
			
		||||
       		$compiler->trigger_template_error('{$smarty.block.child} used out of context', $this->compiler->lex->taglineno);
 | 
			
		||||
		}
 | 
			
		||||
		// undefined child?
 | 
			
		||||
		if (!isset($compiler->template->block_data[$_name])) {
 | 
			
		||||
       		return '';
 | 
			
		||||
		}
 | 
			
		||||
		$_tpl = new Smarty_Internal_template ('eval:' . $compiler->template->block_data[$_name]['source'], $compiler->smarty, $compiler->template, $compiler->template->cache_id, 
 | 
			
		||||
		               $compiler->template->compile_id = null, $compiler->template->caching, $compiler->template->cache_lifetime);
 | 
			
		||||
		$_tpl->properties['nocache_hash'] = $compiler->template->properties['nocache_hash'];
 | 
			
		||||
		$_tpl->template_filepath = $compiler->template->block_data[$_name]['file'];
 | 
			
		||||
		if ($compiler->nocache) {
 | 
			
		||||
			$_tpl->forceNocache = 2;
 | 
			
		||||
		} else {
 | 
			
		||||
			$_tpl->forceNocache = 1;
 | 
			
		||||
		}
 | 
			
		||||
		$_tpl->suppressHeader = true;
 | 
			
		||||
		$_tpl->suppressFileDependency = true;
 | 
			
		||||
		if (strpos($compiler->template->block_data[$_name]['source'], '%%%%SMARTY_PARENT%%%%') !== false) {
 | 
			
		||||
			$_output = str_replace('%%%%SMARTY_PARENT%%%%', $compiler->parser->current_buffer->to_smarty_php(), $_tpl->getCompiledTemplate());
 | 
			
		||||
		} elseif ($compiler->template->block_data[$_name]['mode'] == 'prepend') {
 | 
			
		||||
			$_output = $_tpl->getCompiledTemplate() . $compiler->parser->current_buffer->to_smarty_php();
 | 
			
		||||
		} elseif ($compiler->template->block_data[$_name]['mode'] == 'append') {
 | 
			
		||||
			$_output = $compiler->parser->current_buffer->to_smarty_php() . $_tpl->getCompiledTemplate();
 | 
			
		||||
		} elseif (!empty($compiler->template->block_data[$_name])) {
 | 
			
		||||
			$_output = $_tpl->getCompiledTemplate();
 | 
			
		||||
		}
 | 
			
		||||
		$compiler->template->properties['file_dependency'] = array_merge($compiler->template->properties['file_dependency'], $_tpl->properties['file_dependency']);
 | 
			
		||||
		$compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $_tpl->properties['function']);
 | 
			
		||||
		if ($_tpl->has_nocache_code) {
 | 
			
		||||
			$compiler->template->has_nocache_code = true;
 | 
			
		||||
		}
 | 
			
		||||
		foreach($_tpl->required_plugins as $code => $tmp1) {
 | 
			
		||||
			foreach($tmp1 as $name => $tmp) {
 | 
			
		||||
				foreach($tmp as $type => $data) {
 | 
			
		||||
					$compiler->template->required_plugins[$code][$name][$type] = $data;
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		unset($_tpl);
 | 
			
		||||
		return $_output;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile BlockClose Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Blockclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/block} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $compiler->smarty;
 | 
			
		||||
        $this->compiler->has_code = true; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $saved_data = $this->_close_tag(array('block'));
 | 
			
		||||
        $_name = trim($saved_data[0]['name'], "\"'");
 | 
			
		||||
        if (isset($compiler->template->block_data[$_name]) && !isset($compiler->template->block_data[$_name]['compiled'])) {
 | 
			
		||||
        	$_output = Smarty_Internal_Compile_Block::compileChildBlock($compiler, $_name);
 | 
			
		||||
        } else {
 | 
			
		||||
            $_output = $compiler->parser->current_buffer->to_smarty_php();
 | 
			
		||||
            unset ($compiler->template->block_data[$_name]['compiled']);
 | 
			
		||||
        }
 | 
			
		||||
        // reset flags
 | 
			
		||||
        $compiler->parser->current_buffer = $saved_data[1];
 | 
			
		||||
        $compiler->nocache = $saved_data[2];
 | 
			
		||||
        $compiler->smarty->merge_compiled_includes = $saved_data[3];
 | 
			
		||||
        $compiler->smarty->inheritance = $saved_data[4];
 | 
			
		||||
        // $_output content has already nocache code processed
 | 
			
		||||
        $compiler->suppressNocacheProcessing = true;
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,65 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Break
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {break} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Break Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Break extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('levels'); 
 | 
			
		||||
    public $shorttag_order = array('levels');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {break} 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)
 | 
			
		||||
    {    
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $compiler->smarty;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['levels'])) {
 | 
			
		||||
            if (!is_numeric($_attr['levels'])) {
 | 
			
		||||
                $this->compiler->trigger_template_error('level attribute must be a numeric constant', $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
            $_levels = $_attr['levels'];
 | 
			
		||||
        } else {
 | 
			
		||||
            $_levels = 1;
 | 
			
		||||
        } 
 | 
			
		||||
        $level_count = $_levels;
 | 
			
		||||
        $stack_count = count($compiler->_tag_stack) - 1;
 | 
			
		||||
        while ($level_count > 0 && $stack_count >= 0) {
 | 
			
		||||
            if (in_array($compiler->_tag_stack[$stack_count][0], array('for', 'foreach', 'while', 'section'))) {
 | 
			
		||||
                $level_count--;
 | 
			
		||||
            } 
 | 
			
		||||
            $stack_count--;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($level_count != 0) {
 | 
			
		||||
            $this->compiler->trigger_template_error("cannot break {$_levels} level(s)", $this->compiler->lex->taglineno);
 | 
			
		||||
        } 
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = true;
 | 
			
		||||
        return "<?php break {$_levels}?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										108
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_call.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										108
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_call.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,108 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Call extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('name');
 | 
			
		||||
    public $shorttag_order = array('name');
 | 
			
		||||
    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
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $compiler->smarty;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        // save possible attributes
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
            // output will be stored in a smarty variable instead of beind displayed
 | 
			
		||||
            $_assign = $_attr['assign'];
 | 
			
		||||
        } 
 | 
			
		||||
        $_name = $_attr['name'];
 | 
			
		||||
        unset($_attr['name'], $_attr['assign'], $_attr['nocache']); 
 | 
			
		||||
        // set flag (compiled code of {function} must be included in cache file
 | 
			
		||||
        if ($compiler->nocache || $compiler->tag_nocache) {
 | 
			
		||||
            $_nocache = 'true';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_nocache = 'false';
 | 
			
		||||
        } 
 | 
			
		||||
        $_paramsArray = array();
 | 
			
		||||
        foreach ($_attr as $_key => $_value) {
 | 
			
		||||
            if (is_int($_key)) {
 | 
			
		||||
                $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
            } 
 | 
			
		||||
        }
 | 
			
		||||
        if (isset($compiler->template->properties['function'][$_name]['parameter'])) {
 | 
			
		||||
            foreach ($compiler->template->properties['function'][$_name]['parameter'] as $_key => $_value) {
 | 
			
		||||
                if (!isset($_attr[$_key])) {
 | 
			
		||||
                    if (is_int($_key)) {
 | 
			
		||||
                        $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } elseif (isset($this->smarty->template_functions[$_name]['parameter'])) {
 | 
			
		||||
           foreach ($this->smarty->template_functions[$_name]['parameter'] as $_key => $_value) {
 | 
			
		||||
                if (!isset($_attr[$_key])) {
 | 
			
		||||
                    if (is_int($_key)) {
 | 
			
		||||
                        $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        }
 | 
			
		||||
        //varibale name?
 | 
			
		||||
        if (!(strpos($_name,'$')===false)) {
 | 
			
		||||
        	$call_cache = $_name;
 | 
			
		||||
        	$call_function = '$tmp = "smarty_template_function_".'.$_name.'; $tmp';
 | 
			
		||||
       	} else {
 | 
			
		||||
        	$_name = trim($_name, "'\"");
 | 
			
		||||
       		$call_cache = "'{$_name}'";
 | 
			
		||||
         	$call_function = 'smarty_template_function_'.$_name;
 | 
			
		||||
        }
 | 
			
		||||
      	
 | 
			
		||||
        $_params = 'array(' . implode(",", $_paramsArray) . ')';
 | 
			
		||||
    	$_hash = str_replace('-','_',$compiler->template->properties['nocache_hash']);
 | 
			
		||||
        // was there an assign attribute
 | 
			
		||||
        if (isset($_assign)) {
 | 
			
		||||
            if ($compiler->template->caching) {
 | 
			
		||||
                $_output = "<?php ob_start(); Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_output = "<?php ob_start(); {$call_function}(\$_smarty_tpl,{$_params}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n";
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            if ($compiler->template->caching) {
 | 
			
		||||
                $_output = "<?php Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache});?>\n";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_output = "<?php {$call_function}(\$_smarty_tpl,{$_params});?>\n";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,81 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Capture
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {capture} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Capture Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Capture extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $shorttag_order = array('name');
 | 
			
		||||
    public $optional_attributes = array('name', 'assign', 'append'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {capture} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        $buffer = isset($_attr['name']) ? $_attr['name'] : "'default'";
 | 
			
		||||
        $assign = isset($_attr['assign']) ? $_attr['assign'] : null;
 | 
			
		||||
        $append = isset($_attr['append']) ? $_attr['append'] : null;
 | 
			
		||||
 | 
			
		||||
        $this->compiler->_capture_stack[] = array($buffer, $assign, $append, $this->compiler->nocache);
 | 
			
		||||
        // maybe nocache because of nocache variables
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache; 
 | 
			
		||||
        $_output = "<?php ob_start(); ?>";
 | 
			
		||||
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Captureclose Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_CaptureClose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/capture} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        // must endblock be nocache?
 | 
			
		||||
        if ($this->compiler->nocache) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        list($buffer, $assign, $append, $this->compiler->nocache) = array_pop($this->compiler->_capture_stack);
 | 
			
		||||
 | 
			
		||||
        $_output = "<?php ";
 | 
			
		||||
        if (isset($assign)) {
 | 
			
		||||
            $_output .= " \$_smarty_tpl->assign($assign, ob_get_contents());";
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($append)) {
 | 
			
		||||
            $_output .= " \$_smarty_tpl->append($append, ob_get_contents());";
 | 
			
		||||
        } 
 | 
			
		||||
        $_output .= " Smarty::\$_smarty_vars['capture'][$buffer]=ob_get_clean();?>";
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,64 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Config_Load extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('file');
 | 
			
		||||
    public $shorttag_order = array('file','section');
 | 
			
		||||
    public $optional_attributes = array('section', 'scope'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {config_load} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
         
 | 
			
		||||
        // save posible attributes
 | 
			
		||||
        $conf_file = $_attr['file'];
 | 
			
		||||
        if (isset($_attr['section'])) {
 | 
			
		||||
            $section = $_attr['section'];
 | 
			
		||||
        } else {
 | 
			
		||||
            $section = 'null';
 | 
			
		||||
        } 
 | 
			
		||||
        $scope = 'local';
 | 
			
		||||
        // scope setup
 | 
			
		||||
        if (isset($_attr['scope'])) {
 | 
			
		||||
            $_attr['scope'] = trim($_attr['scope'], "'\"");
 | 
			
		||||
            if (in_array($_attr['scope'],array('local','parent','root','global'))) {
 | 
			
		||||
                $scope = $_attr['scope'];
 | 
			
		||||
           } else {
 | 
			
		||||
                $this->compiler->trigger_template_error('illegal value for "scope" attribute', $this->compiler->lex->taglineno);
 | 
			
		||||
           } 
 | 
			
		||||
        } 
 | 
			
		||||
        // create config object
 | 
			
		||||
        $_output = "<?php  \$_config = new Smarty_Internal_Config($conf_file, \$_smarty_tpl->smarty, \$_smarty_tpl);";
 | 
			
		||||
        $_output .= "\$_config->loadConfigVars($section, '$scope'); ?>";
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,64 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Continue
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {continue} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Continue Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Continue extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('levels'); 
 | 
			
		||||
    public $shorttag_order = array('levels');
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {continue} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $compiler->smarty;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['levels'])) {
 | 
			
		||||
            if (!is_numeric($_attr['levels'])) {
 | 
			
		||||
                $this->compiler->trigger_template_error('level attribute must be a numeric constant', $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
            $_levels = $_attr['levels'];
 | 
			
		||||
        } else {
 | 
			
		||||
            $_levels = 1;
 | 
			
		||||
        } 
 | 
			
		||||
        $level_count = $_levels;
 | 
			
		||||
        $stack_count = count($compiler->_tag_stack) - 1;
 | 
			
		||||
        while ($level_count > 0 && $stack_count >= 0) {
 | 
			
		||||
            if (in_array($compiler->_tag_stack[$stack_count][0], array('for', 'foreach', 'while', 'section'))) {
 | 
			
		||||
                $level_count--;
 | 
			
		||||
            } 
 | 
			
		||||
            $stack_count--;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($level_count != 0) {
 | 
			
		||||
            $this->compiler->trigger_template_error("cannot continue {$_levels} level(s)", $this->compiler->lex->taglineno);
 | 
			
		||||
        } 
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = true;
 | 
			
		||||
        return "<?php continue {$_levels}?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,38 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */ 
 | 
			
		||||
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)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
		// compile always as nocache
 | 
			
		||||
		$this->compiler->tag_nocache = true;
 | 
			
		||||
 | 
			
		||||
        // display debug template
 | 
			
		||||
        $_output = "<?php \$_smarty_tpl->smarty->loadPlugin('Smarty_Internal_Debug'); Smarty_Internal_Debug::display_debug(\$_smarty_tpl); ?>";
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,51 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Eval
 | 
			
		||||
 *
 | 
			
		||||
 * Compiles the {eval} tag 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Eval Class
 | 
			
		||||
 */ 
 | 
			
		||||
class Smarty_Internal_Compile_Eval extends Smarty_Internal_CompileBase {
 | 
			
		||||
    public $required_attributes = array('var');
 | 
			
		||||
    public $optional_attributes = array('assign'); 
 | 
			
		||||
    public $shorttag_order = array('var','assign');
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {eval} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        $this->required_attributes = array('var');
 | 
			
		||||
        $this->optional_attributes = array('assign'); 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
              // output will be stored in a smarty variable instead of beind 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->getRenderedTemplate());";
 | 
			
		||||
        } else {
 | 
			
		||||
            $_output .= "echo \$_template->getRenderedTemplate();";
 | 
			
		||||
        } 
 | 
			
		||||
        return "<?php $_output ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,90 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile extend
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {extends} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile extend Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Extends extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('file');
 | 
			
		||||
    public $shorttag_order = array('file');
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {extends} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $compiler->smarty;
 | 
			
		||||
        $this->_rdl = preg_quote($this->smarty->right_delimiter);
 | 
			
		||||
        $this->_ldl = preg_quote($this->smarty->left_delimiter);
 | 
			
		||||
        $filepath = $compiler->template->getTemplateFilepath();
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $_smarty_tpl = $compiler->template; 
 | 
			
		||||
        $include_file = null;
 | 
			
		||||
        if (strpos($_attr['file'],'$_tmp') !== false) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('illegal value for file attribute', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
        eval('$include_file = ' . $_attr['file'] . ';'); 
 | 
			
		||||
        // create template object
 | 
			
		||||
        $_template = new $compiler->smarty->template_class($include_file, $this->smarty, $compiler->template); 
 | 
			
		||||
        // save file dependency
 | 
			
		||||
        if (in_array($_template->resource_type,array('eval','string'))) {
 | 
			
		||||
        	$template_sha1 = sha1($include_file);
 | 
			
		||||
    	} else {
 | 
			
		||||
        	$template_sha1 = sha1($_template->getTemplateFilepath());
 | 
			
		||||
    	}
 | 
			
		||||
        if (isset($compiler->template->properties['file_dependency'][$template_sha1])) {
 | 
			
		||||
            $this->compiler->trigger_template_error("illegal recursive call of \"{$include_file}\"",$compiler->lex->line-1);
 | 
			
		||||
        } 
 | 
			
		||||
        $compiler->template->properties['file_dependency'][$template_sha1] = array($_template->getTemplateFilepath(), $_template->getTemplateTimestamp(),$_template->resource_type);
 | 
			
		||||
        $_content = substr($compiler->template->template_source,$compiler->lex->counter-1);
 | 
			
		||||
        if (preg_match_all("!({$this->_ldl}block\s(.+?){$this->_rdl})!", $_content, $s) !=
 | 
			
		||||
                preg_match_all("!({$this->_ldl}/block{$this->_rdl})!", $_content, $c)) {
 | 
			
		||||
            $this->compiler->trigger_template_error('unmatched {block} {/block} pairs');
 | 
			
		||||
        } 
 | 
			
		||||
        preg_match_all("!{$this->_ldl}block\s(.+?){$this->_rdl}|{$this->_ldl}/block{$this->_rdl}!", $_content, $_result, PREG_OFFSET_CAPTURE);
 | 
			
		||||
        $_result_count = count($_result[0]);
 | 
			
		||||
        $_start = 0;
 | 
			
		||||
        while ($_start < $_result_count) {
 | 
			
		||||
            $_end = 0;
 | 
			
		||||
            $_level = 1;
 | 
			
		||||
            while ($_level != 0) {
 | 
			
		||||
                $_end++;
 | 
			
		||||
                if (!strpos($_result[0][$_start + $_end][0], '/')) {
 | 
			
		||||
                    $_level++;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_level--;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_block_content = str_replace($this->smarty->left_delimiter . '$smarty.block.parent' . $this->smarty->right_delimiter, '%%%%SMARTY_PARENT%%%%',
 | 
			
		||||
                substr($_content, $_result[0][$_start][1] + strlen($_result[0][$_start][0]), $_result[0][$_start + $_end][1] - $_result[0][$_start][1] - + strlen($_result[0][$_start][0])));
 | 
			
		||||
            Smarty_Internal_Compile_Block::saveBlockData($_block_content, $_result[0][$_start][0], $compiler->template, $filepath);
 | 
			
		||||
            $_start = $_start + $_end + 1;
 | 
			
		||||
        } 
 | 
			
		||||
        $compiler->template->template_source = $_template->getTemplateSource();
 | 
			
		||||
        $compiler->template->template_filepath = $_template->getTemplateFilepath();
 | 
			
		||||
        $compiler->abort_and_recompile = true;
 | 
			
		||||
        return '';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
} 
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										147
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										147
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_for.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,147 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_For extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {for} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * Smarty 3 does implement two different sytaxes:
 | 
			
		||||
     * 
 | 
			
		||||
     * - {for $var in $array}
 | 
			
		||||
     * For looping over arrays or iterators
 | 
			
		||||
     * 
 | 
			
		||||
     * - {for $x=0; $x<$y; $x++}
 | 
			
		||||
     * For general loops
 | 
			
		||||
     * 
 | 
			
		||||
     * The parser is gereration different sets of attribute by which this compiler can 
 | 
			
		||||
     * determin 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)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        if ($parameter == 0) {
 | 
			
		||||
        	$this->required_attributes = array('start','to');
 | 
			
		||||
        	$this->optional_attributes = array('max','step');
 | 
			
		||||
        } else {
 | 
			
		||||
        	$this->required_attributes = array('start','ifexp','var','step');
 | 
			
		||||
        	$this->optional_attributes = array();
 | 
			
		||||
        }
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        $local_vars = array();
 | 
			
		||||
 | 
			
		||||
        $output = "<?php ";
 | 
			
		||||
        if ($parameter == 1) {
 | 
			
		||||
            foreach ($_attr['start'] as $_statement) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars[$_statement[var]] = new Smarty_Variable;";
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars[$_statement[var]]->value = $_statement[value];\n";
 | 
			
		||||
                $compiler->local_var[$_statement['var']] = true;
 | 
			
		||||
                $local_vars[] = $_statement['var'];
 | 
			
		||||
            } 
 | 
			
		||||
            $output .= "  if ($_attr[ifexp]){ for (\$_foo=true;$_attr[ifexp]; \$_smarty_tpl->tpl_vars[$_attr[var]]->value$_attr[step]){\n";
 | 
			
		||||
        } else {
 | 
			
		||||
            $_statement = $_attr['start'];
 | 
			
		||||
            $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]] = new Smarty_Variable;";
 | 
			
		||||
            $compiler->local_var[$_statement['var']] = true;
 | 
			
		||||
            $local_vars[] = $_statement['var'];
 | 
			
		||||
            if (isset($_attr['step'])) {
 | 
			
		||||
                $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->step = $_attr[step];";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->step = 1;";
 | 
			
		||||
            } 
 | 
			
		||||
            if (isset($_attr['max'])) {
 | 
			
		||||
                $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->total = (int)min(ceil((\$_smarty_tpl->tpl_vars[$_statement[var]]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$_statement[var]]->step)),$_attr[max]);\n";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->total = (int)ceil((\$_smarty_tpl->tpl_vars[$_statement[var]]->step > 0 ? $_attr[to]+1 - ($_statement[value]) : $_statement[value]-($_attr[to])+1)/abs(\$_smarty_tpl->tpl_vars[$_statement[var]]->step));\n";
 | 
			
		||||
            } 
 | 
			
		||||
            $output .= "if (\$_smarty_tpl->tpl_vars[$_statement[var]]->total > 0){\n";
 | 
			
		||||
            $output .= "for (\$_smarty_tpl->tpl_vars[$_statement[var]]->value = $_statement[value], \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration = 1;\$_smarty_tpl->tpl_vars[$_statement[var]]->iteration <= \$_smarty_tpl->tpl_vars[$_statement[var]]->total;\$_smarty_tpl->tpl_vars[$_statement[var]]->value += \$_smarty_tpl->tpl_vars[$_statement[var]]->step, \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration++){\n";
 | 
			
		||||
            $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->first = \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration == 1;";
 | 
			
		||||
            $output .= "\$_smarty_tpl->tpl_vars[$_statement[var]]->last = \$_smarty_tpl->tpl_vars[$_statement[var]]->iteration == \$_smarty_tpl->tpl_vars[$_statement[var]]->total;";
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= "?>";
 | 
			
		||||
 | 
			
		||||
        $this->_open_tag('for', array('for', $this->compiler->nocache, $local_vars)); 
 | 
			
		||||
        // maybe nocache because of nocache variables
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache; 
 | 
			
		||||
        // return compiled code
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Forelse Class
 | 
			
		||||
 */
 | 
			
		||||
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)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr  = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $nocache, $local_vars) = $this->_close_tag(array('for'));
 | 
			
		||||
        $this->_open_tag('forelse', array('forelse', $nocache, $local_vars));
 | 
			
		||||
        return "<?php }} else { ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Forclose Class
 | 
			
		||||
 */
 | 
			
		||||
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)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr  = $this->_get_attributes($args); 
 | 
			
		||||
        // must endblock be nocache?
 | 
			
		||||
        if ($this->compiler->nocache) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $this->compiler->nocache, $local_vars) = $this->_close_tag(array('for', 'forelse'));
 | 
			
		||||
 | 
			
		||||
        foreach ($local_vars as $var) {
 | 
			
		||||
            unset($compiler->local_var[$var]);
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_open_tag == 'forelse')
 | 
			
		||||
            return "<?php }  ?>";
 | 
			
		||||
        else
 | 
			
		||||
            return "<?php }} ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,219 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Foreach extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('from', 'item');
 | 
			
		||||
    public $optional_attributes = array('name', 'key'); 
 | 
			
		||||
    public $shorttag_order = array('from','item','key','name');
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {foreach} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $tpl = $compiler->template; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        $from = $_attr['from'];
 | 
			
		||||
        $item = $_attr['item'];
 | 
			
		||||
 | 
			
		||||
        if (substr_compare("\$_smarty_tpl->getVariable($item)", $from,0, strlen("\$_smarty_tpl->getVariable($item)")) == 0) {
 | 
			
		||||
            $this->compiler->trigger_template_error("item variable {$item} may not be the same variable as at 'from'", $this->compiler->lex->taglineno);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['key'])) {
 | 
			
		||||
            $key = $_attr['key'];
 | 
			
		||||
        } else {
 | 
			
		||||
            $key = null;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $this->_open_tag('foreach', array('foreach', $this->compiler->nocache, $item, $key)); 
 | 
			
		||||
        // maybe nocache because of nocache variables
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache;
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['name'])) {
 | 
			
		||||
            $name = $_attr['name'];
 | 
			
		||||
            $has_name = true;
 | 
			
		||||
            $SmartyVarName = '$smarty.foreach.' . trim($name, '\'"') . '.';
 | 
			
		||||
        } else {
 | 
			
		||||
            $name = null;
 | 
			
		||||
            $has_name = false;
 | 
			
		||||
        } 
 | 
			
		||||
        $ItemVarName = '$' . trim($item, '\'"') . '@'; 
 | 
			
		||||
        // evaluates which Smarty variables and properties have to be computed
 | 
			
		||||
        if ($has_name) {
 | 
			
		||||
            $usesSmartyFirst = strpos($tpl->template_source, $SmartyVarName . 'first') !== false;
 | 
			
		||||
            $usesSmartyLast = strpos($tpl->template_source, $SmartyVarName . 'last') !== false;
 | 
			
		||||
            $usesSmartyIndex = strpos($tpl->template_source, $SmartyVarName . 'index') !== false;
 | 
			
		||||
            $usesSmartyIteration = strpos($tpl->template_source, $SmartyVarName . 'iteration') !== false;
 | 
			
		||||
            $usesSmartyShow = strpos($tpl->template_source, $SmartyVarName . 'show') !== false;
 | 
			
		||||
            $usesSmartyTotal = strpos($tpl->template_source, $SmartyVarName . 'total') !== false;
 | 
			
		||||
        } else {
 | 
			
		||||
            $usesSmartyFirst = false;
 | 
			
		||||
            $usesSmartyLast = false;
 | 
			
		||||
            $usesSmartyTotal = false;
 | 
			
		||||
            $usesSmartyShow = false;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $usesPropFirst = $usesSmartyFirst || strpos($tpl->template_source, $ItemVarName . 'first') !== false;
 | 
			
		||||
        $usesPropLast = $usesSmartyLast || strpos($tpl->template_source, $ItemVarName . 'last') !== false;
 | 
			
		||||
        $usesPropIndex = $usesPropFirst || strpos($tpl->template_source, $ItemVarName . 'index') !== false;
 | 
			
		||||
        $usesPropIteration = $usesPropLast || strpos($tpl->template_source, $ItemVarName . 'iteration') !== false;
 | 
			
		||||
        $usesPropShow = strpos($tpl->template_source, $ItemVarName . 'show') !== false;
 | 
			
		||||
        $usesPropTotal = $usesSmartyTotal || $usesSmartyShow || $usesPropShow || $usesPropLast || strpos($tpl->template_source, $ItemVarName . 'total') !== false; 
 | 
			
		||||
        // generate output code
 | 
			
		||||
        $output = "<?php ";
 | 
			
		||||
        $output .= " \$_smarty_tpl->tpl_vars[$item] = new Smarty_Variable;\n";
 | 
			
		||||
        $compiler->local_var[$item] = true;
 | 
			
		||||
        if ($key != null) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$key] = new Smarty_Variable;\n";
 | 
			
		||||
            $compiler->local_var[$key] = true;
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= " \$_from = $from; if (!is_array(\$_from) && !is_object(\$_from)) { settype(\$_from, 'array');}\n";
 | 
			
		||||
        if ($usesPropTotal) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->total= \$_smarty_tpl->_count(\$_from);\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropIteration) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->iteration=0;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropIndex) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->index=-1;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropShow) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->show = (\$_smarty_tpl->tpl_vars[$item]->total > 0);\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($has_name) {
 | 
			
		||||
            if ($usesSmartyTotal) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['total'] = \$_smarty_tpl->tpl_vars[$item]->total;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyIteration) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']=0;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyIndex) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']=-1;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyShow) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['show']=(\$_smarty_tpl->tpl_vars[$item]->total > 0);\n";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropTotal) {
 | 
			
		||||
			$output .= "if (\$_smarty_tpl->tpl_vars[$item]->total > 0){\n";
 | 
			
		||||
        } else {
 | 
			
		||||
			$output .= "if (\$_smarty_tpl->_count(\$_from) > 0){\n";
 | 
			
		||||
		}
 | 
			
		||||
		$output .= "    foreach (\$_from as \$_smarty_tpl->tpl_vars[$item]->key => \$_smarty_tpl->tpl_vars[$item]->value){\n";
 | 
			
		||||
        if ($key != null) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$key]->value = \$_smarty_tpl->tpl_vars[$item]->key;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropIteration) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->iteration++;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropIndex) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->index++;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropFirst) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->first = \$_smarty_tpl->tpl_vars[$item]->index === 0;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($usesPropLast) {
 | 
			
		||||
            $output .= " \$_smarty_tpl->tpl_vars[$item]->last = \$_smarty_tpl->tpl_vars[$item]->iteration === \$_smarty_tpl->tpl_vars[$item]->total;\n";
 | 
			
		||||
        } 
 | 
			
		||||
        if ($has_name) {
 | 
			
		||||
            if ($usesSmartyFirst) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['first'] = \$_smarty_tpl->tpl_vars[$item]->first;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyIteration) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']++;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyIndex) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']++;\n";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($usesSmartyLast) {
 | 
			
		||||
                $output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['last'] = \$_smarty_tpl->tpl_vars[$item]->last;\n";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= "?>";
 | 
			
		||||
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Foreachelse Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Foreachelse extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {foreachelse} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $nocache, $item, $key) = $this->_close_tag(array('foreach'));
 | 
			
		||||
        $this->_open_tag('foreachelse', array('foreachelse', $nocache, $item, $key));
 | 
			
		||||
 | 
			
		||||
        return "<?php }} else { ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Foreachclose Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Foreachclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/foreach} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        // must endblock be nocache?
 | 
			
		||||
        if ($this->compiler->nocache) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $this->compiler->nocache, $item, $key) = $this->_close_tag(array('foreach', 'foreachelse'));
 | 
			
		||||
        unset($compiler->local_var[$item]);
 | 
			
		||||
        if ($key != null) {
 | 
			
		||||
            unset($compiler->local_var[$key]);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if ($_open_tag == 'foreachelse')
 | 
			
		||||
            return "<?php } ?>";
 | 
			
		||||
        else
 | 
			
		||||
            return "<?php }} ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,134 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Function
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {function} {/function} tags
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Function Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Function extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('name');
 | 
			
		||||
    public $shorttag_order = array('name');
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {function} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
      * @param array $parameter array with compilation parameter
 | 
			
		||||
    * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
		unset($_attr['nocache']);
 | 
			
		||||
        $save = array($_attr, $compiler->parser->current_buffer,
 | 
			
		||||
            $compiler->template->has_nocache_code, $compiler->template->required_plugins);
 | 
			
		||||
        $this->_open_tag('function', $save);
 | 
			
		||||
        $_name = trim($_attr['name'], "'\"");
 | 
			
		||||
        unset($_attr['name']);
 | 
			
		||||
        $compiler->template->properties['function'][$_name]['parameter'] = array();
 | 
			
		||||
		$_smarty_tpl = $compiler->template;
 | 
			
		||||
        foreach ($_attr as $_key => $_data) {
 | 
			
		||||
        	eval ('$tmp='.$_data.';');
 | 
			
		||||
            $compiler->template->properties['function'][$_name]['parameter'][$_key] = $tmp;
 | 
			
		||||
        } 
 | 
			
		||||
        $compiler->smarty->template_functions[$_name]['parameter'] = $compiler->template->properties['function'][$_name]['parameter'];
 | 
			
		||||
        if ($compiler->template->caching) {
 | 
			
		||||
            $output = '';
 | 
			
		||||
        } else {
 | 
			
		||||
            $output = "<?php if (!function_exists('smarty_template_function_{$_name}')) {
 | 
			
		||||
    function smarty_template_function_{$_name}(\$_smarty_tpl,\$params) {
 | 
			
		||||
    \$saved_tpl_vars = \$_smarty_tpl->tpl_vars;
 | 
			
		||||
    foreach (\$_smarty_tpl->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);};
 | 
			
		||||
    foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>";
 | 
			
		||||
        } 
 | 
			
		||||
        // Init temporay context
 | 
			
		||||
        $compiler->template->required_plugins = array('compiled' => array(), 'nocache' => array());
 | 
			
		||||
        $compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser);
 | 
			
		||||
        $compiler->parser->current_buffer->append_subtree(new _smarty_tag($compiler->parser, $output));
 | 
			
		||||
        $compiler->template->has_nocache_code = false;
 | 
			
		||||
        $compiler->has_code = false;
 | 
			
		||||
        $compiler->template->properties['function'][$_name]['compiled'] = '';
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Functionclose Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Functionclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/function} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $saved_data = $this->_close_tag(array('function'));
 | 
			
		||||
        $_name = trim($saved_data[0]['name'], "'\""); 
 | 
			
		||||
        // build plugin include code
 | 
			
		||||
        $plugins_string = '';
 | 
			
		||||
        if (!empty($compiler->template->required_plugins['compiled'])) {
 | 
			
		||||
            $plugins_string = '<?php ';
 | 
			
		||||
            foreach($compiler->template->required_plugins['compiled'] as $tmp) {
 | 
			
		||||
                foreach($tmp as $data) {
 | 
			
		||||
                    $plugins_string .= "if (!is_callable('{$data['function']}')) include '{$data['file']}';\n";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $plugins_string .= '?>';
 | 
			
		||||
        } 
 | 
			
		||||
        if (!empty($compiler->template->required_plugins['nocache'])) {
 | 
			
		||||
            $plugins_string .= "<?php echo '/*%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/<?php ";
 | 
			
		||||
            foreach($compiler->template->required_plugins['nocache'] as $tmp) {
 | 
			
		||||
                foreach($tmp as $data) {
 | 
			
		||||
                    $plugins_string .= "if (!is_callable(\'{$data['function']}\')) include \'{$data['file']}\';\n";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $plugins_string .= "?>/*/%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/';?>\n";
 | 
			
		||||
        } 
 | 
			
		||||
 		// remove last line break from function definition
 | 
			
		||||
 		$last = count($compiler->parser->current_buffer->subtrees) - 1;
 | 
			
		||||
 		if ($compiler->parser->current_buffer->subtrees[$last] instanceof _smarty_linebreak) {
 | 
			
		||||
 			unset($compiler->parser->current_buffer->subtrees[$last]);
 | 
			
		||||
 		}
 | 
			
		||||
        // if caching save template function for possible nocache call
 | 
			
		||||
        if ($compiler->template->caching) {
 | 
			
		||||
            $compiler->template->properties['function'][$_name]['compiled'] .= $plugins_string
 | 
			
		||||
             . $compiler->parser->current_buffer->to_smarty_php();
 | 
			
		||||
            $compiler->template->properties['function'][$_name]['nocache_hash'] = $compiler->template->properties['nocache_hash'];
 | 
			
		||||
            $compiler->template->properties['function'][$_name]['has_nocache_code'] = $compiler->template->has_nocache_code;
 | 
			
		||||
            $compiler->smarty->template_functions[$_name] = $compiler->template->properties['function'][$_name];
 | 
			
		||||
            $compiler->has_code = false;
 | 
			
		||||
            $output = true;
 | 
			
		||||
        } else {
 | 
			
		||||
            $output = $plugins_string . $compiler->parser->current_buffer->to_smarty_php() . "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars;}}?>\n";
 | 
			
		||||
        } 
 | 
			
		||||
        // restore old compiler status
 | 
			
		||||
        $compiler->parser->current_buffer = $saved_data[1];
 | 
			
		||||
        $compiler->template->has_nocache_code = $compiler->template->has_nocache_code | $saved_data[2];
 | 
			
		||||
        $compiler->template->required_plugins = $saved_data[3];
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										179
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										179
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compile_if.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,179 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_If extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {if} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $this->_open_tag('if',array(1,$this->compiler->nocache));
 | 
			
		||||
        // must whole block be nocache ?
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache; 
 | 
			
		||||
        if (is_array($parameter['if condition'])) {
 | 
			
		||||
        	if ($this->compiler->nocache) {
 | 
			
		||||
        		$_nocache = ',true';
 | 
			
		||||
            	// create nocache var to make it know for further compiling
 | 
			
		||||
            	if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            		$this->compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
            	} else {
 | 
			
		||||
            		$this->compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
            	}
 | 
			
		||||
        	} else {
 | 
			
		||||
        		$_nocache = '';
 | 
			
		||||
        	}
 | 
			
		||||
            if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            	$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]) || !is_array(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value)) \$_smarty_tpl->createLocalArrayVariable(".$parameter['if condition']['var']['var']."$_nocache);\n";
 | 
			
		||||
	            $_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value".$parameter['if condition']['var']['smarty_internal_index']." = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
            } else {
 | 
			
		||||
	            $_output = "<?php \$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."] = new Smarty_Variable(\$_smarty_tpl->getVariable(".$parameter['if condition']['var'].",null,true,false)->value{$_nocache});";           
 | 
			
		||||
	            $_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."]->value = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
	        }
 | 
			
		||||
            return $_output;
 | 
			
		||||
        } else {
 | 
			
		||||
            return "<?php if ({$parameter['if condition']}){?>";
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Else Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Else extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {else} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        list($nesting, $compiler->tag_nocache) = $this->_close_tag(array('if', 'elseif'));
 | 
			
		||||
        $this->_open_tag('else',array($nesting,$compiler->tag_nocache));
 | 
			
		||||
 | 
			
		||||
        return "<?php }else{ ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile ElseIf Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Elseif extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {elseif} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        list($nesting, $compiler->tag_nocache) = $this->_close_tag(array('if', 'elseif'));
 | 
			
		||||
 | 
			
		||||
		if (is_array($parameter['if condition'])) {
 | 
			
		||||
			$condition_by_assign = true;
 | 
			
		||||
			if ($this->compiler->nocache) {
 | 
			
		||||
        		$_nocache = ',true';
 | 
			
		||||
				// create nocache var to make it know for further compiling
 | 
			
		||||
				if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
					$this->compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
				} else {
 | 
			
		||||
					$this->compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
				}
 | 
			
		||||
			} else {
 | 
			
		||||
				$_nocache = '';
 | 
			
		||||
			}
 | 
			
		||||
		} else {
 | 
			
		||||
			$condition_by_assign = false;
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
        if (empty($this->compiler->prefix_code)) {
 | 
			
		||||
        	if ($condition_by_assign) {
 | 
			
		||||
            	$this->_open_tag('elseif', array($nesting + 1, $compiler->tag_nocache));
 | 
			
		||||
            	if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            		$_output = "<?php }else{ if (!isset(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]) || !is_array(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value)) \$_smarty_tpl->createLocalArrayVariable(".$parameter['if condition']['var']['var']."$_nocache);\n";
 | 
			
		||||
	            	$_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value".$parameter['if condition']['var']['smarty_internal_index']." = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
            	} else {
 | 
			
		||||
	            	$_output = "<?php }else{ \$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."] = new Smarty_Variable(\$_smarty_tpl->getVariable(".$parameter['if condition']['var'].",null,true,false)->value{$_nocache});";          
 | 
			
		||||
	            	$_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."]->value = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
				}
 | 
			
		||||
            	return $_output;
 | 
			
		||||
        	} else {
 | 
			
		||||
            	$this->_open_tag('elseif', array($nesting, $compiler->tag_nocache));
 | 
			
		||||
            	return "<?php }elseif({$parameter['if condition']}){?>";
 | 
			
		||||
        	}
 | 
			
		||||
        } else {
 | 
			
		||||
            $tmp = '';
 | 
			
		||||
            foreach ($this->compiler->prefix_code as $code) $tmp .= $code;
 | 
			
		||||
            $this->compiler->prefix_code = array();
 | 
			
		||||
            $this->_open_tag('elseif', array($nesting + 1, $compiler->tag_nocache));
 | 
			
		||||
        	if ($condition_by_assign) {
 | 
			
		||||
            	if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            		$_output = "<?php }else{?>{$tmp}<?php  if (!isset(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]) || !is_array(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value)) \$_smarty_tpl->createLocalArrayVariable(".$parameter['if condition']['var']['var']."$_nocache);\n";
 | 
			
		||||
	            	$_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value".$parameter['if condition']['var']['smarty_internal_index']." = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
            	} else {
 | 
			
		||||
	            	$_output = "<?php }else{?>{$tmp}<?php \$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."] = new Smarty_Variable(\$_smarty_tpl->getVariable(".$parameter['if condition']['var'].",null,true,false)->value{$_nocache});";           
 | 
			
		||||
	            	$_output .= "if (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."]->value = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
				}
 | 
			
		||||
            	return $_output;
 | 
			
		||||
        	} else {
 | 
			
		||||
            	return "<?php }else{?>{$tmp}<?php if ({$parameter['if condition']}){?>";
 | 
			
		||||
        	}
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Compile Ifclose Class
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Compile_Ifclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
    * Compiles code for the {/if} tag
 | 
			
		||||
    * 
 | 
			
		||||
    * @param array $args array with attributes from parser
 | 
			
		||||
    * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
    * @return string compiled code
 | 
			
		||||
    */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
            // must endblock be nocache?
 | 
			
		||||
            if ($this->compiler->nocache) {
 | 
			
		||||
                $this->compiler->tag_nocache = true;
 | 
			
		||||
            } 
 | 
			
		||||
        list($nesting, $this->compiler->nocache) = $this->_close_tag(array('if', 'else', 'elseif'));
 | 
			
		||||
        $tmp = '';
 | 
			
		||||
        for ($i = 0; $i < $nesting ; $i++) $tmp .= '}';
 | 
			
		||||
        return "<?php {$tmp}?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,176 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Include
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {include} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Include Class
 | 
			
		||||
 */
 | 
			
		||||
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 definitions
 | 
			
		||||
    public $required_attributes = array('file');
 | 
			
		||||
   	public $shorttag_order = array('file');
 | 
			
		||||
    public $option_flags = array('nocache','inline','caching');
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {include} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        // save posible attributes
 | 
			
		||||
        $include_file = $_attr['file'];
 | 
			
		||||
        $has_compiled_template = false;
 | 
			
		||||
        if ($compiler->smarty->merge_compiled_includes || $_attr['inline'] === true) {
 | 
			
		||||
            // check if compiled code can be merged (contains no variable part)
 | 
			
		||||
            if (!$compiler->has_variable_string && (substr_count($include_file, '"') == 2 or substr_count($include_file, "'") == 2) and substr_count($include_file, '(') == 0) {
 | 
			
		||||
             $tmp = null;
 | 
			
		||||
	    eval("\$tmp = $include_file;");
 | 
			
		||||
                if ($this->compiler->template->template_resource != $tmp) {
 | 
			
		||||
                    $tpl = new $compiler->smarty->template_class ($tmp, $compiler->smarty, $compiler->template, $compiler->template->cache_id, $compiler->template->compile_id);
 | 
			
		||||
                    // suppress writing of compiled file
 | 
			
		||||
                    $tpl->write_compiled_code = false;
 | 
			
		||||
                    if ($this->compiler->template->caching) {
 | 
			
		||||
                        // needs code for cached page but no cache file
 | 
			
		||||
                        $tpl->caching = self::CACHING_NOCACHE_CODE;
 | 
			
		||||
                    } 
 | 
			
		||||
//                    if ($this->compiler->template->mustCompile) {
 | 
			
		||||
                        // make sure whole chain gest compiled
 | 
			
		||||
                        $tpl->mustCompile = true;
 | 
			
		||||
//                    } 
 | 
			
		||||
                    if ($tpl->resource_object->usesCompiler && $tpl->isExisting()) {
 | 
			
		||||
                        // get compiled code
 | 
			
		||||
                        $compiled_tpl = $tpl->getCompiledTemplate(); 
 | 
			
		||||
                        // merge compiled code for {function} tags
 | 
			
		||||
                        $compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $tpl->properties['function']); 
 | 
			
		||||
                        // merge filedependency by evaluating header code
 | 
			
		||||
                        preg_match_all("/(<\?php \/\*%%SmartyHeaderCode:{$tpl->properties['nocache_hash']}%%\*\/(.+?)\/\*\/%%SmartyHeaderCode%%\*\/\?>\n)/s", $compiled_tpl, $result);
 | 
			
		||||
                        $saved_has_nocache_code = $compiler->template->has_nocache_code;
 | 
			
		||||
                        $saved_nocache_hash = $compiler->template->properties['nocache_hash'];
 | 
			
		||||
                        $_smarty_tpl = $compiler->template;
 | 
			
		||||
                        eval($result[2][0]);
 | 
			
		||||
                        $compiler->template->properties['nocache_hash'] = $saved_nocache_hash;
 | 
			
		||||
                        $compiler->template->has_nocache_code = $saved_has_nocache_code; 
 | 
			
		||||
                        // remove header code
 | 
			
		||||
                        $compiled_tpl = preg_replace("/(<\?php \/\*%%SmartyHeaderCode:{$tpl->properties['nocache_hash']}%%\*\/(.+?)\/\*\/%%SmartyHeaderCode%%\*\/\?>\n)/s", '', $compiled_tpl);
 | 
			
		||||
                        if ($tpl->has_nocache_code) {
 | 
			
		||||
                            // replace nocache_hash
 | 
			
		||||
                            $compiled_tpl = preg_replace("/{$tpl->properties['nocache_hash']}/", $compiler->template->properties['nocache_hash'], $compiled_tpl);
 | 
			
		||||
                            $compiler->template->has_nocache_code = true;
 | 
			
		||||
                        } 
 | 
			
		||||
                        $has_compiled_template = true;
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
            // output will be stored in a smarty variable instead of beind displayed
 | 
			
		||||
            $_assign = $_attr['assign'];
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $_parent_scope = Smarty::SCOPE_LOCAL;
 | 
			
		||||
        if (isset($_attr['scope'])) {
 | 
			
		||||
            $_attr['scope'] = trim($_attr['scope'], "'\"");
 | 
			
		||||
            if ($_attr['scope'] == 'parent') {
 | 
			
		||||
                $_parent_scope = Smarty::SCOPE_PARENT;
 | 
			
		||||
            } elseif ($_attr['scope'] == 'root') {
 | 
			
		||||
                $_parent_scope = Smarty::SCOPE_ROOT;
 | 
			
		||||
            } elseif ($_attr['scope'] == 'global') {
 | 
			
		||||
                $_parent_scope = Smarty::SCOPE_GLOBAL;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_caching = 'null';
 | 
			
		||||
        if ($this->compiler->nocache || $this->compiler->tag_nocache) {
 | 
			
		||||
            $_caching = Smarty::CACHING_OFF;
 | 
			
		||||
        } 
 | 
			
		||||
        // default for included templates
 | 
			
		||||
        if ($this->compiler->template->caching && !$this->compiler->nocache && !$this->compiler->tag_nocache) {
 | 
			
		||||
            $_caching = self::CACHING_NOCACHE_CODE;
 | 
			
		||||
        } 
 | 
			
		||||
        /*
 | 
			
		||||
        * if the {include} tag provides individual parameter for caching
 | 
			
		||||
        * it will not be included into the common cache file and treated like
 | 
			
		||||
        * a nocache section
 | 
			
		||||
        */
 | 
			
		||||
        if (isset($_attr['cache_lifetime'])) {
 | 
			
		||||
            $_cache_lifetime = $_attr['cache_lifetime'];
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
            $_caching = Smarty::CACHING_LIFETIME_CURRENT;
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache_lifetime = 'null';
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($_attr['cache_id'])) {
 | 
			
		||||
            $_cache_id = $_attr['cache_id'];
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
            $_caching = Smarty::CACHING_LIFETIME_CURRENT;
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache_id = '$_smarty_tpl->cache_id';
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($_attr['compile_id'])) {
 | 
			
		||||
            $_compile_id = $_attr['compile_id'];
 | 
			
		||||
        } else {
 | 
			
		||||
            $_compile_id = '$_smarty_tpl->compile_id';
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_attr['caching'] === true) {
 | 
			
		||||
            $_caching = Smarty::CACHING_LIFETIME_CURRENT;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
            $_caching = Smarty::CACHING_OFF;
 | 
			
		||||
        } 
 | 
			
		||||
        // create template object
 | 
			
		||||
        $_output = "<?php \$_template = new {$compiler->smarty->template_class}($include_file, \$_smarty_tpl->smarty, \$_smarty_tpl, $_cache_id, $_compile_id, $_caching, $_cache_lifetime);\n"; 
 | 
			
		||||
        // delete {include} standard attributes
 | 
			
		||||
        unset($_attr['file'], $_attr['assign'], $_attr['cache_id'], $_attr['compile_id'], $_attr['cache_lifetime'], $_attr['nocache'], $_attr['caching'], $_attr['scope'], $_attr['inline']); 
 | 
			
		||||
        // remaining attributes must be assigned as smarty variable
 | 
			
		||||
        if (!empty($_attr)) {
 | 
			
		||||
            if ($_parent_scope == Smarty::SCOPE_LOCAL) {
 | 
			
		||||
                // create variables
 | 
			
		||||
                foreach ($_attr as $_key => $_value) {
 | 
			
		||||
                    $_output .= "\$_template->assign('$_key',$_value);";
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->compiler->trigger_template_error('variable passing not allowed in parent/global scope', $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // was there an assign attribute
 | 
			
		||||
        if (isset($_assign)) {
 | 
			
		||||
            $_output .= "\$_smarty_tpl->assign($_assign,\$_template->getRenderedTemplate());?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            if ($has_compiled_template && !($compiler->template->caching && ($this->compiler->tag_nocache || $this->compiler->nocache))) {
 | 
			
		||||
                $_output .= "\$_template->properties['nocache_hash']  = '{$compiler->template->properties['nocache_hash']}';\n";
 | 
			
		||||
                $_output .= "\$_tpl_stack[] = \$_smarty_tpl; \$_smarty_tpl = \$_template;?>\n";
 | 
			
		||||
                $_output .= $compiled_tpl;
 | 
			
		||||
                $_output .= "<?php \$_smarty_tpl->updateParentVariables($_parent_scope);?>\n";
 | 
			
		||||
                $_output .= "<?php /*  End of included template \"" . $tpl->getTemplateFilepath() . "\" */ ?>\n";
 | 
			
		||||
                $_output .= "<?php \$_smarty_tpl = array_pop(\$_tpl_stack);?>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_output .= " echo \$_template->getRenderedTemplate();?>";
 | 
			
		||||
                if ($_parent_scope != Smarty::SCOPE_LOCAL) {
 | 
			
		||||
                	$_output .= "<?php \$_template->updateParentVariables($_parent_scope);?>";
 | 
			
		||||
            	}
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_output .= "<?php unset(\$_template);?>";
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,90 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Include_Php extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('file');
 | 
			
		||||
   	public $shorttag_order = array('file');
 | 
			
		||||
    public $optional_attributes = array('once', 'assign'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {include_php} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
    	if (!$compiler->smarty->allow_php_tag) {
 | 
			
		||||
        	throw new SmartyException("{include_php} is deprecated, set allow_php_tag = true to enable");
 | 
			
		||||
    	} 
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        $_output = '<?php '; 
 | 
			
		||||
 | 
			
		||||
        $_smarty_tpl = $compiler->template; 
 | 
			
		||||
        $_filepath = false;
 | 
			
		||||
        eval('$_file = ' . $_attr['file'] . ';'); 
 | 
			
		||||
        if (!isset($this->compiler->smarty->security_policy) && file_exists($_file)) {
 | 
			
		||||
        	$_filepath = $_file;
 | 
			
		||||
        } else {
 | 
			
		||||
            if (isset($this->compiler->smarty->security_policy)) {
 | 
			
		||||
                $_dir = $this->compiler->smarty->security_policy->trusted_dir;
 | 
			
		||||
            } else {
 | 
			
		||||
                $_dir = $this->compiler->smarty->trusted_dir;
 | 
			
		||||
            } 
 | 
			
		||||
            if (!empty($_dir)) {
 | 
			
		||||
                foreach((array)$_dir as $_script_dir) {
 | 
			
		||||
                    if (strpos('/\\', substr($_script_dir, -1)) === false) {
 | 
			
		||||
                        $_script_dir .= DS;
 | 
			
		||||
                    } 
 | 
			
		||||
                    if (file_exists($_script_dir . $_file)) {
 | 
			
		||||
                        $_filepath = $_script_dir .  $_file;
 | 
			
		||||
                        break;
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_filepath == false) {
 | 
			
		||||
            $this->compiler->trigger_template_error("{include_php} file '{$_file}' is not readable", $this->compiler->lex->taglineno);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (isset($this->compiler->smarty->security_policy)) {
 | 
			
		||||
            $this->compiler->smarty->security_policy->isTrustedPHPDir($_filepath);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
            // output will be stored in a smarty variable instead of being displayed
 | 
			
		||||
            $_assign = $_attr['assign'];
 | 
			
		||||
        } 
 | 
			
		||||
        $_once = '_once';
 | 
			
		||||
        if (isset($_attr['once'])) {
 | 
			
		||||
            if ($_attr['once'] == 'false') {
 | 
			
		||||
                $_once = '';
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (isset($_assign)) {
 | 
			
		||||
            return "<?php ob_start(); include{$_once} ('{$_filepath}'); \$_smarty_tpl->assign({$_assign},ob_get_contents()); ob_end_clean();?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            return "<?php include{$_once} ('{$_filepath}');?>\n";
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,123 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Insert
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {insert} tag
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Insert Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Insert extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('name');
 | 
			
		||||
   	public $shorttag_order = array('name');
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {insert} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        // never compile as nocache code
 | 
			
		||||
        $this->compiler->suppressNocacheProcessing = true;
 | 
			
		||||
        $this->compiler->tag_nocache = true;
 | 
			
		||||
        $_smarty_tpl = $compiler->template;
 | 
			
		||||
        $_name = null;
 | 
			
		||||
        $_script = null;
 | 
			
		||||
 | 
			
		||||
        $_output = '<?php '; 
 | 
			
		||||
        // save posible 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 shure that the compiler knows about its nocache status
 | 
			
		||||
            $this->compiler->template->tpl_vars[trim($_attr['assign'], "'")] = new Smarty_Variable(null, true);
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($_attr['script'])) {
 | 
			
		||||
            // script which must be included
 | 
			
		||||
            $_function = "smarty_insert_{$_name}";
 | 
			
		||||
            $_smarty_tpl = $compiler->template;
 | 
			
		||||
            $_filepath = false;
 | 
			
		||||
            eval('$_script = ' . $_attr['script'] . ';');
 | 
			
		||||
            if (!isset($this->compiler->smarty->security_policy) && file_exists($_script)) {
 | 
			
		||||
                $_filepath = $_script;
 | 
			
		||||
            } else {
 | 
			
		||||
                if (isset($this->compiler->smarty->security_policy)) {
 | 
			
		||||
                    $_dir = $this->compiler->smarty->security_policy->trusted_dir;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_dir = $this->compiler->smarty->trusted_dir;
 | 
			
		||||
                } 
 | 
			
		||||
                if (!empty($_dir)) {
 | 
			
		||||
                    foreach((array)$_dir as $_script_dir) {
 | 
			
		||||
                        if (strpos('/\\', substr($_script_dir, -1)) === false) {
 | 
			
		||||
                            $_script_dir .= DS;
 | 
			
		||||
                        } 
 | 
			
		||||
                        if (file_exists($_script_dir . $_script)) {
 | 
			
		||||
                            $_filepath = $_script_dir . $_script;
 | 
			
		||||
                            break;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            if ($_filepath == false) {
 | 
			
		||||
                $this->compiler->trigger_template_error("{insert} missing script file '{$_script}'", $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
            // code for script file loading
 | 
			
		||||
            $_output .= "require_once '{$_filepath}' ;";
 | 
			
		||||
            require_once $_filepath;
 | 
			
		||||
            if (!is_callable($_function)) {
 | 
			
		||||
                $this->compiler->trigger_template_error(" {insert} function '{$_function}' is not callable in script file '{$_script}'", $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            $_filepath = 'null';
 | 
			
		||||
            $_function = "insert_{$_name}"; 
 | 
			
		||||
            // function in PHP script ?
 | 
			
		||||
            if (!is_callable($_function)) {
 | 
			
		||||
                // try plugin
 | 
			
		||||
                if (!$_function = $this->compiler->getPlugin($_name, 'insert')) {
 | 
			
		||||
                    $this->compiler->trigger_template_error("{insert} no function or plugin found for '{$_name}'", $this->compiler->lex->taglineno);
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // delete {insert} standard attributes
 | 
			
		||||
        unset($_attr['name'], $_attr['assign'], $_attr['script'], $_attr['nocache']); 
 | 
			
		||||
        // convert attributes into parameter array string
 | 
			
		||||
        $_paramsArray = array();
 | 
			
		||||
        foreach ($_attr as $_key => $_value) {
 | 
			
		||||
            $_paramsArray[] = "'$_key' => $_value";
 | 
			
		||||
        } 
 | 
			
		||||
        $_params = 'array(' . implode(", ", $_paramsArray) . ')'; 
 | 
			
		||||
        // call insert
 | 
			
		||||
        if (isset($_assign)) {
 | 
			
		||||
            if ($_smarty_tpl->caching) {
 | 
			
		||||
                $_output .= "echo Smarty_Internal_Nocache_Insert::compile ('{$_function}',{$_params}, \$_smarty_tpl, '{$_filepath}',{$_assign});?>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_output .= "\$_smarty_tpl->assign({$_assign} , {$_function} ({$_params},\$_smarty_tpl), true);?>";
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            $this->compiler->has_output = true;
 | 
			
		||||
            if ($_smarty_tpl->caching) {
 | 
			
		||||
                $_output .= "echo Smarty_Internal_Nocache_Insert::compile ('{$_function}',{$_params}, \$_smarty_tpl, '{$_filepath}');?>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_output .= "echo {$_function}({$_params},\$_smarty_tpl);?>";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $_output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,37 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Ldelim
 | 
			
		||||
 *
 | 
			
		||||
 * Compiles the {ldelim} tag 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Ldelim Class
 | 
			
		||||
 */ 
 | 
			
		||||
class Smarty_Internal_Compile_Ldelim extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {ldelim} tag
 | 
			
		||||
     *
 | 
			
		||||
     * This tag does output the left delimiter 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = true;
 | 
			
		||||
        return $this->compiler->smarty->left_delimiter;
 | 
			
		||||
    } 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,63 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Nocache
 | 
			
		||||
 *
 | 
			
		||||
 * Compiles the {nocache} {/nocache} tags 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Nocache Class
 | 
			
		||||
 */ 
 | 
			
		||||
class Smarty_Internal_Compile_Nocache extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {nocache} tag
 | 
			
		||||
     *
 | 
			
		||||
     * This tag does not generate compiled output. It only sets a compiler flag 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
        // enter nocache mode
 | 
			
		||||
        $this->compiler->nocache = true;
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = false;
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Nocacheclose Class
 | 
			
		||||
 */ 
 | 
			
		||||
class Smarty_Internal_Compile_Nocacheclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/nocache} tag
 | 
			
		||||
     *
 | 
			
		||||
     * This tag does not generate compiled output. It only sets a compiler flag 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        // leave nocache mode
 | 
			
		||||
        $this->compiler->nocache = false;
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = false;
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,78 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Block_Plugin extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of block plugin
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of block plugin
 | 
			
		||||
     * @param string $function PHP function name
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag, $function)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        if (strlen($tag) < 6 || substr($tag, -5) != 'close') {
 | 
			
		||||
            // opening tag of block plugin
 | 
			
		||||
        	// check and get attributes
 | 
			
		||||
        	$_attr = $this->_get_attributes($args); 
 | 
			
		||||
        	if ($_attr['nocache'] === true) {
 | 
			
		||||
            	$this->compiler->tag_nocache = true;
 | 
			
		||||
        	}
 | 
			
		||||
       		unset($_attr['nocache']);
 | 
			
		||||
            // convert attributes into parameter array string
 | 
			
		||||
            $_paramsArray = array();
 | 
			
		||||
            foreach ($_attr as $_key => $_value) {
 | 
			
		||||
                if (is_int($_key)) {
 | 
			
		||||
                    $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_params = 'array(' . implode(",", $_paramsArray) . ')';
 | 
			
		||||
 | 
			
		||||
            $this->_open_tag($tag, array($_params, $this->compiler->nocache)); 
 | 
			
		||||
            // maybe nocache because of nocache variables or nocache plugin
 | 
			
		||||
            $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            // must endblock be nocache?
 | 
			
		||||
            if ($this->compiler->nocache) {
 | 
			
		||||
                $this->compiler->tag_nocache = true;
 | 
			
		||||
            } 
 | 
			
		||||
            // closing tag of block plugin, restore nocache
 | 
			
		||||
            list($_params, $this->compiler->nocache) = $this->_close_tag(substr($tag, 0, -5)); 
 | 
			
		||||
            // This tag does create output
 | 
			
		||||
            $this->compiler->has_output = true; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            if (!isset($parameter['modifier_list'])) {
 | 
			
		||||
            	$mod_pre = $mod_post ='';
 | 
			
		||||
            } else {
 | 
			
		||||
            	$mod_pre = ' ob_start(); ';
 | 
			
		||||
            	$mod_post = 'echo '.$this->compiler->compileTag('private_modifier',array(),array('modifierlist'=>$parameter['modifier_list'],'value'=>'ob_get_clean()')).';';
 | 
			
		||||
            }
 | 
			
		||||
            $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;".$mod_pre." echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); ".$mod_post." } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
 | 
			
		||||
        } 
 | 
			
		||||
        return $output . "\n";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,58 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Function_Plugin extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array();
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of function plugin
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of function plugin
 | 
			
		||||
     * @param string $function PHP function name
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag, $function)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // This tag does create output
 | 
			
		||||
        $this->compiler->has_output = true;
 | 
			
		||||
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
        unset($_attr['nocache']);
 | 
			
		||||
        // convert attributes into parameter array string
 | 
			
		||||
        $_paramsArray = array();
 | 
			
		||||
        foreach ($_attr as $_key => $_value) {
 | 
			
		||||
            if (is_int($_key)) {
 | 
			
		||||
                $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_params = 'array(' . implode(",", $_paramsArray) . ')'; 
 | 
			
		||||
        // compile code
 | 
			
		||||
        $output = "<?php echo {$function}({$_params},\$_smarty_tpl);?>\n";
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,69 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Modifier
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles code for modifier execution
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Modifier Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Modifier extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for modifier execution
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        $this->smarty = $this->compiler->smarty;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $output = $parameter['value']; 
 | 
			
		||||
        // loop over list of modifiers
 | 
			
		||||
        foreach ($parameter['modifierlist'] as $single_modifier) {
 | 
			
		||||
            $modifier = $single_modifier[0];
 | 
			
		||||
	   $single_modifier[0] = $output;
 | 
			
		||||
            $params = implode(',', $single_modifier); 
 | 
			
		||||
            // check for registered modifier
 | 
			
		||||
            if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][$modifier])) {
 | 
			
		||||
                $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][$modifier][0];
 | 
			
		||||
                if (!is_array($function)) {
 | 
			
		||||
                    $output = "{$function}({$params})";
 | 
			
		||||
                } else {
 | 
			
		||||
                    if (is_object($function[0])) {
 | 
			
		||||
                        $output = '$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_MODIFIER][\'' . $modifier . '\'][0][0]->' . $function[1] . '(' . $params . ')';
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $output = $function[0] . '::' . $function[1] . '(' . $params . ')';
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
                // check for plugin modifiercompiler
 | 
			
		||||
            } else if ($compiler->smarty->loadPlugin('smarty_modifiercompiler_' . $modifier)) {
 | 
			
		||||
                $plugin = 'smarty_modifiercompiler_' . $modifier;
 | 
			
		||||
                $output = $plugin($single_modifier, $compiler); 
 | 
			
		||||
                // check for plugin modifier
 | 
			
		||||
            } else if ($function = $this->compiler->getPlugin($modifier, Smarty::PLUGIN_MODIFIER)) {
 | 
			
		||||
                $output = "{$function}({$params})"; 
 | 
			
		||||
                // check if trusted PHP function
 | 
			
		||||
            } else if (is_callable($modifier)) {
 | 
			
		||||
                // check if modifier allowed
 | 
			
		||||
                if (!is_object($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedModifier($modifier, $this->compiler)) {
 | 
			
		||||
                    $output = "{$modifier}({$params})";
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->compiler->trigger_template_error ("unknown modifier \"" . $modifier . "\"", $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,80 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Object_Block_Function extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array();
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of block plugin
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of block object
 | 
			
		||||
     * @param string $methode name of methode to call
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag, $methode)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        if (strlen($tag) < 5 || substr($tag, -5) != 'close') {
 | 
			
		||||
            // opening tag of block plugin
 | 
			
		||||
        	// check and get attributes
 | 
			
		||||
        	$_attr = $this->_get_attributes($args); 
 | 
			
		||||
        	if ($_attr['nocache'] === true) {
 | 
			
		||||
            	$this->compiler->tag_nocache = true;
 | 
			
		||||
        	}
 | 
			
		||||
       		unset($_attr['nocache']);
 | 
			
		||||
            // convert attributes into parameter array string
 | 
			
		||||
            $_paramsArray = array();
 | 
			
		||||
            foreach ($_attr as $_key => $_value) {
 | 
			
		||||
                if (is_int($_key)) {
 | 
			
		||||
                    $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_params = 'array(' . implode(",", $_paramsArray) . ')';
 | 
			
		||||
 | 
			
		||||
            $this->_open_tag($tag . '->' . $methode, array($_params, $this->compiler->nocache)); 
 | 
			
		||||
            // maybe nocache because of nocache variables or nocache plugin
 | 
			
		||||
            $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}->{$methode}', {$_params}); \$_block_repeat=true; \$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$methode}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            $base_tag = substr($tag, 0, -5); 
 | 
			
		||||
            // must endblock be nocache?
 | 
			
		||||
            if ($this->compiler->nocache) {
 | 
			
		||||
                $this->compiler->tag_nocache = true;
 | 
			
		||||
            } 
 | 
			
		||||
            // closing tag of block plugin, restore nocache
 | 
			
		||||
            list($_params, $this->compiler->nocache) = $this->_close_tag($base_tag . '->' . $methode); 
 | 
			
		||||
            // This tag does create output
 | 
			
		||||
            $this->compiler->has_output = true; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            if (!isset($parameter['modifier_list'])) {
 | 
			
		||||
            	$mod_pre = $mod_post ='';
 | 
			
		||||
            } else {
 | 
			
		||||
            	$mod_pre = ' ob_start(); ';
 | 
			
		||||
            	$mod_post = 'echo '.$this->compiler->compileTag('private_modifier',array(),array('modifierlist'=>$parameter['modifier_list'],'value'=>'ob_get_clean()')).';';
 | 
			
		||||
            }
 | 
			
		||||
            $output = "<?php \$_block_content = ob_get_contents(); ob_end_clean(); \$_block_repeat=false;".$mod_pre." echo \$_smarty_tpl->smarty->registered_objects['{$base_tag}'][0]->{$methode}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); ".$mod_post."  } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
 | 
			
		||||
        } 
 | 
			
		||||
        return $output."\n";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,71 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Object Funtion
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles code for registered objects as function
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Object Function Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Object_Function extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array();
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of function plugin
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of function
 | 
			
		||||
     * @param string $methode name of methode to call
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag, $methode)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
        unset($_attr['nocache']);
 | 
			
		||||
        $_assign = null;
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
            $_assign = $_attr['assign'];
 | 
			
		||||
            unset($_attr['assign']);
 | 
			
		||||
        } 
 | 
			
		||||
        // convert attributes into parameter array string
 | 
			
		||||
        if ($this->compiler->smarty->registered_objects[$tag][2]) {
 | 
			
		||||
            $_paramsArray = array();
 | 
			
		||||
            foreach ($_attr as $_key => $_value) {
 | 
			
		||||
                if (is_int($_key)) {
 | 
			
		||||
                    $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_params = 'array(' . implode(",", $_paramsArray) . ')';
 | 
			
		||||
            $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$methode}({$_params},\$_smarty_tpl)";
 | 
			
		||||
        } else {
 | 
			
		||||
            $_params = implode(",", $_attr);
 | 
			
		||||
            $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$methode}({$_params})";
 | 
			
		||||
        } 
 | 
			
		||||
        if (empty($_assign)) {
 | 
			
		||||
            // This tag does create output
 | 
			
		||||
            $this->compiler->has_output = true;
 | 
			
		||||
            $output = "<?php echo {$return};?>\n";
 | 
			
		||||
        } else {
 | 
			
		||||
            $output = "<?php \$_smarty_tpl->assign({$_assign},{$return});?>\n";
 | 
			
		||||
    }
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,77 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Print_Expression extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('assign'); 
 | 
			
		||||
    public $option_flags = array('nocache', 'nofilter'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for gererting output from any expression
 | 
			
		||||
     * 
 | 
			
		||||
     * @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)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        // nocache option
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        } 
 | 
			
		||||
        // filter handling
 | 
			
		||||
        if ($_attr['nofilter'] === true) {
 | 
			
		||||
            $_filter = 'false';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_filter = 'true';
 | 
			
		||||
        } 
 | 
			
		||||
        // compiled output
 | 
			
		||||
        // compiled output
 | 
			
		||||
        if (isset($_attr['assign'])) {
 | 
			
		||||
            // assign output to variable
 | 
			
		||||
            $output = "<?php \$_smarty_tpl->assign({$_attr['assign']},{$parameter['value']});?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            // display value
 | 
			
		||||
            if (!$_attr['nofilter'] && isset($this->compiler->smarty->registered_filters['variable'])) {
 | 
			
		||||
                $output = "Smarty_Internal_Filter_Handler::runFilter('variable', {$parameter['value']}, \$_smarty_tpl, {$_filter})";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output = $parameter['value'];
 | 
			
		||||
            } 
 | 
			
		||||
            if (!$_attr['nofilter'] && !empty($this->compiler->smarty->default_modifiers)) {
 | 
			
		||||
                $modifierlist = array();
 | 
			
		||||
                foreach ($this->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];
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
                $output = $this->compiler->compileTag('private_modifier', array(), array('modifierlist' => $modifierlist, 'value' => $output));
 | 
			
		||||
            } 
 | 
			
		||||
            if (!empty($parameter['modifierlist'])) {
 | 
			
		||||
                $output = $this->compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifierlist'], 'value' => $output));
 | 
			
		||||
            } 
 | 
			
		||||
            $this->compiler->has_output = true;
 | 
			
		||||
            $output = "<?php echo {$output};?>";
 | 
			
		||||
        } 
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,95 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Registered_Block extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of a block function
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of block function
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        if (strlen($tag) < 6 || substr($tag,-5) != 'close') {
 | 
			
		||||
            // opening tag of block plugin
 | 
			
		||||
        	// check and get attributes
 | 
			
		||||
        	$_attr = $this->_get_attributes($args); 
 | 
			
		||||
        	if ($_attr['nocache']) {
 | 
			
		||||
            	$this->compiler->tag_nocache = true;
 | 
			
		||||
        	}
 | 
			
		||||
       		unset($_attr['nocache']);
 | 
			
		||||
            // convert attributes into parameter array string
 | 
			
		||||
            $_paramsArray = array();
 | 
			
		||||
            foreach ($_attr as $_key => $_value) {
 | 
			
		||||
                if (is_int($_key)) {
 | 
			
		||||
                    $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
            	} elseif ($this->compiler->template->caching && in_array($_key,$compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag][2])) {
 | 
			
		||||
					$_value = str_replace("'","^#^",$_value);
 | 
			
		||||
                	$_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^";
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_params = 'array(' . implode(",", $_paramsArray) . ')';
 | 
			
		||||
 | 
			
		||||
            $this->_open_tag($tag, array($_params, $this->compiler->nocache)); 
 | 
			
		||||
            // maybe nocache because of nocache variables or nocache plugin
 | 
			
		||||
            $this->compiler->nocache = !$compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag][1] | $this->compiler->nocache | $this->compiler->tag_nocache;
 | 
			
		||||
            $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag][0]; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            if (!is_array($function)) {
 | 
			
		||||
                $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
 | 
			
		||||
            } else if (is_object($function[0])) {
 | 
			
		||||
                $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; \$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0][0]->{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; {$function[0]}::{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            // must endblock be nocache?
 | 
			
		||||
            if ($this->compiler->nocache) {
 | 
			
		||||
                $this->compiler->tag_nocache = true;
 | 
			
		||||
            } 
 | 
			
		||||
            $base_tag = substr($tag, 0, -5); 
 | 
			
		||||
            // closing tag of block plugin, restore nocache
 | 
			
		||||
            list($_params, $this->compiler->nocache) = $this->_close_tag($base_tag); 
 | 
			
		||||
            // This tag does create output
 | 
			
		||||
            $this->compiler->has_output = true;
 | 
			
		||||
            $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag][0]; 
 | 
			
		||||
            // compile code
 | 
			
		||||
            if (!isset($parameter['modifier_list'])) {
 | 
			
		||||
            	$mod_pre = $mod_post ='';
 | 
			
		||||
            } else {
 | 
			
		||||
            	$mod_pre = ' ob_start(); ';
 | 
			
		||||
            	$mod_post = 'echo '.$this->compiler->compileTag('private_modifier',array(),array('modifierlist'=>$parameter['modifier_list'],'value'=>'ob_get_clean()')).';';
 | 
			
		||||
            }
 | 
			
		||||
            if (!is_array($function)) {
 | 
			
		||||
                $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;".$mod_pre." echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat);".$mod_post." } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
 | 
			
		||||
            } else if (is_object($function[0])) {
 | 
			
		||||
                $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;".$mod_pre." echo \$_smarty_tpl->smarty->registered_plugins['block']['{$base_tag}'][0][0]->{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); ".$mod_post."} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;".$mod_pre." echo {$function[0]}::{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); ".$mod_post."} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $output."\n";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,67 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Registered_Function extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $optional_attributes = array('_any'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the execution of a registered function
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @param array $parameter array with compilation parameter
 | 
			
		||||
     * @param string $tag name of function
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter, $tag)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // This tag does create output
 | 
			
		||||
        $this->compiler->has_output = true;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args); 
 | 
			
		||||
        if ($_attr['nocache']) {
 | 
			
		||||
            $this->compiler->tag_nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
        unset($_attr['nocache']);
 | 
			
		||||
        // not cachable?
 | 
			
		||||
        $this->compiler->tag_nocache =  $this->compiler->tag_nocache || !$compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag][1]; 
 | 
			
		||||
        // convert attributes into parameter array string
 | 
			
		||||
        $_paramsArray = array();
 | 
			
		||||
        foreach ($_attr as $_key => $_value) {
 | 
			
		||||
            if (is_int($_key)) {
 | 
			
		||||
                $_paramsArray[] = "$_key=>$_value";
 | 
			
		||||
            } elseif ($this->compiler->template->caching && in_array($_key,$compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag][2])) {
 | 
			
		||||
				$_value = str_replace("'","^#^",$_value);
 | 
			
		||||
                $_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^";
 | 
			
		||||
            } else {
 | 
			
		||||
                $_paramsArray[] = "'$_key'=>$_value";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_params = 'array(' . implode(",", $_paramsArray) . ')'; 
 | 
			
		||||
        $function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag][0]; 
 | 
			
		||||
        // compile code
 | 
			
		||||
        if (!is_array($function)) {
 | 
			
		||||
            $output = "<?php echo {$function}({$_params},\$_smarty_tpl);?>\n";
 | 
			
		||||
        } else if (is_object($function[0])) {
 | 
			
		||||
            $output = "<?php echo \$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION]['{$tag}'][0][0]->{$function[1]}({$_params},\$_smarty_tpl);?>\n";
 | 
			
		||||
        } else {
 | 
			
		||||
            $output = "<?php echo {$function[0]}::{$function[1]}({$_params},\$_smarty_tpl);?>\n";
 | 
			
		||||
        } 
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,99 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Private_Special_Variable extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the speical $smarty variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $_index = preg_split("/\]\[/",substr($parameter, 1, strlen($parameter)-2));
 | 
			
		||||
        $compiled_ref = ' ';
 | 
			
		||||
        $variable = trim($_index[0], "'");
 | 
			
		||||
        switch ($variable) {
 | 
			
		||||
            case 'foreach':
 | 
			
		||||
                return "\$_smarty_tpl->getVariable('smarty')->value$parameter";
 | 
			
		||||
            case 'section':
 | 
			
		||||
                return "\$_smarty_tpl->getVariable('smarty')->value$parameter";
 | 
			
		||||
            case 'capture':
 | 
			
		||||
                return "Smarty::\$_smarty_vars$parameter";
 | 
			
		||||
            case 'now':
 | 
			
		||||
                return 'time()';
 | 
			
		||||
            case 'cookies':
 | 
			
		||||
                if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) {
 | 
			
		||||
                    $compiler->trigger_template_error("(secure mode) super globals not permitted");
 | 
			
		||||
                    break;
 | 
			
		||||
                } 
 | 
			
		||||
                $compiled_ref = '$_COOKIE';
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'get':
 | 
			
		||||
            case 'post':
 | 
			
		||||
            case 'env':
 | 
			
		||||
            case 'server':
 | 
			
		||||
            case 'session':
 | 
			
		||||
            case 'request':
 | 
			
		||||
                if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) {
 | 
			
		||||
                    $compiler->trigger_template_error("(secure mode) super globals not permitted");
 | 
			
		||||
                    break;
 | 
			
		||||
                } 
 | 
			
		||||
                $compiled_ref = '$_'.strtoupper($variable);
 | 
			
		||||
                break;
 | 
			
		||||
 | 
			
		||||
            case 'template':
 | 
			
		||||
                return 'basename($_smarty_tpl->getTemplateFilepath())';
 | 
			
		||||
 | 
			
		||||
            case 'current_dir':
 | 
			
		||||
                return 'dirname($_smarty_tpl->getTemplateFilepath())';
 | 
			
		||||
 | 
			
		||||
            case 'version':
 | 
			
		||||
                $_version = Smarty::SMARTY_VERSION;
 | 
			
		||||
                return "'$_version'";
 | 
			
		||||
 | 
			
		||||
            case 'const':
 | 
			
		||||
                if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_constants) {
 | 
			
		||||
                    $compiler->trigger_template_error("(secure mode) constants not permitted");
 | 
			
		||||
                    break;
 | 
			
		||||
                } 
 | 
			
		||||
                return '@' . trim($_index[1], "'");
 | 
			
		||||
 | 
			
		||||
            case 'config':
 | 
			
		||||
                return "\$_smarty_tpl->getConfigVariable($_index[1])";
 | 
			
		||||
            case 'ldelim':
 | 
			
		||||
                $_ldelim = $compiler->smarty->left_delimiter;
 | 
			
		||||
                return "'$_ldelim'";
 | 
			
		||||
 | 
			
		||||
            case 'rdelim':
 | 
			
		||||
                $_rdelim = $compiler->smarty->right_delimiter;
 | 
			
		||||
                return "'$_rdelim'";
 | 
			
		||||
 | 
			
		||||
            default:
 | 
			
		||||
                $compiler->trigger_template_error('$smarty.' . trim($_index[0], "'") . ' is invalid');
 | 
			
		||||
                break;
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset($_index[1])) {
 | 
			
		||||
            array_shift($_index);
 | 
			
		||||
            foreach ($_index as $_ind) {
 | 
			
		||||
                $compiled_ref = $compiled_ref . "[$_ind]";
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $compiled_ref;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,37 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Rdelim
 | 
			
		||||
 *
 | 
			
		||||
 * Compiles the {rdelim} tag 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Rdelim Class
 | 
			
		||||
 */ 
 | 
			
		||||
class Smarty_Internal_Compile_Rdelim extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {rdelim} tag
 | 
			
		||||
     *
 | 
			
		||||
     * This tag does output the right delimiter 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        if ($_attr['nocache'] === true) {
 | 
			
		||||
        	$this->compiler->trigger_template_error('nocache option not allowed', $this->compiler->lex->taglineno);
 | 
			
		||||
        }
 | 
			
		||||
        // this tag does not return compiled code
 | 
			
		||||
        $this->compiler->has_code = true;
 | 
			
		||||
        return $this->compiler->smarty->right_delimiter;
 | 
			
		||||
    } 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,173 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Section extends Smarty_Internal_CompileBase {
 | 
			
		||||
	// attribute definitions
 | 
			
		||||
    public $required_attributes = array('name', 'loop');
 | 
			
		||||
   	public $shorttag_order = array('name', 'loop');
 | 
			
		||||
    public $optional_attributes = array('start', 'step', 'max', 'show'); 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {section} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        $this->_open_tag('section', array('section',$this->compiler->nocache));
 | 
			
		||||
        // maybe nocache because of nocache variables
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache;
 | 
			
		||||
 | 
			
		||||
        $output = "<?php ";
 | 
			
		||||
 | 
			
		||||
        $section_name = $_attr['name'];
 | 
			
		||||
        
 | 
			
		||||
        $output .= "unset(\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]);\n";
 | 
			
		||||
        $section_props = "\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]";
 | 
			
		||||
 | 
			
		||||
        foreach ($_attr as $attr_name => $attr_value) {
 | 
			
		||||
            switch ($attr_name) {
 | 
			
		||||
                case 'loop':
 | 
			
		||||
                    $output .= "{$section_props}['loop'] = is_array(\$_loop=$attr_value) ? count(\$_loop) : max(0, (int)\$_loop); unset(\$_loop);\n";
 | 
			
		||||
                    break;
 | 
			
		||||
 | 
			
		||||
                case 'show':
 | 
			
		||||
                    if (is_bool($attr_value))
 | 
			
		||||
                        $show_attr_value = $attr_value ? 'true' : 'false';
 | 
			
		||||
                    else
 | 
			
		||||
                        $show_attr_value = "(bool)$attr_value";
 | 
			
		||||
                    $output .= "{$section_props}['show'] = $show_attr_value;\n";
 | 
			
		||||
                    break;
 | 
			
		||||
 | 
			
		||||
                case 'name':
 | 
			
		||||
                    $output .= "{$section_props}['$attr_name'] = $attr_value;\n";
 | 
			
		||||
                    break;
 | 
			
		||||
 | 
			
		||||
                case 'max':
 | 
			
		||||
                case 'start':
 | 
			
		||||
                    $output .= "{$section_props}['$attr_name'] = (int)$attr_value;\n";
 | 
			
		||||
                    break;
 | 
			
		||||
 | 
			
		||||
                case 'step':
 | 
			
		||||
                    $output .= "{$section_props}['$attr_name'] = ((int)$attr_value) == 0 ? 1 : (int)$attr_value;\n";
 | 
			
		||||
                    break;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if (!isset($_attr['show']))
 | 
			
		||||
            $output .= "{$section_props}['show'] = true;\n";
 | 
			
		||||
 | 
			
		||||
        if (!isset($_attr['loop']))
 | 
			
		||||
            $output .= "{$section_props}['loop'] = 1;\n";
 | 
			
		||||
 | 
			
		||||
        if (!isset($_attr['max']))
 | 
			
		||||
            $output .= "{$section_props}['max'] = {$section_props}['loop'];\n";
 | 
			
		||||
        else
 | 
			
		||||
            $output .= "if ({$section_props}['max'] < 0)\n" . "    {$section_props}['max'] = {$section_props}['loop'];\n";
 | 
			
		||||
 | 
			
		||||
        if (!isset($_attr['step']))
 | 
			
		||||
            $output .= "{$section_props}['step'] = 1;\n";
 | 
			
		||||
 | 
			
		||||
        if (!isset($_attr['start']))
 | 
			
		||||
            $output .= "{$section_props}['start'] = {$section_props}['step'] > 0 ? 0 : {$section_props}['loop']-1;\n";
 | 
			
		||||
        else {
 | 
			
		||||
            $output .= "if ({$section_props}['start'] < 0)\n" . "    {$section_props}['start'] = max({$section_props}['step'] > 0 ? 0 : -1, {$section_props}['loop'] + {$section_props}['start']);\n" . "else\n" . "    {$section_props}['start'] = min({$section_props}['start'], {$section_props}['step'] > 0 ? {$section_props}['loop'] : {$section_props}['loop']-1);\n";
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        $output .= "if ({$section_props}['show']) {\n";
 | 
			
		||||
        if (!isset($_attr['start']) && !isset($_attr['step']) && !isset($_attr['max'])) {
 | 
			
		||||
            $output .= "    {$section_props}['total'] = {$section_props}['loop'];\n";
 | 
			
		||||
        } else {
 | 
			
		||||
            $output .= "    {$section_props}['total'] = min(ceil(({$section_props}['step'] > 0 ? {$section_props}['loop'] - {$section_props}['start'] : {$section_props}['start']+1)/abs({$section_props}['step'])), {$section_props}['max']);\n";
 | 
			
		||||
        } 
 | 
			
		||||
        $output .= "    if ({$section_props}['total'] == 0)\n" . "        {$section_props}['show'] = false;\n" . "} else\n" . "    {$section_props}['total'] = 0;\n";
 | 
			
		||||
 | 
			
		||||
        $output .= "if ({$section_props}['show']):\n";
 | 
			
		||||
        $output .= "
 | 
			
		||||
            for ({$section_props}['index'] = {$section_props}['start'], {$section_props}['iteration'] = 1;
 | 
			
		||||
                 {$section_props}['iteration'] <= {$section_props}['total'];
 | 
			
		||||
                 {$section_props}['index'] += {$section_props}['step'], {$section_props}['iteration']++):\n";
 | 
			
		||||
        $output .= "{$section_props}['rownum'] = {$section_props}['iteration'];\n";
 | 
			
		||||
        $output .= "{$section_props}['index_prev'] = {$section_props}['index'] - {$section_props}['step'];\n";
 | 
			
		||||
        $output .= "{$section_props}['index_next'] = {$section_props}['index'] + {$section_props}['step'];\n";
 | 
			
		||||
        $output .= "{$section_props}['first']      = ({$section_props}['iteration'] == 1);\n";
 | 
			
		||||
        $output .= "{$section_props}['last']       = ({$section_props}['iteration'] == {$section_props}['total']);\n";
 | 
			
		||||
 | 
			
		||||
        $output .= "?>";
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Compile Sectionelse Class
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Compile_Sectionelse extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {sectionelse} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $nocache) = $this->_close_tag(array('section'));
 | 
			
		||||
        $this->_open_tag('sectionelse',array('sectionelse', $nocache));
 | 
			
		||||
 | 
			
		||||
        return "<?php endfor; else: ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Sectionclose Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Compile_Sectionclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {/section} tag
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $args array with attributes from parser
 | 
			
		||||
     * @param object $compiler compiler object
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
 | 
			
		||||
        // must endblock be nocache?
 | 
			
		||||
        if ($this->compiler->nocache) {
 | 
			
		||||
                 $this->compiler->tag_nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        list($_open_tag, $this->compiler->nocache) = $this->_close_tag(array('section', 'sectionelse'));
 | 
			
		||||
 | 
			
		||||
        if ($_open_tag == 'sectionelse')
 | 
			
		||||
            return "<?php endif; ?>";
 | 
			
		||||
        else
 | 
			
		||||
            return "<?php endfor; endif; ?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,82 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Compile While
 | 
			
		||||
* 
 | 
			
		||||
* Compiles the {while} tag
 | 
			
		||||
* 
 | 
			
		||||
* @package Smarty
 | 
			
		||||
* @subpackage Compiler
 | 
			
		||||
* @author Uwe Tews 
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Compile While Class
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Compile_While extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
    * Compiles code for the {while} tag
 | 
			
		||||
    * 
 | 
			
		||||
    * @param array $args array with attributes from parser
 | 
			
		||||
    * @param object $compiler compiler object
 | 
			
		||||
    * @param array $parameter array with compilation parameter
 | 
			
		||||
    * @return string compiled code
 | 
			
		||||
    */
 | 
			
		||||
    public function compile($args, $compiler, $parameter)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
        // check and get attributes
 | 
			
		||||
        $_attr = $this->_get_attributes($args);
 | 
			
		||||
        $this->_open_tag('while', $this->compiler->nocache);
 | 
			
		||||
 | 
			
		||||
        // maybe nocache because of nocache variables
 | 
			
		||||
        $this->compiler->nocache = $this->compiler->nocache | $this->compiler->tag_nocache;
 | 
			
		||||
        if (is_array($parameter['if condition'])) {
 | 
			
		||||
        	if ($this->compiler->nocache) {
 | 
			
		||||
        		$_nocache = ',true';
 | 
			
		||||
            	// create nocache var to make it know for further compiling
 | 
			
		||||
            	if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            		$this->compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
            	} else {
 | 
			
		||||
            		$this->compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
 | 
			
		||||
            	}
 | 
			
		||||
        	} else {
 | 
			
		||||
        		$_nocache = '';
 | 
			
		||||
        	}
 | 
			
		||||
            if (is_array($parameter['if condition']['var'])) {
 | 
			
		||||
            	$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]) || !is_array(\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value)) \$_smarty_tpl->createLocalArrayVariable(".$parameter['if condition']['var']['var']."$_nocache);\n";
 | 
			
		||||
	            $_output .= "while (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']['var']."]->value".$parameter['if condition']['var']['smarty_internal_index']." = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
            } else {
 | 
			
		||||
	            $_output = "<?php \$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."] = new Smarty_Variable(\$_smarty_tpl->getVariable(".$parameter['if condition']['var'].",null,true,false)->value{$_nocache});";            
 | 
			
		||||
	            $_output .= "while (\$_smarty_tpl->tpl_vars[".$parameter['if condition']['var']."]->value = ".$parameter['if condition']['value']."){?>";
 | 
			
		||||
	        }
 | 
			
		||||
            return $_output;
 | 
			
		||||
        } else {
 | 
			
		||||
            return "<?php while ({$parameter['if condition']}){?>";
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Compile Whileclose Class
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Compile_Whileclose extends Smarty_Internal_CompileBase {
 | 
			
		||||
    /**
 | 
			
		||||
    * Compiles code for the {/while} tag
 | 
			
		||||
    * 
 | 
			
		||||
    * @param array $args array with attributes from parser
 | 
			
		||||
    * @param object $compiler compiler object
 | 
			
		||||
    * @return string compiled code
 | 
			
		||||
    */
 | 
			
		||||
    public function compile($args, $compiler)
 | 
			
		||||
    {
 | 
			
		||||
        $this->compiler = $compiler; 
 | 
			
		||||
        // must endblock be nocache?
 | 
			
		||||
        if ($this->compiler->nocache) {
 | 
			
		||||
                 $this->compiler->tag_nocache = true;
 | 
			
		||||
        }
 | 
			
		||||
        $this->compiler->nocache = $this->_close_tag(array('while'));
 | 
			
		||||
        return "<?php }?>";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										150
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								site/stackreach/libs/sysplugins/smarty_internal_compilebase.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,150 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin CompileBase
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This class does extend all internal compile plugins
 | 
			
		||||
 */
 | 
			
		||||
// abstract class Smarty_Internal_CompileBase implements TagCompilerInterface
 | 
			
		||||
class Smarty_Internal_CompileBase {
 | 
			
		||||
	public $required_attributes = array();
 | 
			
		||||
    public $optional_attributes = array();
 | 
			
		||||
    public $shorttag_order = array();
 | 
			
		||||
    public $option_flags = array('nocache');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * This function checks if the attributes passed are valid
 | 
			
		||||
     * 
 | 
			
		||||
     * The attributes passed for the tag to compile are checked against the list of required and 
 | 
			
		||||
     * optional attributes. Required attributes must be present. Optional attributes are check against
 | 
			
		||||
     * against the corresponding list. The keyword '_any' specifies that any attribute will be accepted 
 | 
			
		||||
     * as valid
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $attributes attributes applied to the tag
 | 
			
		||||
     * @return array of mapped attributes for further processing
 | 
			
		||||
     */
 | 
			
		||||
    function _get_attributes ($attributes)
 | 
			
		||||
    {
 | 
			
		||||
        $_indexed_attr = array(); 
 | 
			
		||||
        // loop over attributes
 | 
			
		||||
        foreach ($attributes as $key => $mixed) {
 | 
			
		||||
            // shorthand ?
 | 
			
		||||
            if (!is_array($mixed)) {
 | 
			
		||||
                // option flag ?
 | 
			
		||||
                if (in_array(trim($mixed, '\'"'), $this->option_flags)) {
 | 
			
		||||
                    $_indexed_attr[trim($mixed, '\'"')] = true; 
 | 
			
		||||
                    // shorthand attribute ?
 | 
			
		||||
                } else if (isset($this->shorttag_order[$key])) {
 | 
			
		||||
                    $_indexed_attr[$this->shorttag_order[$key]] = $mixed;
 | 
			
		||||
                } else {
 | 
			
		||||
                    // too many shorthands
 | 
			
		||||
                    $this->compiler->trigger_template_error('too many shorthand attributes', $this->compiler->lex->taglineno);
 | 
			
		||||
                } 
 | 
			
		||||
                // named attribute
 | 
			
		||||
            } else {
 | 
			
		||||
                $kv = each($mixed); 
 | 
			
		||||
                // option flag?
 | 
			
		||||
                if (in_array($kv['key'], $this->option_flags)) {
 | 
			
		||||
                    if (is_bool($kv['value'])) {
 | 
			
		||||
                        $_indexed_attr[$kv['key']] = $kv['value'];
 | 
			
		||||
                    } else if (is_string($kv['value']) && in_array(trim($kv['value'], '\'"'), array('true', 'false'))) {
 | 
			
		||||
                        if (trim($kv['value']) == 'true') {
 | 
			
		||||
                            $_indexed_attr[$kv['key']] = true;
 | 
			
		||||
                        } else {
 | 
			
		||||
                            $_indexed_attr[$kv['key']] = false;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } else if (is_numeric($kv['value']) && in_array($kv['value'], array(0, 1))) {
 | 
			
		||||
                        if ($kv['value'] == 1) {
 | 
			
		||||
                            $_indexed_attr[$kv['key']] = true;
 | 
			
		||||
                        } else {
 | 
			
		||||
                            $_indexed_attr[$kv['key']] = false;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $this->compiler->trigger_template_error("illegal value of option flag \"{$kv['key']}\"", $this->compiler->lex->taglineno);
 | 
			
		||||
                    } 
 | 
			
		||||
                    // must be named attribute
 | 
			
		||||
                } else {
 | 
			
		||||
                	reset($mixed);
 | 
			
		||||
                    $_indexed_attr[key($mixed)] = $mixed[key($mixed)];
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // check if all required attributes present
 | 
			
		||||
        foreach ($this->required_attributes as $attr) {
 | 
			
		||||
            if (!array_key_exists($attr, $_indexed_attr)) {
 | 
			
		||||
                $this->compiler->trigger_template_error("missing \"" . $attr . "\" attribute", $this->compiler->lex->taglineno);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // check for unallowed attributes
 | 
			
		||||
        if ($this->optional_attributes != array('_any')) {
 | 
			
		||||
            $tmp_array = array_merge($this->required_attributes, $this->optional_attributes, $this->option_flags);
 | 
			
		||||
            foreach ($_indexed_attr as $key => $dummy) {
 | 
			
		||||
                if (!in_array($key, $tmp_array) && $key !== 0) {
 | 
			
		||||
                    $this->compiler->trigger_template_error("unexpected \"" . $key . "\" attribute", $this->compiler->lex->taglineno);
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // default 'false' for all option flags not set
 | 
			
		||||
        foreach ($this->option_flags as $flag) {
 | 
			
		||||
            if (!isset($_indexed_attr[$flag])) {
 | 
			
		||||
                $_indexed_attr[$flag] = false;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        return $_indexed_attr;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Push opening tag name on stack
 | 
			
		||||
     * 
 | 
			
		||||
     * Optionally additional data can be saved on stack
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $open_tag the opening tag's name
 | 
			
		||||
     * @param anytype $data optional data which shall be saved on stack
 | 
			
		||||
     */
 | 
			
		||||
    function _open_tag($open_tag, $data = null)
 | 
			
		||||
    {
 | 
			
		||||
        array_push($this->compiler->_tag_stack, array($open_tag, $data));
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Pop closing tag
 | 
			
		||||
     * 
 | 
			
		||||
     * Raise an error if this stack-top doesn't match with expected opening tags
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $ |string $expected_tag the expected opening tag names
 | 
			
		||||
     * @return anytype the opening tag's name or saved data
 | 
			
		||||
     */
 | 
			
		||||
    function _close_tag($expected_tag)
 | 
			
		||||
    {
 | 
			
		||||
        if (count($this->compiler->_tag_stack) > 0) {
 | 
			
		||||
            // get stacked info
 | 
			
		||||
            list($_open_tag, $_data) = array_pop($this->compiler->_tag_stack); 
 | 
			
		||||
            // open tag must match with the expected ones
 | 
			
		||||
            if (in_array($_open_tag, (array)$expected_tag)) {
 | 
			
		||||
                if (is_null($_data)) {
 | 
			
		||||
                    // return opening tag
 | 
			
		||||
                    return $_open_tag;
 | 
			
		||||
                } else {
 | 
			
		||||
                    // return restored data
 | 
			
		||||
                    return $_data;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            // wrong nesting of tags
 | 
			
		||||
            $this->compiler->trigger_template_error("unclosed {" . $_open_tag . "} tag");
 | 
			
		||||
            return;
 | 
			
		||||
        } 
 | 
			
		||||
        // wrong nesting of tags
 | 
			
		||||
        $this->compiler->trigger_template_error("unexpected closing tag", $this->compiler->lex->taglineno);
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										288
									
								
								site/stackreach/libs/sysplugins/smarty_internal_config.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										288
									
								
								site/stackreach/libs/sysplugins/smarty_internal_config.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,288 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Config
 | 
			
		||||
 * 
 | 
			
		||||
 * Main class for config variables
 | 
			
		||||
 * 
 | 
			
		||||
 * @ignore 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Config
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Config {
 | 
			
		||||
    static $config_objects = array();
 | 
			
		||||
 | 
			
		||||
    public function __construct($config_resource, $smarty, $data = null)
 | 
			
		||||
    {
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
        $this->config_resource = $config_resource;
 | 
			
		||||
        $this->config_resource_type = null;
 | 
			
		||||
        $this->config_resource_name = null;
 | 
			
		||||
        $this->config_filepath = null;
 | 
			
		||||
        $this->config_timestamp = null;
 | 
			
		||||
        $this->config_source = null;
 | 
			
		||||
        $this->compiled_config = null;
 | 
			
		||||
        $this->compiled_filepath = null;
 | 
			
		||||
        $this->compiled_timestamp = null;
 | 
			
		||||
        $this->mustCompile = null;
 | 
			
		||||
        $this->compiler_object = null; 
 | 
			
		||||
        // parse config resource name
 | 
			
		||||
        if (!$this->parseConfigResourceName ($config_resource)) {
 | 
			
		||||
            throw new SmartyException ("Unable to parse config resource '{$config_resource}'");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function getConfigFilepath ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->config_filepath === null ?
 | 
			
		||||
        $this->config_filepath = $this->buildConfigFilepath() :
 | 
			
		||||
        $this->config_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function getTimestamp ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->config_timestamp === null ?
 | 
			
		||||
        $this->config_timestamp = filemtime($this->getConfigFilepath()) :
 | 
			
		||||
        $this->config_timestamp;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    private function parseConfigResourceName($config_resource)
 | 
			
		||||
    {
 | 
			
		||||
        if (empty($config_resource))
 | 
			
		||||
            return false;
 | 
			
		||||
        if (strpos($config_resource, ':') === false) {
 | 
			
		||||
            // no resource given, use default
 | 
			
		||||
            $this->config_resource_type = $this->smarty->default_config_type;
 | 
			
		||||
            $this->config_resource_name = $config_resource;
 | 
			
		||||
        } else {
 | 
			
		||||
            // get type and name from path
 | 
			
		||||
            list($this->config_resource_type, $this->config_resource_name) = explode(':', $config_resource, 2);
 | 
			
		||||
            if (strlen($this->config_resource_type) == 1) {
 | 
			
		||||
                // 1 char is not resource type, but part of filepath
 | 
			
		||||
                $this->config_resource_type = $this->smarty->default_config_type;
 | 
			
		||||
                $this->config_resource_name = $config_resource;
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->config_resource_type = strtolower($this->config_resource_type);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /*
 | 
			
		||||
     * get system filepath to config
 | 
			
		||||
     */
 | 
			
		||||
    public function buildConfigFilepath ()
 | 
			
		||||
    {
 | 
			
		||||
        foreach((array)$this->smarty->config_dir as $_config_dir) {
 | 
			
		||||
            if (strpos('/\\', substr($_config_dir, -1)) === false) {
 | 
			
		||||
                $_config_dir .= DS;
 | 
			
		||||
            } 
 | 
			
		||||
 | 
			
		||||
            $_filepath = $_config_dir . $this->config_resource_name;
 | 
			
		||||
            if (file_exists($_filepath))
 | 
			
		||||
                return $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        // check for absolute path
 | 
			
		||||
        if (file_exists($this->config_resource_name))
 | 
			
		||||
            return $this->config_resource_name; 
 | 
			
		||||
        // no tpl file found
 | 
			
		||||
        throw new SmartyException("Unable to load config file \"{$this->config_resource_name}\"");
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Read config file source
 | 
			
		||||
     * 
 | 
			
		||||
     * @return string content of source file
 | 
			
		||||
     */
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the template source code
 | 
			
		||||
     * 
 | 
			
		||||
     * The template source is being read by the actual resource handler
 | 
			
		||||
     * 
 | 
			
		||||
     * @return string the template source
 | 
			
		||||
     */
 | 
			
		||||
    public function getConfigSource ()
 | 
			
		||||
    {
 | 
			
		||||
        if ($this->config_source === null) {
 | 
			
		||||
            if ($this->readConfigSource($this) === false) {
 | 
			
		||||
                throw new SmartyException("Unable to load config file \"{$this->config_resource_name}\"");
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $this->config_source;
 | 
			
		||||
    } 
 | 
			
		||||
    public function readConfigSource()
 | 
			
		||||
    { 
 | 
			
		||||
        // read source file
 | 
			
		||||
        if (file_exists($this->getConfigFilepath())) {
 | 
			
		||||
            $this->config_source = file_get_contents($this->getConfigFilepath());
 | 
			
		||||
            return true;
 | 
			
		||||
        } else {
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the compiled  filepath
 | 
			
		||||
     * 
 | 
			
		||||
     * @return string the compiled filepath
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->compiled_filepath === null ?
 | 
			
		||||
        ($this->compiled_filepath = $this->buildCompiledFilepath()) :
 | 
			
		||||
        $this->compiled_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
    public function buildCompiledFilepath()
 | 
			
		||||
    {
 | 
			
		||||
        $_compile_id = isset($this->smarty->compile_id) ? preg_replace('![^\w\|]+!', '_', $this->smarty->compile_id) : null;
 | 
			
		||||
        $_flag = (int)$this->smarty->config_read_hidden + (int)$this->smarty->config_booleanize * 2 +
 | 
			
		||||
        (int)$this->smarty->config_overwrite * 4;
 | 
			
		||||
        $_filepath = sha1($this->config_resource_name . $_flag); 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($this->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $this->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir = $this->smarty->compile_dir;
 | 
			
		||||
        if (substr($_compile_dir, -1) != DS) {
 | 
			
		||||
            $_compile_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_compile_dir . $_filepath . '.' . basename($this->config_resource_name) . '.config' . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the timpestamp of the compiled file
 | 
			
		||||
     * 
 | 
			
		||||
     * @return integer the file timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledTimestamp ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->compiled_timestamp === null ?
 | 
			
		||||
        ($this->compiled_timestamp = (file_exists($this->getCompiledFilepath())) ? filemtime($this->getCompiledFilepath()) : false) :
 | 
			
		||||
        $this->compiled_timestamp;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns if the current config file must be compiled 
 | 
			
		||||
     * 
 | 
			
		||||
     * It does compare the timestamps of config source and the compiled config and checks the force compile configuration
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true if the file must be compiled
 | 
			
		||||
     */
 | 
			
		||||
    public function mustCompile ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->mustCompile === null ?
 | 
			
		||||
        $this->mustCompile = ($this->smarty->force_compile || $this->getCompiledTimestamp () === false || $this->smarty->compile_check && $this->getCompiledTimestamp () < $this->getTimestamp ()):
 | 
			
		||||
        $this->mustCompile;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the compiled config file 
 | 
			
		||||
     * 
 | 
			
		||||
     * It checks if the config file must be compiled or just read the compiled version
 | 
			
		||||
     * 
 | 
			
		||||
     * @return string the compiled config file
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledConfig ()
 | 
			
		||||
    {
 | 
			
		||||
        if ($this->compiled_config === null) {
 | 
			
		||||
            // see if template needs compiling.
 | 
			
		||||
            if ($this->mustCompile()) {
 | 
			
		||||
                $this->compileConfigSource();
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->compiled_config = file_get_contents($this->getCompiledFilepath());
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $this->compiled_config;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles the config files
 | 
			
		||||
     */
 | 
			
		||||
    public function compileConfigSource ()
 | 
			
		||||
    { 
 | 
			
		||||
        // compile template
 | 
			
		||||
        if (!is_object($this->compiler_object)) {
 | 
			
		||||
            // load compiler
 | 
			
		||||
            $this->compiler_object = new Smarty_Internal_Config_File_Compiler($this->smarty);
 | 
			
		||||
        } 
 | 
			
		||||
        // compile locking
 | 
			
		||||
        if ($this->smarty->compile_locking) {
 | 
			
		||||
            if ($saved_timestamp = $this->getCompiledTimestamp()) {
 | 
			
		||||
                touch($this->getCompiledFilepath());
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // call compiler
 | 
			
		||||
        try {
 | 
			
		||||
            $this->compiler_object->compileSource($this);
 | 
			
		||||
        } 
 | 
			
		||||
        catch (Exception $e) {
 | 
			
		||||
            // restore old timestamp in case of error
 | 
			
		||||
            if ($this->smarty->compile_locking && $saved_timestamp) {
 | 
			
		||||
                touch($this->getCompiledFilepath(), $saved_timestamp);
 | 
			
		||||
            } 
 | 
			
		||||
            throw $e;
 | 
			
		||||
        } 
 | 
			
		||||
        // compiling succeded
 | 
			
		||||
        // write compiled template
 | 
			
		||||
        Smarty_Internal_Write_File::writeFile($this->getCompiledFilepath(), $this->getCompiledConfig(), $this->smarty);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /*
 | 
			
		||||
     * load config variables
 | 
			
		||||
    *
 | 
			
		||||
    * @param mixed $sections array of section names, single section or null
 | 
			
		||||
    * @param object $scope global,parent or local
 | 
			
		||||
    */
 | 
			
		||||
    public function loadConfigVars ($sections = null, $scope = 'local')
 | 
			
		||||
    {
 | 
			
		||||
        if ($this->data instanceof Smarty_Internal_Template) {
 | 
			
		||||
            $this->data->properties['file_dependency'][sha1($this->getConfigFilepath())] = array($this->getConfigFilepath(), $this->getTimestamp(),'file');
 | 
			
		||||
        } 
 | 
			
		||||
        if ($this->mustCompile()) {
 | 
			
		||||
            $this->compileConfigSource();
 | 
			
		||||
        }
 | 
			
		||||
        // pointer to scope
 | 
			
		||||
        if ($scope == 'local') {
 | 
			
		||||
        	$scope_ptr = $this->data;
 | 
			
		||||
        } elseif ($scope == 'parent') {
 | 
			
		||||
        	if (isset($this->data->parent)) {
 | 
			
		||||
        		$scope_ptr = $this->data->parent;
 | 
			
		||||
        	} else {
 | 
			
		||||
        		$scope_ptr = $this->data;
 | 
			
		||||
        	}        		
 | 
			
		||||
        } elseif ($scope == 'root' || $scope == 'global') {
 | 
			
		||||
        	$scope_ptr = $this->data;
 | 
			
		||||
        	while (isset($scope_ptr->parent)) {
 | 
			
		||||
        		$scope_ptr = $scope_ptr->parent;
 | 
			
		||||
        	} 
 | 
			
		||||
        }
 | 
			
		||||
        $_config_vars = array();
 | 
			
		||||
        include($this->getCompiledFilepath ());
 | 
			
		||||
        // copy global config vars
 | 
			
		||||
        foreach ($_config_vars['vars'] as $variable => $value) {
 | 
			
		||||
            if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) {
 | 
			
		||||
                $scope_ptr->config_vars[$variable] = $value;
 | 
			
		||||
            } else {
 | 
			
		||||
                $scope_ptr->config_vars[$variable] = array_merge((array)$scope_ptr->config_vars[$variable], (array)$value);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // scan sections
 | 
			
		||||
        foreach ($_config_vars['sections'] as $this_section => $dummy) {
 | 
			
		||||
            if ($sections == null || in_array($this_section, (array)$sections)) {
 | 
			
		||||
                foreach ($_config_vars['sections'][$this_section]['vars'] as $variable => $value) {
 | 
			
		||||
                    if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) {
 | 
			
		||||
                        $scope_ptr->config_vars[$variable] = $value;
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $scope_ptr->config_vars[$variable] = array_merge((array)$scope_ptr->config_vars[$variable], (array)$value);
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        }
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,106 @@
 | 
			
		||||
<?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
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Config_File_Compiler {
 | 
			
		||||
    /**
 | 
			
		||||
     * Initialize compiler
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty; 
 | 
			
		||||
        // get required plugins
 | 
			
		||||
        $this->smarty->loadPlugin('Smarty_Internal_Configfilelexer');
 | 
			
		||||
		$this->smarty->loadPlugin('Smarty_Internal_Configfileparser');
 | 
			
		||||
        $this->config_data['sections'] = array();
 | 
			
		||||
        $this->config_data['vars'] = array();
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Methode to compile a Smarty template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param  $template template object to compile
 | 
			
		||||
     * @return bool true if compiling succeeded, false if it failed
 | 
			
		||||
     */
 | 
			
		||||
    public function compileSource($config)
 | 
			
		||||
    {
 | 
			
		||||
        /* here is where the compiling takes place. Smarty
 | 
			
		||||
       tags in the templates are replaces with PHP code,
 | 
			
		||||
       then written to compiled files. */
 | 
			
		||||
        $this->config = $config; 
 | 
			
		||||
        // get config file source
 | 
			
		||||
        $_content = $config->getConfigSource() . "\n"; 
 | 
			
		||||
        // on empty template just return
 | 
			
		||||
        if ($_content == '') {
 | 
			
		||||
            return true;
 | 
			
		||||
        } 
 | 
			
		||||
        // init the lexer/parser to compile the config file
 | 
			
		||||
        $lex = new Smarty_Internal_Configfilelexer($_content, $this->smarty);
 | 
			
		||||
        $parser = new Smarty_Internal_Configfileparser($lex, $this);
 | 
			
		||||
        if (isset($this->smarty->_parserdebug)) $parser->PrintTrace(); 
 | 
			
		||||
        // get tokens from lexer and parse them
 | 
			
		||||
        while ($lex->yylex()) {
 | 
			
		||||
            if (isset($this->smarty->_parserdebug)) echo "<br>Parsing  {$parser->yyTokenName[$lex->token]} Token {$lex->value} Line {$lex->line} \n";
 | 
			
		||||
            $parser->doParse($lex->token, $lex->value);
 | 
			
		||||
        } 
 | 
			
		||||
        // finish parsing process
 | 
			
		||||
        $parser->doParse(0, 0);
 | 
			
		||||
        $config->compiled_config = '<?php $_config_vars = ' . var_export($this->config_data, true) . '; ?>';
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * display compiler error messages without dying
 | 
			
		||||
     * 
 | 
			
		||||
     * If parameter $args is empty it is a parser detected syntax error.
 | 
			
		||||
     * In this case the parser is called to obtain information about exspected tokens.
 | 
			
		||||
     * 
 | 
			
		||||
     * If parameter $args contains a string this is used as error message
 | 
			
		||||
     * 
 | 
			
		||||
     * @todo output exact position of parse error in source line
 | 
			
		||||
     * @param  $args string individual error message or null
 | 
			
		||||
     */
 | 
			
		||||
    public function trigger_config_file_error($args = null)
 | 
			
		||||
    {
 | 
			
		||||
        $this->lex = Smarty_Internal_Configfilelexer::instance();
 | 
			
		||||
        $this->parser = Smarty_Internal_Configfileparser::instance(); 
 | 
			
		||||
        // get template source line which has error
 | 
			
		||||
        $line = $this->lex->line;
 | 
			
		||||
        if (isset($args)) {
 | 
			
		||||
            // $line--;
 | 
			
		||||
        } 
 | 
			
		||||
        $match = preg_split("/\n/", $this->lex->data);
 | 
			
		||||
        $error_text = "Syntax error in config file '{$this->config->getConfigFilepath()}' on line {$line} '{$match[$line-1]}' ";
 | 
			
		||||
        if (isset($args)) {
 | 
			
		||||
            // individual error message
 | 
			
		||||
            $error_text .= $args;
 | 
			
		||||
        } else {
 | 
			
		||||
            // exspected token from parser
 | 
			
		||||
            foreach ($this->parser->yy_get_expected_tokens($this->parser->yymajor) as $token) {
 | 
			
		||||
                $exp_token = $this->parser->yyTokenName[$token];
 | 
			
		||||
                if (isset($this->lex->smarty_token_names[$exp_token])) {
 | 
			
		||||
                    // token type from lexer
 | 
			
		||||
                    $expect[] = '"' . $this->lex->smarty_token_names[$exp_token] . '"';
 | 
			
		||||
                } else {
 | 
			
		||||
                    // otherwise internal token name
 | 
			
		||||
                    $expect[] = $this->parser->yyTokenName[$token];
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            // output parser error message
 | 
			
		||||
            $error_text .= ' - Unexpected "' . $this->lex->value . '", expected one of: ' . implode(' , ', $expect);
 | 
			
		||||
        } 
 | 
			
		||||
        throw new SmartyCompilerException($error_text);
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,526 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Configfilelexer
 | 
			
		||||
*
 | 
			
		||||
* This is the lexer to break the config file source into tokens 
 | 
			
		||||
* @package Smarty
 | 
			
		||||
* @subpackage Config
 | 
			
		||||
* @author Uwe Tews 
 | 
			
		||||
*/
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Configfilelexer
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Configfilelexer
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
    public $data;
 | 
			
		||||
    public $counter;
 | 
			
		||||
    public $token;
 | 
			
		||||
    public $value;
 | 
			
		||||
    public $node;
 | 
			
		||||
    public $line;
 | 
			
		||||
    private $state = 1;
 | 
			
		||||
    public $smarty_token_names = array (		// Text for parser error messages
 | 
			
		||||
   				);
 | 
			
		||||
    				
 | 
			
		||||
    				
 | 
			
		||||
    function __construct($data, $smarty)
 | 
			
		||||
    {
 | 
			
		||||
        // set instance object
 | 
			
		||||
        self::instance($this); 
 | 
			
		||||
        $this->data = $data . "\n"; //now all lines are \n-terminated
 | 
			
		||||
        $this->counter = 0;
 | 
			
		||||
        $this->line = 1;
 | 
			
		||||
        $this->smarty = $smarty; 
 | 
			
		||||
     }
 | 
			
		||||
    public static function &instance($new_instance = null)
 | 
			
		||||
    {
 | 
			
		||||
        static $instance = null;
 | 
			
		||||
        if (isset($new_instance) && is_object($new_instance))
 | 
			
		||||
            $instance = $new_instance;
 | 
			
		||||
        return $instance;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    private $_yy_state = 1;
 | 
			
		||||
    private $_yy_stack = array();
 | 
			
		||||
 | 
			
		||||
    function yylex()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->{'yylex' . $this->_yy_state}();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yypushstate($state)
 | 
			
		||||
    {
 | 
			
		||||
        array_push($this->_yy_stack, $this->_yy_state);
 | 
			
		||||
        $this->_yy_state = $state;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yypopstate()
 | 
			
		||||
    {
 | 
			
		||||
        $this->_yy_state = array_pop($this->_yy_stack);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yybegin($state)
 | 
			
		||||
    {
 | 
			
		||||
        $this->_yy_state = $state;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    function yylex1()
 | 
			
		||||
    {
 | 
			
		||||
        $tokenMap = array (
 | 
			
		||||
              1 => 0,
 | 
			
		||||
              2 => 0,
 | 
			
		||||
              3 => 0,
 | 
			
		||||
              4 => 0,
 | 
			
		||||
              5 => 0,
 | 
			
		||||
              6 => 0,
 | 
			
		||||
              7 => 0,
 | 
			
		||||
            );
 | 
			
		||||
        if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
            return false; // end of input
 | 
			
		||||
        }
 | 
			
		||||
        $yy_global_pattern = "/^(#)|^(\\[)|^(\\])|^(=)|^([ \t\r]+)|^(\n)|^([0-9]*[a-zA-Z_]\\w*)/iS";
 | 
			
		||||
 | 
			
		||||
        do {
 | 
			
		||||
            if (preg_match($yy_global_pattern, substr($this->data, $this->counter), $yymatches)) {
 | 
			
		||||
                $yysubmatches = $yymatches;
 | 
			
		||||
                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns
 | 
			
		||||
                if (!count($yymatches)) {
 | 
			
		||||
                    throw new Exception('Error: lexing failed because a rule matched' .
 | 
			
		||||
                        'an empty string.  Input "' . substr($this->data,
 | 
			
		||||
                        $this->counter, 5) . '... state START');
 | 
			
		||||
                }
 | 
			
		||||
                next($yymatches); // skip global match
 | 
			
		||||
                $this->token = key($yymatches); // token number
 | 
			
		||||
                if ($tokenMap[$this->token]) {
 | 
			
		||||
                    // extract sub-patterns for passing to lex function
 | 
			
		||||
                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,
 | 
			
		||||
                        $tokenMap[$this->token]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yysubmatches = array();
 | 
			
		||||
                }
 | 
			
		||||
                $this->value = current($yymatches); // token value
 | 
			
		||||
                $r = $this->{'yy_r1_' . $this->token}($yysubmatches);
 | 
			
		||||
                if ($r === null) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    // accept this token
 | 
			
		||||
                    return true;
 | 
			
		||||
                } elseif ($r === true) {
 | 
			
		||||
                    // we have changed state
 | 
			
		||||
                    // process this token in the new state
 | 
			
		||||
                    return $this->yylex();
 | 
			
		||||
                } elseif ($r === false) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
                        return false; // end of input
 | 
			
		||||
                    }
 | 
			
		||||
                    // skip this token
 | 
			
		||||
                    continue;
 | 
			
		||||
                }            } else {
 | 
			
		||||
                throw new Exception('Unexpected input at line' . $this->line .
 | 
			
		||||
                    ': ' . $this->data[$this->counter]);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
 | 
			
		||||
    } // end function
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    const START = 1;
 | 
			
		||||
    function yy_r1_1($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_COMMENTSTART;
 | 
			
		||||
    $this->yypushstate(self::COMMENT);
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_2($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_OPENB;
 | 
			
		||||
    $this->yypushstate(self::SECTION);
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_3($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_CLOSEB;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_4($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_EQUAL;
 | 
			
		||||
    $this->yypushstate(self::VALUE);
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_5($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    return false;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_6($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r1_7($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_ID;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    function yylex2()
 | 
			
		||||
    {
 | 
			
		||||
        $tokenMap = array (
 | 
			
		||||
              1 => 0,
 | 
			
		||||
              2 => 0,
 | 
			
		||||
              3 => 0,
 | 
			
		||||
              4 => 0,
 | 
			
		||||
              5 => 0,
 | 
			
		||||
              6 => 0,
 | 
			
		||||
              7 => 0,
 | 
			
		||||
              8 => 0,
 | 
			
		||||
              9 => 0,
 | 
			
		||||
            );
 | 
			
		||||
        if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
            return false; // end of input
 | 
			
		||||
        }
 | 
			
		||||
        $yy_global_pattern = "/^([ \t\r]+)|^(\\d+\\.\\d+(?=[ \t\r]*[\n#]))|^(\\d+(?=[ \t\r]*[\n#]))|^('[^'\\\\]*(?:\\\\.[^'\\\\]*)*'(?=[ \t\r]*[\n#]))|^(\"[^\"\\\\]*(?:\\\\.[^\"\\\\]*)*\"(?=[ \t\r]*[\n#]))|^(\"\"\"[^\"\\\\]*(?:\\\\.[^\"\\\\]*)*\"\"\"(?=[ \t\r]*[\n#]))|^([a-zA-Z]+(?=[ \t\r]*[\n#]))|^([^\n]+?(?=[ \t\r]*\n))|^(\n)/iS";
 | 
			
		||||
 | 
			
		||||
        do {
 | 
			
		||||
            if (preg_match($yy_global_pattern, substr($this->data, $this->counter), $yymatches)) {
 | 
			
		||||
                $yysubmatches = $yymatches;
 | 
			
		||||
                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns
 | 
			
		||||
                if (!count($yymatches)) {
 | 
			
		||||
                    throw new Exception('Error: lexing failed because a rule matched' .
 | 
			
		||||
                        'an empty string.  Input "' . substr($this->data,
 | 
			
		||||
                        $this->counter, 5) . '... state VALUE');
 | 
			
		||||
                }
 | 
			
		||||
                next($yymatches); // skip global match
 | 
			
		||||
                $this->token = key($yymatches); // token number
 | 
			
		||||
                if ($tokenMap[$this->token]) {
 | 
			
		||||
                    // extract sub-patterns for passing to lex function
 | 
			
		||||
                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,
 | 
			
		||||
                        $tokenMap[$this->token]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yysubmatches = array();
 | 
			
		||||
                }
 | 
			
		||||
                $this->value = current($yymatches); // token value
 | 
			
		||||
                $r = $this->{'yy_r2_' . $this->token}($yysubmatches);
 | 
			
		||||
                if ($r === null) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    // accept this token
 | 
			
		||||
                    return true;
 | 
			
		||||
                } elseif ($r === true) {
 | 
			
		||||
                    // we have changed state
 | 
			
		||||
                    // process this token in the new state
 | 
			
		||||
                    return $this->yylex();
 | 
			
		||||
                } elseif ($r === false) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
                        return false; // end of input
 | 
			
		||||
                    }
 | 
			
		||||
                    // skip this token
 | 
			
		||||
                    continue;
 | 
			
		||||
                }            } else {
 | 
			
		||||
                throw new Exception('Unexpected input at line' . $this->line .
 | 
			
		||||
                    ': ' . $this->data[$this->counter]);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
 | 
			
		||||
    } // end function
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    const VALUE = 2;
 | 
			
		||||
    function yy_r2_1($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    return false;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_2($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_FLOAT;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_3($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_INT;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_4($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_SINGLE_QUOTED_STRING;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_5($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_DOUBLE_QUOTED_STRING;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_6($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_TRIPPLE_DOUBLE_QUOTED_STRING;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_7($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    if (!$this->smarty->config_booleanize || !in_array(strtolower($this->value), Array("true", "false", "on", "off", "yes", "no")) ) {
 | 
			
		||||
        $this->yypopstate();
 | 
			
		||||
        $this->yypushstate(self::NAKED_STRING_VALUE);
 | 
			
		||||
        return true; //reprocess in new state
 | 
			
		||||
    } else {
 | 
			
		||||
        $this->token = Smarty_Internal_Configfileparser::TPC_BOOL;
 | 
			
		||||
        $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_8($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r2_9($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING;
 | 
			
		||||
    $this->value = "";
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    function yylex3()
 | 
			
		||||
    {
 | 
			
		||||
        $tokenMap = array (
 | 
			
		||||
              1 => 0,
 | 
			
		||||
            );
 | 
			
		||||
        if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
            return false; // end of input
 | 
			
		||||
        }
 | 
			
		||||
        $yy_global_pattern = "/^([^\n]+?(?=[ \t\r]*\n))/iS";
 | 
			
		||||
 | 
			
		||||
        do {
 | 
			
		||||
            if (preg_match($yy_global_pattern, substr($this->data, $this->counter), $yymatches)) {
 | 
			
		||||
                $yysubmatches = $yymatches;
 | 
			
		||||
                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns
 | 
			
		||||
                if (!count($yymatches)) {
 | 
			
		||||
                    throw new Exception('Error: lexing failed because a rule matched' .
 | 
			
		||||
                        'an empty string.  Input "' . substr($this->data,
 | 
			
		||||
                        $this->counter, 5) . '... state NAKED_STRING_VALUE');
 | 
			
		||||
                }
 | 
			
		||||
                next($yymatches); // skip global match
 | 
			
		||||
                $this->token = key($yymatches); // token number
 | 
			
		||||
                if ($tokenMap[$this->token]) {
 | 
			
		||||
                    // extract sub-patterns for passing to lex function
 | 
			
		||||
                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,
 | 
			
		||||
                        $tokenMap[$this->token]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yysubmatches = array();
 | 
			
		||||
                }
 | 
			
		||||
                $this->value = current($yymatches); // token value
 | 
			
		||||
                $r = $this->{'yy_r3_' . $this->token}($yysubmatches);
 | 
			
		||||
                if ($r === null) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    // accept this token
 | 
			
		||||
                    return true;
 | 
			
		||||
                } elseif ($r === true) {
 | 
			
		||||
                    // we have changed state
 | 
			
		||||
                    // process this token in the new state
 | 
			
		||||
                    return $this->yylex();
 | 
			
		||||
                } elseif ($r === false) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
                        return false; // end of input
 | 
			
		||||
                    }
 | 
			
		||||
                    // skip this token
 | 
			
		||||
                    continue;
 | 
			
		||||
                }            } else {
 | 
			
		||||
                throw new Exception('Unexpected input at line' . $this->line .
 | 
			
		||||
                    ': ' . $this->data[$this->counter]);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
 | 
			
		||||
    } // end function
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    const NAKED_STRING_VALUE = 3;
 | 
			
		||||
    function yy_r3_1($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    function yylex4()
 | 
			
		||||
    {
 | 
			
		||||
        $tokenMap = array (
 | 
			
		||||
              1 => 0,
 | 
			
		||||
              2 => 0,
 | 
			
		||||
              3 => 0,
 | 
			
		||||
            );
 | 
			
		||||
        if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
            return false; // end of input
 | 
			
		||||
        }
 | 
			
		||||
        $yy_global_pattern = "/^([ \t\r]+)|^([^\n]+?(?=[ \t\r]*\n))|^(\n)/iS";
 | 
			
		||||
 | 
			
		||||
        do {
 | 
			
		||||
            if (preg_match($yy_global_pattern, substr($this->data, $this->counter), $yymatches)) {
 | 
			
		||||
                $yysubmatches = $yymatches;
 | 
			
		||||
                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns
 | 
			
		||||
                if (!count($yymatches)) {
 | 
			
		||||
                    throw new Exception('Error: lexing failed because a rule matched' .
 | 
			
		||||
                        'an empty string.  Input "' . substr($this->data,
 | 
			
		||||
                        $this->counter, 5) . '... state COMMENT');
 | 
			
		||||
                }
 | 
			
		||||
                next($yymatches); // skip global match
 | 
			
		||||
                $this->token = key($yymatches); // token number
 | 
			
		||||
                if ($tokenMap[$this->token]) {
 | 
			
		||||
                    // extract sub-patterns for passing to lex function
 | 
			
		||||
                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,
 | 
			
		||||
                        $tokenMap[$this->token]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yysubmatches = array();
 | 
			
		||||
                }
 | 
			
		||||
                $this->value = current($yymatches); // token value
 | 
			
		||||
                $r = $this->{'yy_r4_' . $this->token}($yysubmatches);
 | 
			
		||||
                if ($r === null) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    // accept this token
 | 
			
		||||
                    return true;
 | 
			
		||||
                } elseif ($r === true) {
 | 
			
		||||
                    // we have changed state
 | 
			
		||||
                    // process this token in the new state
 | 
			
		||||
                    return $this->yylex();
 | 
			
		||||
                } elseif ($r === false) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
                        return false; // end of input
 | 
			
		||||
                    }
 | 
			
		||||
                    // skip this token
 | 
			
		||||
                    continue;
 | 
			
		||||
                }            } else {
 | 
			
		||||
                throw new Exception('Unexpected input at line' . $this->line .
 | 
			
		||||
                    ': ' . $this->data[$this->counter]);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
 | 
			
		||||
    } // end function
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    const COMMENT = 4;
 | 
			
		||||
    function yy_r4_1($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    return false;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r4_2($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NAKED_STRING;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r4_3($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_NEWLINE;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    function yylex5()
 | 
			
		||||
    {
 | 
			
		||||
        $tokenMap = array (
 | 
			
		||||
              1 => 0,
 | 
			
		||||
              2 => 0,
 | 
			
		||||
            );
 | 
			
		||||
        if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
            return false; // end of input
 | 
			
		||||
        }
 | 
			
		||||
        $yy_global_pattern = "/^(\\.)|^(.*?(?=[\.=[\]\r\n]))/iS";
 | 
			
		||||
 | 
			
		||||
        do {
 | 
			
		||||
            if (preg_match($yy_global_pattern, substr($this->data, $this->counter), $yymatches)) {
 | 
			
		||||
                $yysubmatches = $yymatches;
 | 
			
		||||
                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns
 | 
			
		||||
                if (!count($yymatches)) {
 | 
			
		||||
                    throw new Exception('Error: lexing failed because a rule matched' .
 | 
			
		||||
                        'an empty string.  Input "' . substr($this->data,
 | 
			
		||||
                        $this->counter, 5) . '... state SECTION');
 | 
			
		||||
                }
 | 
			
		||||
                next($yymatches); // skip global match
 | 
			
		||||
                $this->token = key($yymatches); // token number
 | 
			
		||||
                if ($tokenMap[$this->token]) {
 | 
			
		||||
                    // extract sub-patterns for passing to lex function
 | 
			
		||||
                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,
 | 
			
		||||
                        $tokenMap[$this->token]);
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yysubmatches = array();
 | 
			
		||||
                }
 | 
			
		||||
                $this->value = current($yymatches); // token value
 | 
			
		||||
                $r = $this->{'yy_r5_' . $this->token}($yysubmatches);
 | 
			
		||||
                if ($r === null) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    // accept this token
 | 
			
		||||
                    return true;
 | 
			
		||||
                } elseif ($r === true) {
 | 
			
		||||
                    // we have changed state
 | 
			
		||||
                    // process this token in the new state
 | 
			
		||||
                    return $this->yylex();
 | 
			
		||||
                } elseif ($r === false) {
 | 
			
		||||
                    $this->counter += strlen($this->value);
 | 
			
		||||
                    $this->line += substr_count($this->value, "\n");
 | 
			
		||||
                    if ($this->counter >= strlen($this->data)) {
 | 
			
		||||
                        return false; // end of input
 | 
			
		||||
                    }
 | 
			
		||||
                    // skip this token
 | 
			
		||||
                    continue;
 | 
			
		||||
                }            } else {
 | 
			
		||||
                throw new Exception('Unexpected input at line' . $this->line .
 | 
			
		||||
                    ': ' . $this->data[$this->counter]);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
 | 
			
		||||
    } // end function
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    const SECTION = 5;
 | 
			
		||||
    function yy_r5_1($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_DOT;
 | 
			
		||||
    }
 | 
			
		||||
    function yy_r5_2($yy_subpatterns)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
    $this->token = Smarty_Internal_Configfileparser::TPC_SECTION;
 | 
			
		||||
    $this->yypopstate();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,870 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Configfileparser
 | 
			
		||||
*
 | 
			
		||||
* This is the config file parser.
 | 
			
		||||
* It is generated from the internal.configfileparser.y file
 | 
			
		||||
* @package Smarty
 | 
			
		||||
* @subpackage Compiler
 | 
			
		||||
* @author Uwe Tews
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
class TPC_yyToken implements ArrayAccess
 | 
			
		||||
{
 | 
			
		||||
    public $string = '';
 | 
			
		||||
    public $metadata = array();
 | 
			
		||||
 | 
			
		||||
    function __construct($s, $m = array())
 | 
			
		||||
    {
 | 
			
		||||
        if ($s instanceof TPC_yyToken) {
 | 
			
		||||
            $this->string = $s->string;
 | 
			
		||||
            $this->metadata = $s->metadata;
 | 
			
		||||
        } else {
 | 
			
		||||
            $this->string = (string) $s;
 | 
			
		||||
            if ($m instanceof TPC_yyToken) {
 | 
			
		||||
                $this->metadata = $m->metadata;
 | 
			
		||||
            } elseif (is_array($m)) {
 | 
			
		||||
                $this->metadata = $m;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function __toString()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->_string;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function offsetExists($offset)
 | 
			
		||||
    {
 | 
			
		||||
        return isset($this->metadata[$offset]);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function offsetGet($offset)
 | 
			
		||||
    {
 | 
			
		||||
        return $this->metadata[$offset];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function offsetSet($offset, $value)
 | 
			
		||||
    {
 | 
			
		||||
        if ($offset === null) {
 | 
			
		||||
            if (isset($value[0])) {
 | 
			
		||||
                $x = ($value instanceof TPC_yyToken) ?
 | 
			
		||||
                    $value->metadata : $value;
 | 
			
		||||
                $this->metadata = array_merge($this->metadata, $x);
 | 
			
		||||
                return;
 | 
			
		||||
            }
 | 
			
		||||
            $offset = count($this->metadata);
 | 
			
		||||
        }
 | 
			
		||||
        if ($value === null) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        if ($value instanceof TPC_yyToken) {
 | 
			
		||||
            if ($value->metadata) {
 | 
			
		||||
                $this->metadata[$offset] = $value->metadata;
 | 
			
		||||
            }
 | 
			
		||||
        } elseif ($value) {
 | 
			
		||||
            $this->metadata[$offset] = $value;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function offsetUnset($offset)
 | 
			
		||||
    {
 | 
			
		||||
        unset($this->metadata[$offset]);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
class TPC_yyStackEntry
 | 
			
		||||
{
 | 
			
		||||
    public $stateno;       /* The state-number */
 | 
			
		||||
    public $major;         /* The major token value.  This is the code
 | 
			
		||||
                     ** number for the token at this stack level */
 | 
			
		||||
    public $minor; /* The user-supplied minor token value.  This
 | 
			
		||||
                     ** is the value of the token  */
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#line 12 "smarty_internal_configfileparser.y"
 | 
			
		||||
class Smarty_Internal_Configfileparser#line 79 "smarty_internal_configfileparser.php"
 | 
			
		||||
{
 | 
			
		||||
#line 14 "smarty_internal_configfileparser.y"
 | 
			
		||||
 | 
			
		||||
    // states whether the parse was successful or not
 | 
			
		||||
    public $successful = true;
 | 
			
		||||
    public $retvalue = 0;
 | 
			
		||||
    private $lex;
 | 
			
		||||
    private $internalError = false;
 | 
			
		||||
 | 
			
		||||
    function __construct($lex, $compiler) {
 | 
			
		||||
        // set instance object
 | 
			
		||||
        self::instance($this); 
 | 
			
		||||
        $this->lex = $lex;
 | 
			
		||||
        $this->smarty = $compiler->smarty; 
 | 
			
		||||
        $this->compiler = $compiler;
 | 
			
		||||
    }
 | 
			
		||||
    public static function &instance($new_instance = null)
 | 
			
		||||
    {
 | 
			
		||||
        static $instance = null;
 | 
			
		||||
        if (isset($new_instance) && is_object($new_instance))
 | 
			
		||||
            $instance = $new_instance;
 | 
			
		||||
        return $instance;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private function parse_bool($str) {
 | 
			
		||||
        if (in_array(strtolower($str) ,array('on','yes','true'))) {
 | 
			
		||||
            $res = true;
 | 
			
		||||
        } else {
 | 
			
		||||
            $res = false;
 | 
			
		||||
        }
 | 
			
		||||
        return $res;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static $escapes_single = Array('\\' => '\\',
 | 
			
		||||
                                          '\'' => '\'');
 | 
			
		||||
    private static function parse_single_quoted_string($qstr) {
 | 
			
		||||
        $escaped_string = substr($qstr, 1, strlen($qstr)-2); //remove outer quotes
 | 
			
		||||
 | 
			
		||||
        $ss = preg_split('/(\\\\.)/', $escaped_string, -1, PREG_SPLIT_DELIM_CAPTURE);
 | 
			
		||||
 | 
			
		||||
        $str = "";
 | 
			
		||||
        foreach ($ss as $s) {
 | 
			
		||||
            if (strlen($s) === 2 && $s[0] === '\\') {
 | 
			
		||||
                if (isset(self::$escapes_single[$s[1]])) {
 | 
			
		||||
                    $s = self::$escapes_single[$s[1]];
 | 
			
		||||
                }
 | 
			
		||||
             }
 | 
			
		||||
 | 
			
		||||
             $str .= $s;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return $str;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static function parse_double_quoted_string($qstr) {
 | 
			
		||||
        $inner_str = substr($qstr, 1, strlen($qstr)-2);
 | 
			
		||||
        return stripcslashes($inner_str);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static function parse_tripple_double_quoted_string($qstr) {
 | 
			
		||||
        $inner_str = substr($qstr, 3, strlen($qstr)-6);
 | 
			
		||||
        return stripcslashes($inner_str);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private function set_var(Array $var, Array &$target_array) {
 | 
			
		||||
        $key = $var["key"];
 | 
			
		||||
        $value = $var["value"];
 | 
			
		||||
 | 
			
		||||
        if ($this->smarty->config_overwrite || !isset($target_array['vars'][$key])) {
 | 
			
		||||
            $target_array['vars'][$key] = $value;
 | 
			
		||||
        } else {
 | 
			
		||||
            settype($target_array['vars'][$key], 'array');
 | 
			
		||||
            $target_array['vars'][$key][] = $value;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private function add_global_vars(Array $vars) {
 | 
			
		||||
        if (!isset($this->compiler->config_data['vars'])) {
 | 
			
		||||
	    $this->compiler->config_data['vars'] = Array();
 | 
			
		||||
        }
 | 
			
		||||
        foreach ($vars as $var) {
 | 
			
		||||
            $this->set_var($var, $this->compiler->config_data);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private function add_section_vars($section_name, Array $vars) {
 | 
			
		||||
        if (!isset($this->compiler->config_data['sections'][$section_name]['vars'])) {
 | 
			
		||||
            $this->compiler->config_data['sections'][$section_name]['vars'] = Array();
 | 
			
		||||
        }
 | 
			
		||||
        foreach ($vars as $var) {
 | 
			
		||||
            $this->set_var($var, $this->compiler->config_data['sections'][$section_name]);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
#line 174 "smarty_internal_configfileparser.php"
 | 
			
		||||
 | 
			
		||||
    const TPC_OPENB                          =  1;
 | 
			
		||||
    const TPC_SECTION                        =  2;
 | 
			
		||||
    const TPC_CLOSEB                         =  3;
 | 
			
		||||
    const TPC_DOT                            =  4;
 | 
			
		||||
    const TPC_ID                             =  5;
 | 
			
		||||
    const TPC_EQUAL                          =  6;
 | 
			
		||||
    const TPC_FLOAT                          =  7;
 | 
			
		||||
    const TPC_INT                            =  8;
 | 
			
		||||
    const TPC_BOOL                           =  9;
 | 
			
		||||
    const TPC_SINGLE_QUOTED_STRING           = 10;
 | 
			
		||||
    const TPC_DOUBLE_QUOTED_STRING           = 11;
 | 
			
		||||
    const TPC_TRIPPLE_DOUBLE_QUOTED_STRING   = 12;
 | 
			
		||||
    const TPC_NAKED_STRING                   = 13;
 | 
			
		||||
    const TPC_NEWLINE                        = 14;
 | 
			
		||||
    const TPC_COMMENTSTART                   = 15;
 | 
			
		||||
    const YY_NO_ACTION = 54;
 | 
			
		||||
    const YY_ACCEPT_ACTION = 53;
 | 
			
		||||
    const YY_ERROR_ACTION = 52;
 | 
			
		||||
 | 
			
		||||
    const YY_SZ_ACTTAB = 35;
 | 
			
		||||
static public $yy_action = array(
 | 
			
		||||
 /*     0 */    26,   27,   21,   30,   29,   28,   31,   16,   53,    8,
 | 
			
		||||
 /*    10 */    19,    2,   20,   11,   24,   23,   20,   11,   17,   15,
 | 
			
		||||
 /*    20 */     3,   14,   13,   18,    4,    6,    5,    1,   12,   22,
 | 
			
		||||
 /*    30 */     9,   47,   10,   25,    7,
 | 
			
		||||
    );
 | 
			
		||||
    static public $yy_lookahead = array(
 | 
			
		||||
 /*     0 */     7,    8,    9,   10,   11,   12,   13,    5,   17,   18,
 | 
			
		||||
 /*    10 */    14,   20,   14,   15,   22,   23,   14,   15,    2,    2,
 | 
			
		||||
 /*    20 */    20,    4,   13,   14,    6,    3,    3,   20,    1,   24,
 | 
			
		||||
 /*    30 */    22,   25,   22,   21,   19,
 | 
			
		||||
);
 | 
			
		||||
    const YY_SHIFT_USE_DFLT = -8;
 | 
			
		||||
    const YY_SHIFT_MAX = 17;
 | 
			
		||||
    static public $yy_shift_ofst = array(
 | 
			
		||||
 /*     0 */    -8,    2,    2,    2,   -7,   -2,   -2,   27,   -8,   -8,
 | 
			
		||||
 /*    10 */    -8,    9,   17,   -4,   16,   23,   18,   22,
 | 
			
		||||
);
 | 
			
		||||
    const YY_REDUCE_USE_DFLT = -10;
 | 
			
		||||
    const YY_REDUCE_MAX = 10;
 | 
			
		||||
    static public $yy_reduce_ofst = array(
 | 
			
		||||
 /*     0 */    -9,   -8,   -8,   -8,    5,   10,    8,   12,   15,    0,
 | 
			
		||||
 /*    10 */     7,
 | 
			
		||||
);
 | 
			
		||||
    static public $yyExpectedTokens = array(
 | 
			
		||||
        /* 0 */ array(),
 | 
			
		||||
        /* 1 */ array(5, 14, 15, ),
 | 
			
		||||
        /* 2 */ array(5, 14, 15, ),
 | 
			
		||||
        /* 3 */ array(5, 14, 15, ),
 | 
			
		||||
        /* 4 */ array(7, 8, 9, 10, 11, 12, 13, ),
 | 
			
		||||
        /* 5 */ array(14, 15, ),
 | 
			
		||||
        /* 6 */ array(14, 15, ),
 | 
			
		||||
        /* 7 */ array(1, ),
 | 
			
		||||
        /* 8 */ array(),
 | 
			
		||||
        /* 9 */ array(),
 | 
			
		||||
        /* 10 */ array(),
 | 
			
		||||
        /* 11 */ array(13, 14, ),
 | 
			
		||||
        /* 12 */ array(2, 4, ),
 | 
			
		||||
        /* 13 */ array(14, ),
 | 
			
		||||
        /* 14 */ array(2, ),
 | 
			
		||||
        /* 15 */ array(3, ),
 | 
			
		||||
        /* 16 */ array(6, ),
 | 
			
		||||
        /* 17 */ array(3, ),
 | 
			
		||||
        /* 18 */ array(),
 | 
			
		||||
        /* 19 */ array(),
 | 
			
		||||
        /* 20 */ array(),
 | 
			
		||||
        /* 21 */ array(),
 | 
			
		||||
        /* 22 */ array(),
 | 
			
		||||
        /* 23 */ array(),
 | 
			
		||||
        /* 24 */ array(),
 | 
			
		||||
        /* 25 */ array(),
 | 
			
		||||
        /* 26 */ array(),
 | 
			
		||||
        /* 27 */ array(),
 | 
			
		||||
        /* 28 */ array(),
 | 
			
		||||
        /* 29 */ array(),
 | 
			
		||||
        /* 30 */ array(),
 | 
			
		||||
        /* 31 */ array(),
 | 
			
		||||
);
 | 
			
		||||
    static public $yy_default = array(
 | 
			
		||||
 /*     0 */    40,   36,   33,   37,   52,   52,   52,   32,   35,   40,
 | 
			
		||||
 /*    10 */    40,   52,   52,   52,   52,   52,   52,   52,   50,   51,
 | 
			
		||||
 /*    20 */    49,   44,   41,   39,   38,   34,   42,   43,   47,   46,
 | 
			
		||||
 /*    30 */    45,   48,
 | 
			
		||||
);
 | 
			
		||||
    const YYNOCODE = 26;
 | 
			
		||||
    const YYSTACKDEPTH = 100;
 | 
			
		||||
    const YYNSTATE = 32;
 | 
			
		||||
    const YYNRULE = 20;
 | 
			
		||||
    const YYERRORSYMBOL = 16;
 | 
			
		||||
    const YYERRSYMDT = 'yy0';
 | 
			
		||||
    const YYFALLBACK = 0;
 | 
			
		||||
    static public $yyFallback = array(
 | 
			
		||||
    );
 | 
			
		||||
    static function Trace($TraceFILE, $zTracePrompt)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$TraceFILE) {
 | 
			
		||||
            $zTracePrompt = 0;
 | 
			
		||||
        } elseif (!$zTracePrompt) {
 | 
			
		||||
            $TraceFILE = 0;
 | 
			
		||||
        }
 | 
			
		||||
        self::$yyTraceFILE = $TraceFILE;
 | 
			
		||||
        self::$yyTracePrompt = $zTracePrompt;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    static function PrintTrace()
 | 
			
		||||
    {
 | 
			
		||||
        self::$yyTraceFILE = fopen('php://output', 'w');
 | 
			
		||||
        self::$yyTracePrompt = '<br>';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    static public $yyTraceFILE;
 | 
			
		||||
    static public $yyTracePrompt;
 | 
			
		||||
    public $yyidx;                    /* Index of top element in stack */
 | 
			
		||||
    public $yyerrcnt;                 /* Shifts left before out of the error */
 | 
			
		||||
    public $yystack = array();  /* The parser's stack */
 | 
			
		||||
 | 
			
		||||
    public $yyTokenName = array( 
 | 
			
		||||
  '$',             'OPENB',         'SECTION',       'CLOSEB',      
 | 
			
		||||
  'DOT',           'ID',            'EQUAL',         'FLOAT',       
 | 
			
		||||
  'INT',           'BOOL',          'SINGLE_QUOTED_STRING',  'DOUBLE_QUOTED_STRING',
 | 
			
		||||
  'TRIPPLE_DOUBLE_QUOTED_STRING',  'NAKED_STRING',  'NEWLINE',       'COMMENTSTART',
 | 
			
		||||
  'error',         'start',         'global_vars',   'sections',    
 | 
			
		||||
  'var_list',      'section',       'newline',       'var',         
 | 
			
		||||
  'value',       
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    static public $yyRuleName = array(
 | 
			
		||||
 /*   0 */ "start ::= global_vars sections",
 | 
			
		||||
 /*   1 */ "global_vars ::= var_list",
 | 
			
		||||
 /*   2 */ "sections ::= sections section",
 | 
			
		||||
 /*   3 */ "sections ::=",
 | 
			
		||||
 /*   4 */ "section ::= OPENB SECTION CLOSEB newline var_list",
 | 
			
		||||
 /*   5 */ "section ::= OPENB DOT SECTION CLOSEB newline var_list",
 | 
			
		||||
 /*   6 */ "var_list ::= var_list newline",
 | 
			
		||||
 /*   7 */ "var_list ::= var_list var",
 | 
			
		||||
 /*   8 */ "var_list ::=",
 | 
			
		||||
 /*   9 */ "var ::= ID EQUAL value",
 | 
			
		||||
 /*  10 */ "value ::= FLOAT",
 | 
			
		||||
 /*  11 */ "value ::= INT",
 | 
			
		||||
 /*  12 */ "value ::= BOOL",
 | 
			
		||||
 /*  13 */ "value ::= SINGLE_QUOTED_STRING",
 | 
			
		||||
 /*  14 */ "value ::= DOUBLE_QUOTED_STRING",
 | 
			
		||||
 /*  15 */ "value ::= TRIPPLE_DOUBLE_QUOTED_STRING",
 | 
			
		||||
 /*  16 */ "value ::= NAKED_STRING",
 | 
			
		||||
 /*  17 */ "newline ::= NEWLINE",
 | 
			
		||||
 /*  18 */ "newline ::= COMMENTSTART NEWLINE",
 | 
			
		||||
 /*  19 */ "newline ::= COMMENTSTART NAKED_STRING NEWLINE",
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    function tokenName($tokenType)
 | 
			
		||||
    {
 | 
			
		||||
        if ($tokenType === 0) {
 | 
			
		||||
            return 'End of Input';
 | 
			
		||||
        }
 | 
			
		||||
        if ($tokenType > 0 && $tokenType < count($this->yyTokenName)) {
 | 
			
		||||
            return $this->yyTokenName[$tokenType];
 | 
			
		||||
        } else {
 | 
			
		||||
            return "Unknown";
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    static function yy_destructor($yymajor, $yypminor)
 | 
			
		||||
    {
 | 
			
		||||
        switch ($yymajor) {
 | 
			
		||||
            default:  break;   /* If no destructor action specified: do nothing */
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_pop_parser_stack()
 | 
			
		||||
    {
 | 
			
		||||
        if (!count($this->yystack)) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        $yytos = array_pop($this->yystack);
 | 
			
		||||
        if (self::$yyTraceFILE && $this->yyidx >= 0) {
 | 
			
		||||
            fwrite(self::$yyTraceFILE,
 | 
			
		||||
                self::$yyTracePrompt . 'Popping ' . $this->yyTokenName[$yytos->major] .
 | 
			
		||||
                    "\n");
 | 
			
		||||
        }
 | 
			
		||||
        $yymajor = $yytos->major;
 | 
			
		||||
        self::yy_destructor($yymajor, $yytos->minor);
 | 
			
		||||
        $this->yyidx--;
 | 
			
		||||
        return $yymajor;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function __destruct()
 | 
			
		||||
    {
 | 
			
		||||
        while ($this->yystack !== Array()) {
 | 
			
		||||
            $this->yy_pop_parser_stack();
 | 
			
		||||
        }
 | 
			
		||||
        if (is_resource(self::$yyTraceFILE)) {
 | 
			
		||||
            fclose(self::$yyTraceFILE);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_get_expected_tokens($token)
 | 
			
		||||
    {
 | 
			
		||||
        $state = $this->yystack[$this->yyidx]->stateno;
 | 
			
		||||
        $expected = self::$yyExpectedTokens[$state];
 | 
			
		||||
        if (in_array($token, self::$yyExpectedTokens[$state], true)) {
 | 
			
		||||
            return $expected;
 | 
			
		||||
        }
 | 
			
		||||
        $stack = $this->yystack;
 | 
			
		||||
        $yyidx = $this->yyidx;
 | 
			
		||||
        do {
 | 
			
		||||
            $yyact = $this->yy_find_shift_action($token);
 | 
			
		||||
            if ($yyact >= self::YYNSTATE && $yyact < self::YYNSTATE + self::YYNRULE) {
 | 
			
		||||
                // reduce action
 | 
			
		||||
                $done = 0;
 | 
			
		||||
                do {
 | 
			
		||||
                    if ($done++ == 100) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        // too much recursion prevents proper detection
 | 
			
		||||
                        // so give up
 | 
			
		||||
                        return array_unique($expected);
 | 
			
		||||
                    }
 | 
			
		||||
                    $yyruleno = $yyact - self::YYNSTATE;
 | 
			
		||||
                    $this->yyidx -= self::$yyRuleInfo[$yyruleno]['rhs'];
 | 
			
		||||
                    $nextstate = $this->yy_find_reduce_action(
 | 
			
		||||
                        $this->yystack[$this->yyidx]->stateno,
 | 
			
		||||
                        self::$yyRuleInfo[$yyruleno]['lhs']);
 | 
			
		||||
                    if (isset(self::$yyExpectedTokens[$nextstate])) {
 | 
			
		||||
		        $expected = array_merge($expected, self::$yyExpectedTokens[$nextstate]);
 | 
			
		||||
                            if (in_array($token,
 | 
			
		||||
                                  self::$yyExpectedTokens[$nextstate], true)) {
 | 
			
		||||
                            $this->yyidx = $yyidx;
 | 
			
		||||
                            $this->yystack = $stack;
 | 
			
		||||
                            return array_unique($expected);
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                    if ($nextstate < self::YYNSTATE) {
 | 
			
		||||
                        // we need to shift a non-terminal
 | 
			
		||||
                        $this->yyidx++;
 | 
			
		||||
                        $x = new TPC_yyStackEntry;
 | 
			
		||||
                        $x->stateno = $nextstate;
 | 
			
		||||
                        $x->major = self::$yyRuleInfo[$yyruleno]['lhs'];
 | 
			
		||||
                        $this->yystack[$this->yyidx] = $x;
 | 
			
		||||
                        continue 2;
 | 
			
		||||
                    } elseif ($nextstate == self::YYNSTATE + self::YYNRULE + 1) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        // the last token was just ignored, we can't accept
 | 
			
		||||
                        // by ignoring input, this is in essence ignoring a
 | 
			
		||||
                        // syntax error!
 | 
			
		||||
                        return array_unique($expected);
 | 
			
		||||
                    } elseif ($nextstate === self::YY_NO_ACTION) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        // input accepted, but not shifted (I guess)
 | 
			
		||||
                        return $expected;
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $yyact = $nextstate;
 | 
			
		||||
                    }
 | 
			
		||||
                } while (true);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
	$this->yyidx = $yyidx;
 | 
			
		||||
	$this->yystack = $stack;
 | 
			
		||||
        return array_unique($expected);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_is_expected_token($token)
 | 
			
		||||
    {
 | 
			
		||||
        if ($token === 0) {
 | 
			
		||||
            return true; // 0 is not part of this
 | 
			
		||||
        }
 | 
			
		||||
        $state = $this->yystack[$this->yyidx]->stateno;
 | 
			
		||||
        if (in_array($token, self::$yyExpectedTokens[$state], true)) {
 | 
			
		||||
            return true;
 | 
			
		||||
        }
 | 
			
		||||
        $stack = $this->yystack;
 | 
			
		||||
        $yyidx = $this->yyidx;
 | 
			
		||||
        do {
 | 
			
		||||
            $yyact = $this->yy_find_shift_action($token);
 | 
			
		||||
            if ($yyact >= self::YYNSTATE && $yyact < self::YYNSTATE + self::YYNRULE) {
 | 
			
		||||
                // reduce action
 | 
			
		||||
                $done = 0;
 | 
			
		||||
                do {
 | 
			
		||||
                    if ($done++ == 100) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        // too much recursion prevents proper detection
 | 
			
		||||
                        // so give up
 | 
			
		||||
                        return true;
 | 
			
		||||
                    }
 | 
			
		||||
                    $yyruleno = $yyact - self::YYNSTATE;
 | 
			
		||||
                    $this->yyidx -= self::$yyRuleInfo[$yyruleno]['rhs'];
 | 
			
		||||
                    $nextstate = $this->yy_find_reduce_action(
 | 
			
		||||
                        $this->yystack[$this->yyidx]->stateno,
 | 
			
		||||
                        self::$yyRuleInfo[$yyruleno]['lhs']);
 | 
			
		||||
                    if (isset(self::$yyExpectedTokens[$nextstate]) &&
 | 
			
		||||
                          in_array($token, self::$yyExpectedTokens[$nextstate], true)) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        return true;
 | 
			
		||||
                    }
 | 
			
		||||
                    if ($nextstate < self::YYNSTATE) {
 | 
			
		||||
                        // we need to shift a non-terminal
 | 
			
		||||
                        $this->yyidx++;
 | 
			
		||||
                        $x = new TPC_yyStackEntry;
 | 
			
		||||
                        $x->stateno = $nextstate;
 | 
			
		||||
                        $x->major = self::$yyRuleInfo[$yyruleno]['lhs'];
 | 
			
		||||
                        $this->yystack[$this->yyidx] = $x;
 | 
			
		||||
                        continue 2;
 | 
			
		||||
                    } elseif ($nextstate == self::YYNSTATE + self::YYNRULE + 1) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        if (!$token) {
 | 
			
		||||
                            // end of input: this is valid
 | 
			
		||||
                            return true;
 | 
			
		||||
                        }
 | 
			
		||||
                        // the last token was just ignored, we can't accept
 | 
			
		||||
                        // by ignoring input, this is in essence ignoring a
 | 
			
		||||
                        // syntax error!
 | 
			
		||||
                        return false;
 | 
			
		||||
                    } elseif ($nextstate === self::YY_NO_ACTION) {
 | 
			
		||||
                        $this->yyidx = $yyidx;
 | 
			
		||||
                        $this->yystack = $stack;
 | 
			
		||||
                        // input accepted, but not shifted (I guess)
 | 
			
		||||
                        return true;
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $yyact = $nextstate;
 | 
			
		||||
                    }
 | 
			
		||||
                } while (true);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        } while (true);
 | 
			
		||||
        $this->yyidx = $yyidx;
 | 
			
		||||
        $this->yystack = $stack;
 | 
			
		||||
        return true;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
   function yy_find_shift_action($iLookAhead)
 | 
			
		||||
    {
 | 
			
		||||
        $stateno = $this->yystack[$this->yyidx]->stateno;
 | 
			
		||||
     
 | 
			
		||||
        /* if ($this->yyidx < 0) return self::YY_NO_ACTION;  */
 | 
			
		||||
        if (!isset(self::$yy_shift_ofst[$stateno])) {
 | 
			
		||||
            // no shift actions
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        }
 | 
			
		||||
        $i = self::$yy_shift_ofst[$stateno];
 | 
			
		||||
        if ($i === self::YY_SHIFT_USE_DFLT) {
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        }
 | 
			
		||||
        if ($iLookAhead == self::YYNOCODE) {
 | 
			
		||||
            return self::YY_NO_ACTION;
 | 
			
		||||
        }
 | 
			
		||||
        $i += $iLookAhead;
 | 
			
		||||
        if ($i < 0 || $i >= self::YY_SZ_ACTTAB ||
 | 
			
		||||
              self::$yy_lookahead[$i] != $iLookAhead) {
 | 
			
		||||
            if (count(self::$yyFallback) && $iLookAhead < count(self::$yyFallback)
 | 
			
		||||
                   && ($iFallback = self::$yyFallback[$iLookAhead]) != 0) {
 | 
			
		||||
                if (self::$yyTraceFILE) {
 | 
			
		||||
                    fwrite(self::$yyTraceFILE, self::$yyTracePrompt . "FALLBACK " .
 | 
			
		||||
                        $this->yyTokenName[$iLookAhead] . " => " .
 | 
			
		||||
                        $this->yyTokenName[$iFallback] . "\n");
 | 
			
		||||
                }
 | 
			
		||||
                return $this->yy_find_shift_action($iFallback);
 | 
			
		||||
            }
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        } else {
 | 
			
		||||
            return self::$yy_action[$i];
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_find_reduce_action($stateno, $iLookAhead)
 | 
			
		||||
    {
 | 
			
		||||
        /* $stateno = $this->yystack[$this->yyidx]->stateno; */
 | 
			
		||||
 | 
			
		||||
        if (!isset(self::$yy_reduce_ofst[$stateno])) {
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        }
 | 
			
		||||
        $i = self::$yy_reduce_ofst[$stateno];
 | 
			
		||||
        if ($i == self::YY_REDUCE_USE_DFLT) {
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        }
 | 
			
		||||
        if ($iLookAhead == self::YYNOCODE) {
 | 
			
		||||
            return self::YY_NO_ACTION;
 | 
			
		||||
        }
 | 
			
		||||
        $i += $iLookAhead;
 | 
			
		||||
        if ($i < 0 || $i >= self::YY_SZ_ACTTAB ||
 | 
			
		||||
              self::$yy_lookahead[$i] != $iLookAhead) {
 | 
			
		||||
            return self::$yy_default[$stateno];
 | 
			
		||||
        } else {
 | 
			
		||||
            return self::$yy_action[$i];
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_shift($yyNewState, $yyMajor, $yypMinor)
 | 
			
		||||
    {
 | 
			
		||||
        $this->yyidx++;
 | 
			
		||||
        if ($this->yyidx >= self::YYSTACKDEPTH) {
 | 
			
		||||
            $this->yyidx--;
 | 
			
		||||
            if (self::$yyTraceFILE) {
 | 
			
		||||
                fprintf(self::$yyTraceFILE, "%sStack Overflow!\n", self::$yyTracePrompt);
 | 
			
		||||
            }
 | 
			
		||||
            while ($this->yyidx >= 0) {
 | 
			
		||||
                $this->yy_pop_parser_stack();
 | 
			
		||||
            }
 | 
			
		||||
#line 126 "smarty_internal_configfileparser.y"
 | 
			
		||||
 | 
			
		||||
    $this->internalError = true;
 | 
			
		||||
    $this->compiler->trigger_config_file_error("Stack overflow in configfile parser");
 | 
			
		||||
#line 585 "smarty_internal_configfileparser.php"
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        $yytos = new TPC_yyStackEntry;
 | 
			
		||||
        $yytos->stateno = $yyNewState;
 | 
			
		||||
        $yytos->major = $yyMajor;
 | 
			
		||||
        $yytos->minor = $yypMinor;
 | 
			
		||||
        array_push($this->yystack, $yytos);
 | 
			
		||||
        if (self::$yyTraceFILE && $this->yyidx > 0) {
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sShift %d\n", self::$yyTracePrompt,
 | 
			
		||||
                $yyNewState);
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sStack:", self::$yyTracePrompt);
 | 
			
		||||
            for($i = 1; $i <= $this->yyidx; $i++) {
 | 
			
		||||
                fprintf(self::$yyTraceFILE, " %s",
 | 
			
		||||
                    $this->yyTokenName[$this->yystack[$i]->major]);
 | 
			
		||||
            }
 | 
			
		||||
            fwrite(self::$yyTraceFILE,"\n");
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    static public $yyRuleInfo = array(
 | 
			
		||||
  array( 'lhs' => 17, 'rhs' => 2 ),
 | 
			
		||||
  array( 'lhs' => 18, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 19, 'rhs' => 2 ),
 | 
			
		||||
  array( 'lhs' => 19, 'rhs' => 0 ),
 | 
			
		||||
  array( 'lhs' => 21, 'rhs' => 5 ),
 | 
			
		||||
  array( 'lhs' => 21, 'rhs' => 6 ),
 | 
			
		||||
  array( 'lhs' => 20, 'rhs' => 2 ),
 | 
			
		||||
  array( 'lhs' => 20, 'rhs' => 2 ),
 | 
			
		||||
  array( 'lhs' => 20, 'rhs' => 0 ),
 | 
			
		||||
  array( 'lhs' => 23, 'rhs' => 3 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 24, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 22, 'rhs' => 1 ),
 | 
			
		||||
  array( 'lhs' => 22, 'rhs' => 2 ),
 | 
			
		||||
  array( 'lhs' => 22, 'rhs' => 3 ),
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    static public $yyReduceMap = array(
 | 
			
		||||
        0 => 0,
 | 
			
		||||
        2 => 0,
 | 
			
		||||
        3 => 0,
 | 
			
		||||
        17 => 0,
 | 
			
		||||
        18 => 0,
 | 
			
		||||
        19 => 0,
 | 
			
		||||
        1 => 1,
 | 
			
		||||
        4 => 4,
 | 
			
		||||
        5 => 5,
 | 
			
		||||
        6 => 6,
 | 
			
		||||
        7 => 7,
 | 
			
		||||
        8 => 8,
 | 
			
		||||
        9 => 9,
 | 
			
		||||
        10 => 10,
 | 
			
		||||
        11 => 11,
 | 
			
		||||
        12 => 12,
 | 
			
		||||
        13 => 13,
 | 
			
		||||
        14 => 14,
 | 
			
		||||
        15 => 15,
 | 
			
		||||
        16 => 16,
 | 
			
		||||
    );
 | 
			
		||||
#line 132 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r0(){ $this->_retvalue = null;     }
 | 
			
		||||
#line 652 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 135 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r1(){ $this->add_global_vars($this->yystack[$this->yyidx + 0]->minor); $this->_retvalue = null;     }
 | 
			
		||||
#line 655 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 141 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r4(){ $this->add_section_vars($this->yystack[$this->yyidx + -3]->minor, $this->yystack[$this->yyidx + 0]->minor); $this->_retvalue = null;     }
 | 
			
		||||
#line 658 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 142 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r5(){ if ($this->smarty->config_read_hidden) { $this->add_section_vars($this->yystack[$this->yyidx + -3]->minor, $this->yystack[$this->yyidx + 0]->minor); } $this->_retvalue = null;     }
 | 
			
		||||
#line 661 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 145 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r6(){ $this->_retvalue = $this->yystack[$this->yyidx + -1]->minor;     }
 | 
			
		||||
#line 664 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 146 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r7(){ $this->_retvalue = array_merge($this->yystack[$this->yyidx + -1]->minor, Array($this->yystack[$this->yyidx + 0]->minor));     }
 | 
			
		||||
#line 667 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 147 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r8(){ $this->_retvalue = Array();     }
 | 
			
		||||
#line 670 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 151 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r9(){ $this->_retvalue = Array("key" => $this->yystack[$this->yyidx + -2]->minor, "value" => $this->yystack[$this->yyidx + 0]->minor);     }
 | 
			
		||||
#line 673 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 153 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r10(){ $this->_retvalue = (float) $this->yystack[$this->yyidx + 0]->minor;     }
 | 
			
		||||
#line 676 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 154 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r11(){ $this->_retvalue = (int) $this->yystack[$this->yyidx + 0]->minor;     }
 | 
			
		||||
#line 679 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 155 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r12(){ $this->_retvalue = $this->parse_bool($this->yystack[$this->yyidx + 0]->minor);     }
 | 
			
		||||
#line 682 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 156 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r13(){ $this->_retvalue = self::parse_single_quoted_string($this->yystack[$this->yyidx + 0]->minor);     }
 | 
			
		||||
#line 685 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 157 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r14(){ $this->_retvalue = self::parse_double_quoted_string($this->yystack[$this->yyidx + 0]->minor);     }
 | 
			
		||||
#line 688 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 158 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r15(){ $this->_retvalue = self::parse_tripple_double_quoted_string($this->yystack[$this->yyidx + 0]->minor);     }
 | 
			
		||||
#line 691 "smarty_internal_configfileparser.php"
 | 
			
		||||
#line 159 "smarty_internal_configfileparser.y"
 | 
			
		||||
    function yy_r16(){ $this->_retvalue = $this->yystack[$this->yyidx + 0]->minor;     }
 | 
			
		||||
#line 694 "smarty_internal_configfileparser.php"
 | 
			
		||||
 | 
			
		||||
    private $_retvalue;
 | 
			
		||||
 | 
			
		||||
    function yy_reduce($yyruleno)
 | 
			
		||||
    {
 | 
			
		||||
        $yymsp = $this->yystack[$this->yyidx];
 | 
			
		||||
        if (self::$yyTraceFILE && $yyruleno >= 0 
 | 
			
		||||
              && $yyruleno < count(self::$yyRuleName)) {
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sReduce (%d) [%s].\n",
 | 
			
		||||
                self::$yyTracePrompt, $yyruleno,
 | 
			
		||||
                self::$yyRuleName[$yyruleno]);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $this->_retvalue = $yy_lefthand_side = null;
 | 
			
		||||
        if (array_key_exists($yyruleno, self::$yyReduceMap)) {
 | 
			
		||||
            // call the action
 | 
			
		||||
            $this->_retvalue = null;
 | 
			
		||||
            $this->{'yy_r' . self::$yyReduceMap[$yyruleno]}();
 | 
			
		||||
            $yy_lefthand_side = $this->_retvalue;
 | 
			
		||||
        }
 | 
			
		||||
        $yygoto = self::$yyRuleInfo[$yyruleno]['lhs'];
 | 
			
		||||
        $yysize = self::$yyRuleInfo[$yyruleno]['rhs'];
 | 
			
		||||
        $this->yyidx -= $yysize;
 | 
			
		||||
        for($i = $yysize; $i; $i--) {
 | 
			
		||||
            // pop all of the right-hand side parameters
 | 
			
		||||
            array_pop($this->yystack);
 | 
			
		||||
        }
 | 
			
		||||
        $yyact = $this->yy_find_reduce_action($this->yystack[$this->yyidx]->stateno, $yygoto);
 | 
			
		||||
        if ($yyact < self::YYNSTATE) {
 | 
			
		||||
            if (!self::$yyTraceFILE && $yysize) {
 | 
			
		||||
                $this->yyidx++;
 | 
			
		||||
                $x = new TPC_yyStackEntry;
 | 
			
		||||
                $x->stateno = $yyact;
 | 
			
		||||
                $x->major = $yygoto;
 | 
			
		||||
                $x->minor = $yy_lefthand_side;
 | 
			
		||||
                $this->yystack[$this->yyidx] = $x;
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->yy_shift($yyact, $yygoto, $yy_lefthand_side);
 | 
			
		||||
            }
 | 
			
		||||
        } elseif ($yyact == self::YYNSTATE + self::YYNRULE + 1) {
 | 
			
		||||
            $this->yy_accept();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_parse_failed()
 | 
			
		||||
    {
 | 
			
		||||
        if (self::$yyTraceFILE) {
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sFail!\n", self::$yyTracePrompt);
 | 
			
		||||
        }
 | 
			
		||||
        while ($this->yyidx >= 0) {
 | 
			
		||||
            $this->yy_pop_parser_stack();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_syntax_error($yymajor, $TOKEN)
 | 
			
		||||
    {
 | 
			
		||||
#line 119 "smarty_internal_configfileparser.y"
 | 
			
		||||
 | 
			
		||||
    $this->internalError = true;
 | 
			
		||||
    $this->yymajor = $yymajor;
 | 
			
		||||
    $this->compiler->trigger_config_file_error();
 | 
			
		||||
#line 757 "smarty_internal_configfileparser.php"
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function yy_accept()
 | 
			
		||||
    {
 | 
			
		||||
        if (self::$yyTraceFILE) {
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sAccept!\n", self::$yyTracePrompt);
 | 
			
		||||
        }
 | 
			
		||||
        while ($this->yyidx >= 0) {
 | 
			
		||||
            $stack = $this->yy_pop_parser_stack();
 | 
			
		||||
        }
 | 
			
		||||
#line 111 "smarty_internal_configfileparser.y"
 | 
			
		||||
 | 
			
		||||
    $this->successful = !$this->internalError;
 | 
			
		||||
    $this->internalError = false;
 | 
			
		||||
    $this->retvalue = $this->_retvalue;
 | 
			
		||||
    //echo $this->retvalue."\n\n";
 | 
			
		||||
#line 775 "smarty_internal_configfileparser.php"
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function doParse($yymajor, $yytokenvalue)
 | 
			
		||||
    {
 | 
			
		||||
        $yyerrorhit = 0;   /* True if yymajor has invoked an error */
 | 
			
		||||
        
 | 
			
		||||
        if ($this->yyidx === null || $this->yyidx < 0) {
 | 
			
		||||
            $this->yyidx = 0;
 | 
			
		||||
            $this->yyerrcnt = -1;
 | 
			
		||||
            $x = new TPC_yyStackEntry;
 | 
			
		||||
            $x->stateno = 0;
 | 
			
		||||
            $x->major = 0;
 | 
			
		||||
            $this->yystack = array();
 | 
			
		||||
            array_push($this->yystack, $x);
 | 
			
		||||
        }
 | 
			
		||||
        $yyendofinput = ($yymajor==0);
 | 
			
		||||
        
 | 
			
		||||
        if (self::$yyTraceFILE) {
 | 
			
		||||
            fprintf(self::$yyTraceFILE, "%sInput %s\n",
 | 
			
		||||
                self::$yyTracePrompt, $this->yyTokenName[$yymajor]);
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        do {
 | 
			
		||||
            $yyact = $this->yy_find_shift_action($yymajor);
 | 
			
		||||
            if ($yymajor < self::YYERRORSYMBOL &&
 | 
			
		||||
                  !$this->yy_is_expected_token($yymajor)) {
 | 
			
		||||
                // force a syntax error
 | 
			
		||||
                $yyact = self::YY_ERROR_ACTION;
 | 
			
		||||
            }
 | 
			
		||||
            if ($yyact < self::YYNSTATE) {
 | 
			
		||||
                $this->yy_shift($yyact, $yymajor, $yytokenvalue);
 | 
			
		||||
                $this->yyerrcnt--;
 | 
			
		||||
                if ($yyendofinput && $this->yyidx >= 0) {
 | 
			
		||||
                    $yymajor = 0;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $yymajor = self::YYNOCODE;
 | 
			
		||||
                }
 | 
			
		||||
            } elseif ($yyact < self::YYNSTATE + self::YYNRULE) {
 | 
			
		||||
                $this->yy_reduce($yyact - self::YYNSTATE);
 | 
			
		||||
            } elseif ($yyact == self::YY_ERROR_ACTION) {
 | 
			
		||||
                if (self::$yyTraceFILE) {
 | 
			
		||||
                    fprintf(self::$yyTraceFILE, "%sSyntax Error!\n",
 | 
			
		||||
                        self::$yyTracePrompt);
 | 
			
		||||
                }
 | 
			
		||||
                if (self::YYERRORSYMBOL) {
 | 
			
		||||
                    if ($this->yyerrcnt < 0) {
 | 
			
		||||
                        $this->yy_syntax_error($yymajor, $yytokenvalue);
 | 
			
		||||
                    }
 | 
			
		||||
                    $yymx = $this->yystack[$this->yyidx]->major;
 | 
			
		||||
                    if ($yymx == self::YYERRORSYMBOL || $yyerrorhit ){
 | 
			
		||||
                        if (self::$yyTraceFILE) {
 | 
			
		||||
                            fprintf(self::$yyTraceFILE, "%sDiscard input token %s\n",
 | 
			
		||||
                                self::$yyTracePrompt, $this->yyTokenName[$yymajor]);
 | 
			
		||||
                        }
 | 
			
		||||
                        $this->yy_destructor($yymajor, $yytokenvalue);
 | 
			
		||||
                        $yymajor = self::YYNOCODE;
 | 
			
		||||
                    } else {
 | 
			
		||||
                        while ($this->yyidx >= 0 &&
 | 
			
		||||
                                 $yymx != self::YYERRORSYMBOL &&
 | 
			
		||||
        ($yyact = $this->yy_find_shift_action(self::YYERRORSYMBOL)) >= self::YYNSTATE
 | 
			
		||||
                              ){
 | 
			
		||||
                            $this->yy_pop_parser_stack();
 | 
			
		||||
                        }
 | 
			
		||||
                        if ($this->yyidx < 0 || $yymajor==0) {
 | 
			
		||||
                            $this->yy_destructor($yymajor, $yytokenvalue);
 | 
			
		||||
                            $this->yy_parse_failed();
 | 
			
		||||
                            $yymajor = self::YYNOCODE;
 | 
			
		||||
                        } elseif ($yymx != self::YYERRORSYMBOL) {
 | 
			
		||||
                            $u2 = 0;
 | 
			
		||||
                            $this->yy_shift($yyact, self::YYERRORSYMBOL, $u2);
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                    $this->yyerrcnt = 3;
 | 
			
		||||
                    $yyerrorhit = 1;
 | 
			
		||||
                } else {
 | 
			
		||||
                    if ($this->yyerrcnt <= 0) {
 | 
			
		||||
                        $this->yy_syntax_error($yymajor, $yytokenvalue);
 | 
			
		||||
                    }
 | 
			
		||||
                    $this->yyerrcnt = 3;
 | 
			
		||||
                    $this->yy_destructor($yymajor, $yytokenvalue);
 | 
			
		||||
                    if ($yyendofinput) {
 | 
			
		||||
                        $this->yy_parse_failed();
 | 
			
		||||
                    }
 | 
			
		||||
                    $yymajor = self::YYNOCODE;
 | 
			
		||||
                }
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->yy_accept();
 | 
			
		||||
                $yymajor = self::YYNOCODE;
 | 
			
		||||
            }            
 | 
			
		||||
        } while ($yymajor != self::YYNOCODE && $this->yyidx >= 0);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										479
									
								
								site/stackreach/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										479
									
								
								site/stackreach/libs/sysplugins/smarty_internal_data.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,479 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Data
 | 
			
		||||
 * 
 | 
			
		||||
 * This file contains the basic classes and methodes for template and variable creation
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Templates
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Base class with template and variable methodes
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Data {
 | 
			
		||||
    // class used for templates
 | 
			
		||||
    public $template_class = 'Smarty_Internal_Template';
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 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
 | 
			
		||||
     * @param boolean $scope the scope the variable will have  (local,parent or root)
 | 
			
		||||
     */
 | 
			
		||||
    public function assign($tpl_var, $value = null, $nocache = false)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_array($tpl_var)) {
 | 
			
		||||
            foreach ($tpl_var as $_key => $_val) {
 | 
			
		||||
                if ($_key != '') {
 | 
			
		||||
                    $this->tpl_vars[$_key] = new Smarty_variable($_val, $nocache);
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            if ($tpl_var != '') {
 | 
			
		||||
                $this->tpl_vars[$tpl_var] = new Smarty_variable($value, $nocache);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * 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
 | 
			
		||||
     */
 | 
			
		||||
    public function assignGlobal($varname, $value = null, $nocache = false)
 | 
			
		||||
    {
 | 
			
		||||
        if ($varname != '') {
 | 
			
		||||
            Smarty::$global_tpl_vars[$varname] = new Smarty_variable($value, $nocache);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * assigns values to template variables by reference
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $tpl_var the template variable name
 | 
			
		||||
     * @param mixed $ &$value the referenced value to assign
 | 
			
		||||
     * @param boolean $nocache if true any output of this variable will be not cached
 | 
			
		||||
     */
 | 
			
		||||
    public function assignByRef($tpl_var, &$value, $nocache = false)
 | 
			
		||||
    {
 | 
			
		||||
        if ($tpl_var != '') {
 | 
			
		||||
            $this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache);
 | 
			
		||||
            $this->tpl_vars[$tpl_var]->value = &$value;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * wrapper function for Smarty 2 BC
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $tpl_var the template variable name
 | 
			
		||||
     * @param mixed $ &$value the referenced value to assign
 | 
			
		||||
     */
 | 
			
		||||
    public function assign_by_ref($tpl_var, &$value)
 | 
			
		||||
    {
 | 
			
		||||
       	if($this->smarty->deprecation_notices)
 | 
			
		||||
        	trigger_error("function call 'assign_by_ref' is unknown or deprecated, use 'assignByRef'", E_USER_NOTICE);
 | 
			
		||||
        $this->assignByRef($tpl_var, $value);
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * appends values to template variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param array $ |string $tpl_var the template variable name(s)
 | 
			
		||||
     * @param mixed $value the value to append
 | 
			
		||||
     * @param boolean $merge flag if array elements shall be merged
 | 
			
		||||
     * @param boolean $nocache if true any output of this variable will be not cached
 | 
			
		||||
     */
 | 
			
		||||
    public function append($tpl_var, $value = null, $merge = false, $nocache = false)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_array($tpl_var)) {
 | 
			
		||||
            // $tpl_var is an array, ignore $value
 | 
			
		||||
            foreach ($tpl_var as $_key => $_val) {
 | 
			
		||||
                if ($_key != '') {
 | 
			
		||||
                    if (!isset($this->tpl_vars[$_key])) {
 | 
			
		||||
                        $tpl_var_inst = $this->getVariable($_key, null, true, false);
 | 
			
		||||
                        if ($tpl_var_inst instanceof Undefined_Smarty_Variable) {
 | 
			
		||||
                            $this->tpl_vars[$_key] = new Smarty_variable(null, $nocache);
 | 
			
		||||
                        } else {
 | 
			
		||||
                            $this->tpl_vars[$_key] = clone $tpl_var_inst;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                    if (!(is_array($this->tpl_vars[$_key]->value) || $this->tpl_vars[$_key]->value instanceof ArrayAccess)) {
 | 
			
		||||
                        settype($this->tpl_vars[$_key]->value, 'array');
 | 
			
		||||
                    } 
 | 
			
		||||
                    if ($merge && is_array($_val)) {
 | 
			
		||||
                        foreach($_val as $_mkey => $_mval) {
 | 
			
		||||
                            $this->tpl_vars[$_key]->value[$_mkey] = $_mval;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $this->tpl_vars[$_key]->value[] = $_val;
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            if ($tpl_var != '' && isset($value)) {
 | 
			
		||||
                if (!isset($this->tpl_vars[$tpl_var])) {
 | 
			
		||||
                    $tpl_var_inst = $this->getVariable($tpl_var, null, true, false);
 | 
			
		||||
                    if ($tpl_var_inst instanceof Undefined_Smarty_Variable) {
 | 
			
		||||
                        $this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache);
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $this->tpl_vars[$tpl_var] = clone $tpl_var_inst;
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
                if (!(is_array($this->tpl_vars[$tpl_var]->value) || $this->tpl_vars[$tpl_var]->value instanceof ArrayAccess)) {
 | 
			
		||||
                    settype($this->tpl_vars[$tpl_var]->value, 'array');
 | 
			
		||||
                } 
 | 
			
		||||
                if ($merge && is_array($value)) {
 | 
			
		||||
                    foreach($value as $_mkey => $_mval) {
 | 
			
		||||
                        $this->tpl_vars[$tpl_var]->value[$_mkey] = $_mval;
 | 
			
		||||
                    } 
 | 
			
		||||
                } else {
 | 
			
		||||
                    $this->tpl_vars[$tpl_var]->value[] = $value;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 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
 | 
			
		||||
     */
 | 
			
		||||
    public function appendByRef($tpl_var, &$value, $merge = false)
 | 
			
		||||
    {
 | 
			
		||||
        if ($tpl_var != '' && isset($value)) {
 | 
			
		||||
            if (!isset($this->tpl_vars[$tpl_var])) {
 | 
			
		||||
                $this->tpl_vars[$tpl_var] = new Smarty_variable();
 | 
			
		||||
            } 
 | 
			
		||||
            if (!@is_array($this->tpl_vars[$tpl_var]->value)) {
 | 
			
		||||
                settype($this->tpl_vars[$tpl_var]->value, 'array');
 | 
			
		||||
            } 
 | 
			
		||||
            if ($merge && is_array($value)) {
 | 
			
		||||
                foreach($value as $_key => $_val) {
 | 
			
		||||
                    $this->tpl_vars[$tpl_var]->value[$_key] = &$value[$_key];
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->tpl_vars[$tpl_var]->value[] = &$value;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 
 | 
			
		||||
     /**
 | 
			
		||||
     * 
 | 
			
		||||
     * @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
 | 
			
		||||
     */
 | 
			
		||||
    public function append_by_ref($tpl_var, &$value, $merge = false)
 | 
			
		||||
    {
 | 
			
		||||
       	if($this->smarty->deprecation_notices)
 | 
			
		||||
        	trigger_error("function call 'append_by_ref' is unknown or deprecated, use 'appendByRef'", E_USER_NOTICE);
 | 
			
		||||
        $this->appendByRef($tpl_var, $value, $merge);
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns a single or all template variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $varname variable name or null
 | 
			
		||||
     * @return string variable value or or array of variables
 | 
			
		||||
     */
 | 
			
		||||
    function getTemplateVars($varname = null, $_ptr = null, $search_parents = true)
 | 
			
		||||
    {
 | 
			
		||||
        if (isset($varname)) {
 | 
			
		||||
            $_var = $this->getVariable($varname, $_ptr, $search_parents, false);
 | 
			
		||||
            if (is_object($_var)) {
 | 
			
		||||
                return $_var->value;
 | 
			
		||||
            } else {
 | 
			
		||||
                return null;
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            $_result = array();
 | 
			
		||||
            if ($_ptr === null) {
 | 
			
		||||
                $_ptr = $this;
 | 
			
		||||
            } while ($_ptr !== null) {
 | 
			
		||||
                foreach ($_ptr->tpl_vars AS $key => $var) {
 | 
			
		||||
                    if (!array_key_exists($key, $_result)) {
 | 
			
		||||
                        $_result[$key] = $var->value;
 | 
			
		||||
                    }
 | 
			
		||||
                } 
 | 
			
		||||
                // not found, try at parent
 | 
			
		||||
                if ($search_parents) {
 | 
			
		||||
                    $_ptr = $_ptr->parent;
 | 
			
		||||
                } else {
 | 
			
		||||
                    $_ptr = null;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            if ($search_parents && isset(Smarty::$global_tpl_vars)) {
 | 
			
		||||
                foreach (Smarty::$global_tpl_vars AS $key => $var) {
 | 
			
		||||
                    if (!array_key_exists($key, $_result)) {
 | 
			
		||||
                        $_result[$key] = $var->value;
 | 
			
		||||
                    }
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            return $_result;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * clear the given assigned template variable.
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $ |array $tpl_var the template variable(s) to clear
 | 
			
		||||
     */
 | 
			
		||||
    public function clearAssign($tpl_var)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_array($tpl_var)) {
 | 
			
		||||
            foreach ($tpl_var as $curr_var) {
 | 
			
		||||
                unset($this->tpl_vars[$curr_var]);
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            unset($this->tpl_vars[$tpl_var]);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * clear all the assigned template variables.
 | 
			
		||||
     */
 | 
			
		||||
    public function clearAllAssign()
 | 
			
		||||
    {
 | 
			
		||||
        $this->tpl_vars = array();
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * load a config file, optionally load just selected sections
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $config_file filename
 | 
			
		||||
     * @param mixed $sections array of section names, single section or null
 | 
			
		||||
     */
 | 
			
		||||
    public function configLoad($config_file, $sections = null)
 | 
			
		||||
    { 
 | 
			
		||||
        // load Config class
 | 
			
		||||
        $config = new Smarty_Internal_Config($config_file, $this->smarty, $this);
 | 
			
		||||
        $config->loadConfigVars($sections);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * gets the object of a Smarty variable
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $variable the name of the Smarty variable
 | 
			
		||||
     * @param object $_ptr optional pointer to data object
 | 
			
		||||
     * @param boolean $search_parents search also in parent data
 | 
			
		||||
     * @return object the object of the variable
 | 
			
		||||
     */
 | 
			
		||||
    public function getVariable($_variable, $_ptr = null, $search_parents = true, $error_enable = true)
 | 
			
		||||
    {
 | 
			
		||||
        if ($_ptr === null) {
 | 
			
		||||
            $_ptr = $this;
 | 
			
		||||
        } while ($_ptr !== null) {
 | 
			
		||||
            if (isset($_ptr->tpl_vars[$_variable])) {
 | 
			
		||||
                // found it, return it
 | 
			
		||||
                return $_ptr->tpl_vars[$_variable];
 | 
			
		||||
            } 
 | 
			
		||||
            // not found, try at parent
 | 
			
		||||
            if ($search_parents) {
 | 
			
		||||
                $_ptr = $_ptr->parent;
 | 
			
		||||
            } else {
 | 
			
		||||
                $_ptr = null;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        if (isset(Smarty::$global_tpl_vars[$_variable])) {
 | 
			
		||||
            // found it, return it
 | 
			
		||||
            return Smarty::$global_tpl_vars[$_variable];
 | 
			
		||||
        } 
 | 
			
		||||
        if ($this->smarty->error_unassigned && $error_enable) {
 | 
			
		||||
            throw new SmartyException('Undefined Smarty variable "' . $_variable . '"');
 | 
			
		||||
        } else {
 | 
			
		||||
        	if ($error_enable) {
 | 
			
		||||
				// force a notice
 | 
			
		||||
				$x = $$_variable;
 | 
			
		||||
        	}
 | 
			
		||||
            return new Undefined_Smarty_Variable;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * gets  a config variable
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $variable the name of the config variable
 | 
			
		||||
     * @return mixed the value of the config variable
 | 
			
		||||
     */
 | 
			
		||||
    public function getConfigVariable($_variable)
 | 
			
		||||
    {
 | 
			
		||||
        $_ptr = $this;
 | 
			
		||||
        while ($_ptr !== null) {
 | 
			
		||||
            if (isset($_ptr->config_vars[$_variable])) {
 | 
			
		||||
                // found it, return it
 | 
			
		||||
                return $_ptr->config_vars[$_variable];
 | 
			
		||||
            } 
 | 
			
		||||
            // not found, try at parent
 | 
			
		||||
            $_ptr = $_ptr->parent;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($this->smarty->error_unassigned) {
 | 
			
		||||
            throw new SmartyException('Undefined config variable "' . $_variable . '"');
 | 
			
		||||
        } else {
 | 
			
		||||
			// force a notice
 | 
			
		||||
			$x = $$_variable;
 | 
			
		||||
            return null;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * gets  a stream variable
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $variable the stream of the variable
 | 
			
		||||
     * @return mixed the value of the stream variable
 | 
			
		||||
     */
 | 
			
		||||
    public function getStreamVariable($variable)
 | 
			
		||||
    {
 | 
			
		||||
        $_result = '';
 | 
			
		||||
        if ($fp = fopen($variable, 'r+')) {
 | 
			
		||||
            while (!feof($fp)) {
 | 
			
		||||
                $_result .= fgets($fp);
 | 
			
		||||
            } 
 | 
			
		||||
            fclose($fp);
 | 
			
		||||
            return $_result;
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if ($this->smarty->error_unassigned) {
 | 
			
		||||
            throw new SmartyException('Undefined stream variable "' . $variable . '"');
 | 
			
		||||
        } else {
 | 
			
		||||
            return null;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns a single or all config variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $varname variable name or null
 | 
			
		||||
     * @return string variable value or or array of variables
 | 
			
		||||
     */
 | 
			
		||||
    function getConfigVars($varname = null, $search_parents = true)
 | 
			
		||||
    {
 | 
			
		||||
 | 
			
		||||
        $_ptr = $this;
 | 
			
		||||
        $var_array = array();
 | 
			
		||||
        while ($_ptr !== null) {
 | 
			
		||||
        	if (isset($varname)) {
 | 
			
		||||
            	if (isset($_ptr->config_vars[$varname])) {
 | 
			
		||||
                	return $_ptr->config_vars[$varname];
 | 
			
		||||
                }
 | 
			
		||||
            } else {
 | 
			
		||||
            	$var_array = array_merge($_ptr->config_vars, $var_array);
 | 
			
		||||
        	} 
 | 
			
		||||
             // not found, try at parent
 | 
			
		||||
            if ($search_parents) {
 | 
			
		||||
                $_ptr = $_ptr->parent;
 | 
			
		||||
            } else {
 | 
			
		||||
                $_ptr = null;
 | 
			
		||||
            } 
 | 
			
		||||
    	} 
 | 
			
		||||
        if (isset($varname)) {
 | 
			
		||||
    		return '';
 | 
			
		||||
        } else {
 | 
			
		||||
            return $var_array;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Deassigns a single or all config variables
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $varname variable name or null
 | 
			
		||||
     */
 | 
			
		||||
    function clearConfig($varname = null)
 | 
			
		||||
    {
 | 
			
		||||
        if (isset($varname)) {
 | 
			
		||||
            unset($this->config_vars[$varname]);
 | 
			
		||||
            return;
 | 
			
		||||
        } else {
 | 
			
		||||
            $this->config_vars = array();
 | 
			
		||||
            return;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * class for the Smarty data object
 | 
			
		||||
 * 
 | 
			
		||||
 * The Smarty data object will hold Smarty variables in the current scope
 | 
			
		||||
 * 
 | 
			
		||||
 * @param object $parent tpl_vars next higher level of Smarty variables
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Data extends Smarty_Internal_Data {
 | 
			
		||||
    // array of variable objects
 | 
			
		||||
    public $tpl_vars = array(); 
 | 
			
		||||
    // back pointer to parent object
 | 
			
		||||
    public $parent = null; 
 | 
			
		||||
    // config vars
 | 
			
		||||
    public $config_vars = array(); 
 | 
			
		||||
    // Smarty object
 | 
			
		||||
    public $smarty = null;
 | 
			
		||||
    /**
 | 
			
		||||
     * create Smarty data object
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct ($_parent = null, $smarty = null)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
        if (is_object($_parent)) {
 | 
			
		||||
            // when object set up back pointer
 | 
			
		||||
            $this->parent = $_parent;
 | 
			
		||||
        } elseif (is_array($_parent)) {
 | 
			
		||||
            // set up variable values
 | 
			
		||||
            foreach ($_parent as $_key => $_val) {
 | 
			
		||||
                $this->tpl_vars[$_key] = new Smarty_variable($_val);
 | 
			
		||||
            } 
 | 
			
		||||
        } elseif ($_parent != null) {
 | 
			
		||||
            throw new SmartyException("Wrong type for template variables");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
/**
 | 
			
		||||
 * class for the Smarty variable object
 | 
			
		||||
 * 
 | 
			
		||||
 * This class defines the Smarty variable object
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Variable {
 | 
			
		||||
    // template variable
 | 
			
		||||
    public $value;
 | 
			
		||||
    public $nocache;
 | 
			
		||||
    public $scope;
 | 
			
		||||
    /**
 | 
			
		||||
     * create Smarty variable object
 | 
			
		||||
     * 
 | 
			
		||||
     * @param mixed $value the value to assign
 | 
			
		||||
     * @param boolean $nocache if true any output of this variable will be not cached
 | 
			
		||||
     * @param boolean $scope the scope the variable will have  (local,parent or root)
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct ($value = null, $nocache = false, $scope = Smarty::SCOPE_LOCAL)
 | 
			
		||||
    {
 | 
			
		||||
        $this->value = $value;
 | 
			
		||||
        $this->nocache = $nocache;
 | 
			
		||||
        $this->scope = $scope;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function __toString ()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->value;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * class for undefined variable object
 | 
			
		||||
 * 
 | 
			
		||||
 * This class defines an object for undefined variable handling
 | 
			
		||||
 */
 | 
			
		||||
class Undefined_Smarty_Variable {
 | 
			
		||||
    // return always false
 | 
			
		||||
    public function __get ($name)
 | 
			
		||||
    {
 | 
			
		||||
        if ($name == 'nocache') {
 | 
			
		||||
            return false;
 | 
			
		||||
        } else {
 | 
			
		||||
            return null;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										170
									
								
								site/stackreach/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										170
									
								
								site/stackreach/libs/sysplugins/smarty_internal_debug.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,170 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Debug
 | 
			
		||||
*
 | 
			
		||||
* Class to collect data for the Smarty Debugging Consol
 | 
			
		||||
*
 | 
			
		||||
* @package Smarty
 | 
			
		||||
* @subpackage Debug
 | 
			
		||||
* @author Uwe Tews
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
* Smarty Internal Plugin Debug Class
 | 
			
		||||
*/
 | 
			
		||||
class Smarty_Internal_Debug extends Smarty_Internal_Data {
 | 
			
		||||
	// template data
 | 
			
		||||
	static $template_data = array();
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* Start logging of compile time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function start_compile($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['start_time'] = microtime(true);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* End logging of compile time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function end_compile($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['compile_time'] += microtime(true) - self::$template_data[$key]['start_time'];
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* Start logging of render time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function start_render($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['start_time'] = microtime(true);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* End logging of compile time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function end_render($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['render_time'] += microtime(true) - self::$template_data[$key]['start_time'];
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* Start logging of cache time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function start_cache($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['start_time'] = microtime(true);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* End logging of cache time
 | 
			
		||||
	*/
 | 
			
		||||
	public static function end_cache($template)
 | 
			
		||||
	{
 | 
			
		||||
		$key = self::get_key($template);
 | 
			
		||||
		self::$template_data[$key]['cache_time'] += microtime(true) - self::$template_data[$key]['start_time'];
 | 
			
		||||
	}
 | 
			
		||||
	/**
 | 
			
		||||
	* Opens a window for the Smarty Debugging Consol and display the data
 | 
			
		||||
	*/
 | 
			
		||||
	public static function display_debug($obj)
 | 
			
		||||
	{
 | 
			
		||||
		// prepare information of assigned variables
 | 
			
		||||
		$ptr = self::get_debug_vars($obj);
 | 
			
		||||
		if ($obj instanceof Smarty) {
 | 
			
		||||
			$smarty = $obj;
 | 
			
		||||
		} else {
 | 
			
		||||
			$smarty = $obj->smarty;
 | 
			
		||||
		}
 | 
			
		||||
		$_assigned_vars = $ptr->tpl_vars;
 | 
			
		||||
		ksort($_assigned_vars);
 | 
			
		||||
		$_config_vars = $ptr->config_vars;
 | 
			
		||||
		ksort($_config_vars);
 | 
			
		||||
		$ldelim = $smarty->left_delimiter;
 | 
			
		||||
		$rdelim = $smarty->right_delimiter;
 | 
			
		||||
		$smarty->left_delimiter = '{';
 | 
			
		||||
		$smarty->right_delimiter = '}';
 | 
			
		||||
		$_template = new Smarty_Internal_Template ($smarty->debug_tpl, $smarty);
 | 
			
		||||
		$_template->caching = false;
 | 
			
		||||
		$_template->force_compile = false;
 | 
			
		||||
		$_template->disableSecurity();
 | 
			
		||||
		$_template->cache_id = null;
 | 
			
		||||
		$_template->compile_id = null;
 | 
			
		||||
		if ($obj instanceof Smarty_Internal_Template) {
 | 
			
		||||
			$_template->assign('template_name',$obj->resource_type.':'.$obj->resource_name);
 | 
			
		||||
		}
 | 
			
		||||
		if ($obj instanceof Smarty) {
 | 
			
		||||
			$_template->assign('template_data', self::$template_data);
 | 
			
		||||
		} else {
 | 
			
		||||
			$_template->assign('template_data', null);
 | 
			
		||||
		}
 | 
			
		||||
		$_template->assign('assigned_vars', $_assigned_vars);
 | 
			
		||||
		$_template->assign('config_vars', $_config_vars);
 | 
			
		||||
		$_template->assign('execution_time', microtime(true) - $smarty->start_time);
 | 
			
		||||
		echo $_template->getRenderedTemplate();
 | 
			
		||||
		$smarty->left_delimiter = $ldelim;
 | 
			
		||||
		$smarty->right_delimiter = $rdelim;
 | 
			
		||||
	}
 | 
			
		||||
	/*
 | 
			
		||||
	* Recursively gets variables from all template/data scopes
 | 
			
		||||
	*/
 | 
			
		||||
	public static function get_debug_vars($obj)
 | 
			
		||||
	{
 | 
			
		||||
		$config_vars = $obj->config_vars;
 | 
			
		||||
		$tpl_vars = array();
 | 
			
		||||
		foreach ($obj->tpl_vars as $key => $var) {
 | 
			
		||||
			$tpl_vars[$key] = clone $var;
 | 
			
		||||
			if ($obj instanceof Smarty_Internal_Template) {
 | 
			
		||||
				$tpl_vars[$key]->scope = $obj->resource_type.':'.$obj->resource_name;
 | 
			
		||||
			} elseif ($obj instanceof Smarty_Data) {
 | 
			
		||||
				$tpl_vars[$key]->scope = 'Data object';
 | 
			
		||||
			} else {
 | 
			
		||||
				$tpl_vars[$key]->scope = 'Smarty root';
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if (isset($obj->parent)) {
 | 
			
		||||
			$parent = self::get_debug_vars($obj->parent);
 | 
			
		||||
			$tpl_vars = array_merge($parent->tpl_vars, $tpl_vars);
 | 
			
		||||
			$config_vars = array_merge($parent->config_vars, $config_vars);
 | 
			
		||||
		} else {
 | 
			
		||||
			foreach (Smarty::$global_tpl_vars as $name => $var) {
 | 
			
		||||
				if (!array_key_exists($name, $tpl_vars)) {
 | 
			
		||||
					$clone = clone $var;
 | 
			
		||||
					$clone->scope = 'Global';
 | 
			
		||||
					$tpl_vars[$name] = $clone;
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		return (object) array('tpl_vars' => $tpl_vars, 'config_vars' => $config_vars);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	* get_key
 | 
			
		||||
	*/
 | 
			
		||||
	static function get_key($template)
 | 
			
		||||
	{
 | 
			
		||||
		// calculate Uid if not already done
 | 
			
		||||
		if ($template->templateUid == '') {
 | 
			
		||||
			$template->getTemplateFilepath();
 | 
			
		||||
		}
 | 
			
		||||
		$key = $template->templateUid;
 | 
			
		||||
		if (isset(self::$template_data[$key])) {
 | 
			
		||||
			return $key;
 | 
			
		||||
		} else {
 | 
			
		||||
			self::$template_data[$key]['name'] = $template->getTemplateFilepath();
 | 
			
		||||
			self::$template_data[$key]['compile_time'] = 0;
 | 
			
		||||
			self::$template_data[$key]['render_time'] = 0;
 | 
			
		||||
			self::$template_data[$key]['cache_time'] = 0;
 | 
			
		||||
			return $key;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										89
									
								
								site/stackreach/libs/sysplugins/smarty_internal_filter.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								site/stackreach/libs/sysplugins/smarty_internal_filter.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,89 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Filter
 | 
			
		||||
 * 
 | 
			
		||||
 * External Smarty filter methods
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Class for filter methods
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Filter {
 | 
			
		||||
 | 
			
		||||
    function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers a filter function
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type filter type
 | 
			
		||||
     * @param callback $callback 
 | 
			
		||||
     */
 | 
			
		||||
	public function registerFilter($type, $callback)
 | 
			
		||||
	{
 | 
			
		||||
   		$this->smarty->registered_filters[$type][$this->_get_filter_name($callback)] = $callback;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Unregisters a filter function
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type filter type
 | 
			
		||||
     * @param callback $callback 
 | 
			
		||||
     */
 | 
			
		||||
	public function unregisterFilter($type, $callback)
 | 
			
		||||
	{
 | 
			
		||||
   		$name = $this->_get_filter_name($callback);
 | 
			
		||||
   		if(isset($this->smarty->registered_filters[$type][$name])) {
 | 
			
		||||
      		unset($this->smarty->registered_filters[$type][$name]);
 | 
			
		||||
   		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return internal filter name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param callback $function_name 
 | 
			
		||||
     */
 | 
			
		||||
    public function _get_filter_name($function_name)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_array($function_name)) {
 | 
			
		||||
            $_class_name = (is_object($function_name[0]) ?
 | 
			
		||||
                get_class($function_name[0]) : $function_name[0]);
 | 
			
		||||
            return $_class_name . '_' . $function_name[1];
 | 
			
		||||
        } else {
 | 
			
		||||
            return $function_name;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * load a filter of specified type and name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type filter type
 | 
			
		||||
     * @param string $name filter name
 | 
			
		||||
     * @return bool 
 | 
			
		||||
     */
 | 
			
		||||
    function loadFilter($type, $name)
 | 
			
		||||
    {
 | 
			
		||||
        $_plugin = "smarty_{$type}filter_{$name}";
 | 
			
		||||
        $_filter_name = $_plugin;
 | 
			
		||||
        if ($this->smarty->loadPlugin($_plugin)) {
 | 
			
		||||
            if (class_exists($_plugin, false)) {
 | 
			
		||||
                $_plugin = array($_plugin, 'execute');
 | 
			
		||||
            } 
 | 
			
		||||
            if (is_callable($_plugin)) {
 | 
			
		||||
                return $this->smarty->registered_filters[$type][$_filter_name] = $_plugin;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        throw new SmartyException("{$type}filter \"{$name}\" not callable");
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,67 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Filter Handler
 | 
			
		||||
 * 
 | 
			
		||||
 * Smarty filter handler class
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsInternal
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Class for filter processing
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Filter_Handler {
 | 
			
		||||
    /**
 | 
			
		||||
     * Run filters over content
 | 
			
		||||
     * 
 | 
			
		||||
     * The filters will be lazy loaded if required
 | 
			
		||||
     * class name format: Smarty_FilterType_FilterName
 | 
			
		||||
     * plugin filename format: filtertype.filtername.php
 | 
			
		||||
     * Smarty2 filter plugins could be used
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type the type of filter ('pre','post','output' or 'variable') which shall run
 | 
			
		||||
     * @param string $content the content which shall be processed by the filters
 | 
			
		||||
     * @return string the filtered content
 | 
			
		||||
     */
 | 
			
		||||
    static function runFilter($type, $content, $template, $flag = null)
 | 
			
		||||
    {
 | 
			
		||||
        $output = $content;
 | 
			
		||||
        if ($type != 'variable' || ($template->smarty->variable_filter && $flag !== false) || $flag === true) {
 | 
			
		||||
            // loop over autoload filters of specified type
 | 
			
		||||
            if (!empty($template->smarty->autoload_filters[$type])) {
 | 
			
		||||
                foreach ((array)$template->smarty->autoload_filters[$type] as $name) {
 | 
			
		||||
                    $plugin_name = "Smarty_{$type}filter_{$name}";
 | 
			
		||||
                    if ($template->smarty->loadPlugin($plugin_name)) {
 | 
			
		||||
                        if (function_exists($plugin_name)) {
 | 
			
		||||
                            // use loaded Smarty2 style plugin
 | 
			
		||||
                            $output = $plugin_name($output, $template);
 | 
			
		||||
                        } elseif (class_exists($plugin_name, false)) {
 | 
			
		||||
                            // loaded class of filter plugin
 | 
			
		||||
                            $output = call_user_func(array($plugin_name, 'execute'), $output, $template);
 | 
			
		||||
                        } 
 | 
			
		||||
                    } else {
 | 
			
		||||
                        // nothing found, throw exception
 | 
			
		||||
                        throw new SmartyException("Unable to load filter {$plugin_name}");
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            // loop over registerd filters of specified type
 | 
			
		||||
            if (!empty($template->smarty->registered_filters[$type])) {
 | 
			
		||||
                foreach ($template->smarty->registered_filters[$type] as $key => $name) {
 | 
			
		||||
                    if (is_array($template->smarty->registered_filters[$type][$key])) {
 | 
			
		||||
                        $output = call_user_func($template->smarty->registered_filters[$type][$key], $output, $template);
 | 
			
		||||
                    } else {
 | 
			
		||||
                        $output = $template->smarty->registered_filters[$type][$key]($output, $template);
 | 
			
		||||
                    } 
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // return filtered output
 | 
			
		||||
        return $output;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,40 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Function Call Handler
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsInternal
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This class does call function defined with the {function} tag
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Function_Call_Handler extends Smarty_Internal_Template {
 | 
			
		||||
    static function call ($_name, $_template, $_params, $_hash, $_nocache)
 | 
			
		||||
    {
 | 
			
		||||
        if ($_nocache) {
 | 
			
		||||
            $_function = "smarty_template_function_{$_name}_nocache";
 | 
			
		||||
            $_template->smarty->template_functions[$_name]['called_nocache'] = true;
 | 
			
		||||
        } else {
 | 
			
		||||
            $_function = "smarty_template_function_{$_hash}_{$_name}";
 | 
			
		||||
        } 
 | 
			
		||||
        if (!is_callable($_function)) {
 | 
			
		||||
            $_code = "function {$_function}(\$_smarty_tpl,\$params) {
 | 
			
		||||
    \$saved_tpl_vars = \$_smarty_tpl->tpl_vars;
 | 
			
		||||
    foreach (\$_smarty_tpl->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(trim(\$value,'\''));};
 | 
			
		||||
    foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>";
 | 
			
		||||
            if ($_nocache) {
 | 
			
		||||
                $_code .= preg_replace(array("!<\?php echo \\'/\*%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/|/\*/%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/\\';\?>!",
 | 
			
		||||
                        "!\\\'!"), array('', "'"), $_template->smarty->template_functions[$_name]['compiled']);
 | 
			
		||||
            } else {
 | 
			
		||||
                $_code .= preg_replace("/{$_template->smarty->template_functions[$_name]['nocache_hash']}/", $_template->properties['nocache_hash'], $_template->smarty->template_functions[$_name]['compiled']);
 | 
			
		||||
            } 
 | 
			
		||||
            $_code .= "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars;}";
 | 
			
		||||
            eval($_code);
 | 
			
		||||
        } 
 | 
			
		||||
        $_function($_template, $_params);
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,44 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty read include path plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage PluginsInternal
 | 
			
		||||
 * @author Monte Ohrt 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Read Include Path Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Get_Include_Path {
 | 
			
		||||
    /**
 | 
			
		||||
     * Return full file path from PHP include_path
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $filepath filepath
 | 
			
		||||
     * @return mixed full filepath or false
 | 
			
		||||
     */
 | 
			
		||||
    public static function getIncludePath($filepath)
 | 
			
		||||
    {
 | 
			
		||||
    static $_path_array = null;
 | 
			
		||||
 | 
			
		||||
    if(!isset($_path_array)) {
 | 
			
		||||
        $_ini_include_path = ini_get('include_path');
 | 
			
		||||
 | 
			
		||||
        if(strstr($_ini_include_path,';')) {
 | 
			
		||||
            // windows pathnames
 | 
			
		||||
            $_path_array = explode(';',$_ini_include_path);
 | 
			
		||||
        } else {
 | 
			
		||||
            $_path_array = explode(':',$_ini_include_path);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    foreach ($_path_array as $_include_path) {
 | 
			
		||||
        if (file_exists($_include_path . DS . $filepath)) {
 | 
			
		||||
            return $_include_path . DS . $filepath;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    return false;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,49 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Nocache Insert
 | 
			
		||||
 * 
 | 
			
		||||
 * Compiles the {insert} tag into the cache file
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Compile Insert Class
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Nocache_Insert {
 | 
			
		||||
    /**
 | 
			
		||||
     * Compiles code for the {insert} tag into cache file
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $_function insert function name
 | 
			
		||||
     * @param array $_attr array with paramter
 | 
			
		||||
     * @param object $template template object
 | 
			
		||||
     * @param string $_script script name to load or 'null'
 | 
			
		||||
     * @param string $_assign soptinal variable name
 | 
			
		||||
     * @return string compiled code
 | 
			
		||||
     */
 | 
			
		||||
    static function compile($_function, $_attr, $_template, $_script, $_assign = null)
 | 
			
		||||
    {
 | 
			
		||||
        $_output = '<?php ';
 | 
			
		||||
        if ($_script != 'null') {
 | 
			
		||||
            // script which must be included
 | 
			
		||||
            // code for script file loading
 | 
			
		||||
            $_output .= "require_once '{$_script}';";
 | 
			
		||||
        } 
 | 
			
		||||
        // call insert
 | 
			
		||||
        if (isset($_assign)) {
 | 
			
		||||
            $_output .= "\$_smarty_tpl->assign('{$_assign}' , {$_function} (" . var_export($_attr, true) . ",\$_smarty_tpl), true);?>";
 | 
			
		||||
        } else {
 | 
			
		||||
            $_output .= "echo {$_function}(" . var_export($_attr, true) . ",\$_smarty_tpl);?>";
 | 
			
		||||
        } 
 | 
			
		||||
        $_tpl = $_template;
 | 
			
		||||
        while ($_tpl->parent instanceof Smarty_Internal_Template) {
 | 
			
		||||
            $_tpl = $_tpl->parent;
 | 
			
		||||
        } 
 | 
			
		||||
        return "/*%%SmartyNocache:{$_tpl->properties['nocache_hash']}%%*/" . $_output . "/*/%%SmartyNocache:{$_tpl->properties['nocache_hash']}%%*/";
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										236
									
								
								site/stackreach/libs/sysplugins/smarty_internal_parsetree.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										236
									
								
								site/stackreach/libs/sysplugins/smarty_internal_parsetree.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,236 @@
 | 
			
		||||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Templateparser Parsetrees
 | 
			
		||||
 * 
 | 
			
		||||
 * These are classes to build parsetrees in the template parser
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Thue Kristensen 
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
abstract class _smarty_parsetree {
 | 
			
		||||
  abstract public function to_smarty_php();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * A complete smarty tag.
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_tag extends _smarty_parsetree
 | 
			
		||||
{
 | 
			
		||||
    public $parser;
 | 
			
		||||
    public $data;
 | 
			
		||||
    public $saved_block_nesting;
 | 
			
		||||
    function __construct($parser, $data)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
        $this->saved_block_nesting = $parser->block_nesting_level;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->data;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function assign_to_var()
 | 
			
		||||
    {
 | 
			
		||||
        $var = sprintf('$_tmp%d', ++$this->parser->prefix_number);
 | 
			
		||||
        $this->parser->compiler->prefix_code[] = sprintf('<?php ob_start();?>%s<?php %s=ob_get_clean();?>',
 | 
			
		||||
            $this->data, $var);
 | 
			
		||||
        return $var;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Code fragment inside a tag.
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_code extends _smarty_parsetree {
 | 
			
		||||
    public $parser;
 | 
			
		||||
    public $data;
 | 
			
		||||
    function __construct($parser, $data)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        return sprintf("(%s)", $this->data);
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Double quoted string inside a tag.
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_doublequoted extends _smarty_parsetree {
 | 
			
		||||
    public $parser;
 | 
			
		||||
    public $subtrees = Array();
 | 
			
		||||
    function __construct($parser, _smarty_parsetree $subtree)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->subtrees[] = $subtree;
 | 
			
		||||
        if ($subtree instanceof _smarty_tag) {
 | 
			
		||||
            $this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    function append_subtree(_smarty_parsetree $subtree)
 | 
			
		||||
    {
 | 
			
		||||
        $last_subtree = count($this->subtrees)-1;
 | 
			
		||||
        if ($last_subtree >= 0 && $this->subtrees[$last_subtree] instanceof _smarty_tag && $this->subtrees[$last_subtree]->saved_block_nesting < $this->parser->block_nesting_level) {
 | 
			
		||||
            if ($subtree instanceof _smarty_code) {
 | 
			
		||||
                $this->subtrees[$last_subtree]->data .= '<?php echo ' . $subtree->data . ';?>';
 | 
			
		||||
            } elseif ($subtree instanceof _smarty_dq_content) {
 | 
			
		||||
                $this->subtrees[$last_subtree]->data .= '<?php echo "' . $subtree->data . '";?>';
 | 
			
		||||
            } else {
 | 
			
		||||
                $this->subtrees[$last_subtree]->data .= $subtree->data;
 | 
			
		||||
            } 
 | 
			
		||||
        } else {
 | 
			
		||||
            $this->subtrees[] = $subtree;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($subtree instanceof _smarty_tag) {
 | 
			
		||||
            $this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        $code = '';
 | 
			
		||||
        foreach ($this->subtrees as $subtree) {
 | 
			
		||||
            if ($code !== "") {
 | 
			
		||||
                $code .= ".";
 | 
			
		||||
            } 
 | 
			
		||||
            if ($subtree instanceof _smarty_tag) {
 | 
			
		||||
                $more_php = $subtree->assign_to_var();
 | 
			
		||||
            } else {
 | 
			
		||||
                $more_php = $subtree->to_smarty_php();
 | 
			
		||||
            } 
 | 
			
		||||
 | 
			
		||||
            $code .= $more_php;
 | 
			
		||||
 | 
			
		||||
            if (!$subtree instanceof _smarty_dq_content) {
 | 
			
		||||
                $this->parser->compiler->has_variable_string = true;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        return $code;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Raw chars as part of a double quoted string.
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_dq_content extends _smarty_parsetree {
 | 
			
		||||
    public $data;
 | 
			
		||||
    function __construct($parser, $data)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        return '"' . $this->data . '"';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Template element
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_template_buffer extends _smarty_parsetree {
 | 
			
		||||
    public $subtrees = Array();
 | 
			
		||||
    function __construct($parser)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    function append_subtree(_smarty_parsetree $subtree)
 | 
			
		||||
    {
 | 
			
		||||
        $this->subtrees[] = $subtree;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        $code = '';
 | 
			
		||||
        for ($key = 0, $cnt = count($this->subtrees); $key < $cnt; $key++) {
 | 
			
		||||
            if ($key + 2 < $cnt) {
 | 
			
		||||
                if ($this->subtrees[$key] instanceof _smarty_linebreak && $this->subtrees[$key + 1] instanceof _smarty_tag && $this->subtrees[$key + 1]->data == '' && $this->subtrees[$key + 2] instanceof _smarty_linebreak) {
 | 
			
		||||
                    $key = $key + 1;
 | 
			
		||||
                    continue;
 | 
			
		||||
                } 
 | 
			
		||||
                if (substr($this->subtrees[$key]->data, -1) == '<' && $this->subtrees[$key + 1]->data == '' && substr($this->subtrees[$key + 2]->data, -1) == '?') {
 | 
			
		||||
                    $key = $key + 2;
 | 
			
		||||
                    continue;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            if (substr($code, -1) == '<') {
 | 
			
		||||
                $subtree = $this->subtrees[$key]->to_smarty_php();
 | 
			
		||||
                if (substr($subtree, 0, 1) == '?') {
 | 
			
		||||
                    $code = substr($code, 0, strlen($code)-1) . '<<?php ?>?' . substr($subtree, 1);
 | 
			
		||||
                } elseif ($this->parser->asp_tags && substr($subtree, 0, 1) == '%') {
 | 
			
		||||
                    $code = substr($code, 0, strlen($code)-1) . '<<?php ?>%' . substr($subtree, 1);
 | 
			
		||||
           } else {
 | 
			
		||||
                    $code .= $subtree;
 | 
			
		||||
                } 
 | 
			
		||||
                continue;
 | 
			
		||||
            } 
 | 
			
		||||
            if ($this->parser->asp_tags && substr($code, -1) == '%') {
 | 
			
		||||
                $subtree = $this->subtrees[$key]->to_smarty_php();
 | 
			
		||||
                if (substr($subtree, 0, 1) == '>') {
 | 
			
		||||
                    $code = substr($code, 0, strlen($code)-1) . '%<?php ?>>' . substr($subtree, 1);
 | 
			
		||||
           } else {
 | 
			
		||||
                    $code .= $subtree;
 | 
			
		||||
                } 
 | 
			
		||||
                continue;
 | 
			
		||||
            } 
 | 
			
		||||
            if (substr($code, -1) == '?') {
 | 
			
		||||
                $subtree = $this->subtrees[$key]->to_smarty_php();
 | 
			
		||||
                if (substr($subtree, 0, 1) == '>') {
 | 
			
		||||
                    $code = substr($code, 0, strlen($code)-1) . '?<?php ?>>' . substr($subtree, 1);
 | 
			
		||||
           } else {
 | 
			
		||||
                    $code .= $subtree;
 | 
			
		||||
                } 
 | 
			
		||||
                continue;
 | 
			
		||||
            } 
 | 
			
		||||
            $code .= $this->subtrees[$key]->to_smarty_php();
 | 
			
		||||
        } 
 | 
			
		||||
        return $code;
 | 
			
		||||
    } 
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * template text
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_text extends _smarty_parsetree {
 | 
			
		||||
    public $data;
 | 
			
		||||
    function __construct($parser, $data)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->data;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * template linebreaks
 | 
			
		||||
 */
 | 
			
		||||
class _smarty_linebreak extends _smarty_parsetree {
 | 
			
		||||
    public $data;
 | 
			
		||||
    function __construct($parser, $data)
 | 
			
		||||
    {
 | 
			
		||||
        $this->parser = $parser;
 | 
			
		||||
        $this->data = $data;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    public function to_smarty_php()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->data;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										156
									
								
								site/stackreach/libs/sysplugins/smarty_internal_register.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										156
									
								
								site/stackreach/libs/sysplugins/smarty_internal_register.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,156 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Register
 | 
			
		||||
 * 
 | 
			
		||||
 * External Smarty methods register/unregister
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Class for register/unregister methods
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Register {
 | 
			
		||||
 | 
			
		||||
    function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers plugin to be used in templates
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type plugin type
 | 
			
		||||
     * @param string $tag name of template tag
 | 
			
		||||
     * @param callback $callback PHP callback to register
 | 
			
		||||
     * @param boolean $cacheable if true (default) this fuction is cachable
 | 
			
		||||
     * @param array $cache_attr caching attributes if any
 | 
			
		||||
     */
 | 
			
		||||
 | 
			
		||||
	public function registerPlugin($type, $tag, $callback, $cacheable = true, $cache_attr = null)
 | 
			
		||||
	{
 | 
			
		||||
		if (isset($this->smarty->registered_plugins[$type][$tag])) {
 | 
			
		||||
        	throw new Exception("Plugin tag \"{$tag}\" already registered");
 | 
			
		||||
    	} elseif (!is_callable($callback)) {
 | 
			
		||||
        	throw new Exception("Plugin \"{$tag}\" not callable");
 | 
			
		||||
    	} else {
 | 
			
		||||
       		$this->smarty->registered_plugins[$type][$tag] = array($callback, (bool) $cacheable, (array) $cache_attr);
 | 
			
		||||
    	}
 | 
			
		||||
	} 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Unregister Plugin
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type of plugin
 | 
			
		||||
     * @param string $tag name of plugin
 | 
			
		||||
     */
 | 
			
		||||
    function unregisterPlugin($type, $tag)
 | 
			
		||||
    {
 | 
			
		||||
        if (isset($this->smarty->registered_plugins[$type][$tag])) {
 | 
			
		||||
            unset($this->smarty->registered_plugins[$type][$tag]);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers a resource to fetch a template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type name of resource type
 | 
			
		||||
     * @param array $callback array of callbacks to handle resource
 | 
			
		||||
     */
 | 
			
		||||
 	public function registerResource($type, $callback)
 | 
			
		||||
	{
 | 
			
		||||
       	$this->smarty->registered_resources[$type] = array($callback, false);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Unregisters a resource 
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $type name of resource type
 | 
			
		||||
     */
 | 
			
		||||
   function unregisterResource($type)
 | 
			
		||||
    {
 | 
			
		||||
        if (isset($this->smarty->registered_resources[$type])) {
 | 
			
		||||
            unset($this->smarty->registered_resources[$type]);
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers object to be used in templates
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $object name of template object
 | 
			
		||||
     * @param object $ &$object_impl the referenced PHP object to register
 | 
			
		||||
     * @param mixed $ null | array $allowed list of allowed methods (empty = all)
 | 
			
		||||
     * @param boolean $smarty_args smarty argument format, else traditional
 | 
			
		||||
     * @param mixed $ null | array $block_functs list of methods that are block format
 | 
			
		||||
     */
 | 
			
		||||
    function registerObject($object_name, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array())
 | 
			
		||||
    { 
 | 
			
		||||
        // test if allowed methodes callable
 | 
			
		||||
        if (!empty($allowed)) {
 | 
			
		||||
            foreach ((array)$allowed as $method) {
 | 
			
		||||
                if (!is_callable(array($object_impl, $method))) {
 | 
			
		||||
                    throw new SmartyException("Undefined method '$method' in registered object");
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // test if block methodes callable
 | 
			
		||||
        if (!empty($block_methods)) {
 | 
			
		||||
            foreach ((array)$block_methods as $method) {
 | 
			
		||||
                if (!is_callable(array($object_impl, $method))) {
 | 
			
		||||
                    throw new SmartyException("Undefined method '$method' in registered object");
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        // register the object
 | 
			
		||||
        $this->smarty->registered_objects[$object_name] =
 | 
			
		||||
        array($object_impl, (array)$allowed, (boolean)$smarty_args, (array)$block_methods);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers static classes to be used in templates
 | 
			
		||||
     * 
 | 
			
		||||
     * @param string $class name of template class
 | 
			
		||||
     * @param string $class_impl the referenced PHP class to register
 | 
			
		||||
     */
 | 
			
		||||
    function registerClass($class_name, $class_impl)
 | 
			
		||||
    { 
 | 
			
		||||
        // test if exists
 | 
			
		||||
        if (!class_exists($class_impl)) {
 | 
			
		||||
            throw new SmartyException("Undefined class '$class_impl' in register template class");
 | 
			
		||||
        } 
 | 
			
		||||
        // register the class
 | 
			
		||||
        $this->smarty->registered_classes[$class_name] = $class_impl;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers a default plugin handler
 | 
			
		||||
     * 
 | 
			
		||||
     * @param  $callback mixed string | array $plugin class/methode name
 | 
			
		||||
     */
 | 
			
		||||
    function registerDefaultPluginHandler($callback)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_callable($callback)) {
 | 
			
		||||
            $this->smarty->default_plugin_handler_func = $callback;
 | 
			
		||||
        } else {
 | 
			
		||||
            throw new SmartyException("Default plugin handler '$callback' not callable");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Registers a default template handler
 | 
			
		||||
     * 
 | 
			
		||||
     * @param  $callback mixed string | array class/method name
 | 
			
		||||
     */
 | 
			
		||||
    function registerDefaultTemplateHandler($callback)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_callable($callback)) {
 | 
			
		||||
            $this->smarty->default_template_handler_func = $callback;
 | 
			
		||||
        } else {
 | 
			
		||||
            throw new SmartyException("Default template handler '$callback' not callable");
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,89 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Eval
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the strings as resource for Smarty template
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Eval
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_Eval {
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser';
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = true;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($template)
 | 
			
		||||
    {
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return 'string' as template source is not a file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // no filepath for evaluated strings
 | 
			
		||||
        // return "string" for compiler error messages
 | 
			
		||||
        return 'eval:';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean false as string resources have no timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // evaluated strings must always be compiled and have no timestamp
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Retuen template source from resource name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return template string
 | 
			
		||||
        $_template->template_source = $_template->resource_name;
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean return false as compiled template is not stored
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // no filepath for strings
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,176 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Extends
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the file system as resource for Smarty which does extend a chain of template files templates
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Extends
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_Extends {
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
        $this->_rdl = preg_quote($smarty->right_delimiter);
 | 
			
		||||
        $this->_ldl = preg_quote($smarty->left_delimiter);
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser'; 
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = false;
 | 
			
		||||
    public $allFilepaths = array();
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean result
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($_template)
 | 
			
		||||
    {
 | 
			
		||||
    	  $_template->getTemplateFilepath();
 | 
			
		||||
    	  foreach ($this->allFilepaths as $_filepath) {
 | 
			
		||||
        	if ($_filepath === false) {
 | 
			
		||||
            return false;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string filepath to template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $sha1String = '';
 | 
			
		||||
        $_files = explode('|', $_template->resource_name);
 | 
			
		||||
        foreach ($_files as $_file) {
 | 
			
		||||
            $_filepath = $_template->buildTemplateFilepath ($_file);
 | 
			
		||||
            if ($_filepath !== false) {
 | 
			
		||||
            	if (is_object($_template->smarty->security_policy)) {
 | 
			
		||||
                	$_template->smarty->security_policy->isTrustedResourceDir($_filepath);
 | 
			
		||||
            	} 
 | 
			
		||||
            } 
 | 
			
		||||
            $sha1String .= $_filepath;
 | 
			
		||||
            $this->allFilepaths[$_file] = $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_template->templateUid = sha1($sha1String);
 | 
			
		||||
        return $_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return integer timestamp of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    {
 | 
			
		||||
        return filemtime($_template->getTemplateFilepath());
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Read template source from file
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $this->template = $_template;
 | 
			
		||||
        $_files = array_reverse($this->allFilepaths);
 | 
			
		||||
    		$_first = reset($_files);
 | 
			
		||||
    		$_last = end($_files);
 | 
			
		||||
        foreach ($_files as $_file => $_filepath) {
 | 
			
		||||
        		if ($_filepath === false) {
 | 
			
		||||
            		throw new SmartyException("Unable to load template 'file : {$_file}'");
 | 
			
		||||
        		}
 | 
			
		||||
            // read template file
 | 
			
		||||
            if ($_filepath != $_first) {
 | 
			
		||||
                $_template->properties['file_dependency'][sha1($_filepath)] = array($_filepath, filemtime($_filepath),'file');
 | 
			
		||||
            } 
 | 
			
		||||
            $_template->template_filepath = $_filepath;
 | 
			
		||||
            $_content = file_get_contents($_filepath);
 | 
			
		||||
            if ($_filepath != $_last) {
 | 
			
		||||
                if (preg_match_all("!({$this->_ldl}block\s(.+?){$this->_rdl})!", $_content, $_open) !=
 | 
			
		||||
                        preg_match_all("!({$this->_ldl}/block{$this->_rdl})!", $_content, $_close)) {
 | 
			
		||||
                    $this->smarty->triggerError("unmatched {block} {/block} pairs in file '$_filepath'");
 | 
			
		||||
                } 
 | 
			
		||||
                preg_match_all("!{$this->_ldl}block\s(.+?){$this->_rdl}|{$this->_ldl}/block{$this->_rdl}!", $_content, $_result, PREG_OFFSET_CAPTURE);
 | 
			
		||||
                $_result_count = count($_result[0]);
 | 
			
		||||
                $_start = 0;
 | 
			
		||||
                while ($_start < $_result_count) {
 | 
			
		||||
                    $_end = 0;
 | 
			
		||||
                    $_level = 1;
 | 
			
		||||
                    while ($_level != 0) {
 | 
			
		||||
                        $_end++;
 | 
			
		||||
                        if (!strpos($_result[0][$_start + $_end][0], '/')) {
 | 
			
		||||
                            $_level++;
 | 
			
		||||
                        } else {
 | 
			
		||||
                            $_level--;
 | 
			
		||||
                        } 
 | 
			
		||||
                    } 
 | 
			
		||||
                    $_block_content = str_replace($this->smarty->left_delimiter . '$smarty.block.parent' . $this->smarty->right_delimiter, '%%%%SMARTY_PARENT%%%%',
 | 
			
		||||
                        substr($_content, $_result[0][$_start][1] + strlen($_result[0][$_start][0]), $_result[0][$_start + $_end][1] - $_result[0][$_start][1] - + strlen($_result[0][$_start][0])));
 | 
			
		||||
                    Smarty_Internal_Compile_Block::saveBlockData($_block_content, $_result[0][$_start][0], $_template, $_filepath);
 | 
			
		||||
                    $_start = $_start + $_end + 1;
 | 
			
		||||
                } 
 | 
			
		||||
            } else {
 | 
			
		||||
                $_template->template_source = $_content;
 | 
			
		||||
                return true;
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return path to compiled template
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
 | 
			
		||||
        $_files = explode('|', $_template->resource_name); 
 | 
			
		||||
        // calculate Uid if not already done
 | 
			
		||||
        if ($_template->templateUid == '') {
 | 
			
		||||
            $_template->getTemplateFilepath();
 | 
			
		||||
        } 
 | 
			
		||||
        $_filepath = $_template->templateUid; 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($_template->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_template->caching) {
 | 
			
		||||
            $_cache = '.cache';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache = '';
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir = $_template->smarty->compile_dir;
 | 
			
		||||
        if (substr($_compile_dir, -1) != DS) {
 | 
			
		||||
            $_compile_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_compile_dir . $_filepath . '.' . $_template->resource_type . '.' . basename($_files[count($_files)-1]) . $_cache . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,128 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource File
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the file system as resource for Smarty templates
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/** 
 | 
			
		||||
 * Smarty Internal Plugin Resource File
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_File {
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser'; 
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = false;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($template)
 | 
			
		||||
    {
 | 
			
		||||
        if ($template->getTemplateFilepath() === false) {
 | 
			
		||||
            return false;
 | 
			
		||||
        } else {
 | 
			
		||||
            return true;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string filepath to template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_filepath = $_template->buildTemplateFilepath ();
 | 
			
		||||
 | 
			
		||||
        if ($_filepath !== false) {
 | 
			
		||||
            if (is_object($_template->smarty->security_policy)) {
 | 
			
		||||
                $_template->smarty->security_policy->isTrustedResourceDir($_filepath);
 | 
			
		||||
            } 
 | 
			
		||||
        } 
 | 
			
		||||
        $_template->templateUid = sha1($_filepath);
 | 
			
		||||
        return $_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return integer timestamp of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    {
 | 
			
		||||
        return filemtime($_template->getTemplateFilepath());
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Read template source from file
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // read template file
 | 
			
		||||
        if (file_exists($_tfp = $_template->getTemplateFilepath())) {
 | 
			
		||||
            $_template->template_source = file_get_contents($_tfp);
 | 
			
		||||
            return true;
 | 
			
		||||
        } else {
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return path to compiled template
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
 | 
			
		||||
        // calculate Uid if not already done
 | 
			
		||||
        if ($_template->templateUid == '') {
 | 
			
		||||
            $_template->getTemplateFilepath();
 | 
			
		||||
        } 
 | 
			
		||||
        $_filepath = $_template->templateUid; 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($_template->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_template->caching) {
 | 
			
		||||
            $_cache = '.cache';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache = '';
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir = $_template->smarty->compile_dir;
 | 
			
		||||
        if (strpos('/\\', substr($_compile_dir, -1)) === false) {
 | 
			
		||||
            $_compile_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_compile_dir . $_filepath . '.' . $_template->resource_type . '.' . basename($_template->resource_name) . $_cache . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										127
									
								
								site/stackreach/libs/sysplugins/smarty_internal_resource_php.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								site/stackreach/libs/sysplugins/smarty_internal_resource_php.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,127 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource PHP
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the file system as resource for PHP templates
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource PHP
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_PHP {
 | 
			
		||||
    /**
 | 
			
		||||
     * Class constructor, enable short open tags
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
        ini_set('short_open_tag', '1');
 | 
			
		||||
    } 
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = false;
 | 
			
		||||
    public $isEvaluated = false;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($template)
 | 
			
		||||
    {
 | 
			
		||||
        if ($template->getTemplateFilepath() === false) {
 | 
			
		||||
            return false;
 | 
			
		||||
        } else {
 | 
			
		||||
            return true;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string filepath to template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_filepath = $_template->buildTemplateFilepath ();
 | 
			
		||||
 | 
			
		||||
        if (is_object($_template->smarty->security_policy)) {
 | 
			
		||||
            $_template->smarty->security_policy->isTrustedResourceDir($_filepath);
 | 
			
		||||
        } 
 | 
			
		||||
        $_template->templateUid = sha1($_filepath);
 | 
			
		||||
        return $_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return integer timestamp of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    {
 | 
			
		||||
        return filemtime($_template->getTemplateFilepath());
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Read template source from file
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    {
 | 
			
		||||
        if (file_exists($_tfp = $_template->getTemplateFilepath())) {
 | 
			
		||||
            $_template->template_source = file_get_contents($_tfp);
 | 
			
		||||
            return true;
 | 
			
		||||
        } else {
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean return false as compiled template is not stored
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // no filepath for PHP templates
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * renders the PHP template
 | 
			
		||||
     */
 | 
			
		||||
    public function renderUncompiled($_smarty_template)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->smarty->allow_php_templates) {
 | 
			
		||||
            throw new SmartyException("PHP templates are disabled");
 | 
			
		||||
        } 
 | 
			
		||||
        if ($this->getTemplateFilepath($_smarty_template) === false) {
 | 
			
		||||
            throw new SmartyException("Unable to load template \"{$_smarty_template->resource_type} : {$_smarty_template->resource_name}\"");
 | 
			
		||||
        } 
 | 
			
		||||
        // prepare variables
 | 
			
		||||
        $_smarty_ptr = $_smarty_template;
 | 
			
		||||
        do {
 | 
			
		||||
            foreach ($_smarty_ptr->tpl_vars as $_smarty_var => $_smarty_var_object) {
 | 
			
		||||
                if (isset($_smarty_var_object->value)) {
 | 
			
		||||
                    $$_smarty_var = $_smarty_var_object->value;
 | 
			
		||||
                } 
 | 
			
		||||
            } 
 | 
			
		||||
            $_smarty_ptr = $_smarty_ptr->parent;
 | 
			
		||||
        } while ($_smarty_ptr != null);
 | 
			
		||||
        unset ($_smarty_var, $_smarty_var_object, $_smarty_ptr); 
 | 
			
		||||
        // include PHP template
 | 
			
		||||
        include($this->getTemplateFilepath($_smarty_template));
 | 
			
		||||
        return;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,143 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Registered
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the registered resource for Smarty template
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Registered
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_Registered {
 | 
			
		||||
    public function __construct($template, $resource_type = null)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $template->smarty;
 | 
			
		||||
        if (isset($resource_type)) {
 | 
			
		||||
        	$template->smarty->registerResource($resource_type,
 | 
			
		||||
        		array("smarty_resource_{$resource_type}_source",
 | 
			
		||||
            		"smarty_resource_{$resource_type}_timestamp",
 | 
			
		||||
                	"smarty_resource_{$resource_type}_secure",
 | 
			
		||||
                	"smarty_resource_{$resource_type}_trusted"));
 | 
			
		||||
        }
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser';
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = false;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($_template)
 | 
			
		||||
    {
 | 
			
		||||
        if (is_integer($_template->getTemplateTimestamp())) {
 | 
			
		||||
            return true;
 | 
			
		||||
        } else {
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return 'string' as template source is not a file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        $_filepath = $_template->resource_type .':'.$_template->resource_name;
 | 
			
		||||
        $_template->templateUid = sha1($_filepath);
 | 
			
		||||
        return $_filepath;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp of template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return int  timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return timestamp
 | 
			
		||||
        $time_stamp = false;
 | 
			
		||||
        call_user_func_array($this->smarty->registered_resources[$_template->resource_type][0][1],
 | 
			
		||||
            array($_template->resource_name, &$time_stamp, $this->smarty));
 | 
			
		||||
        return is_numeric($time_stamp) ? (int)$time_stamp : $time_stamp;
 | 
			
		||||
    }
 | 
			
		||||
     
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp of template source by type and name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return int  timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestampTypeName($_resource_type, $_resource_name)
 | 
			
		||||
    { 
 | 
			
		||||
        // return timestamp
 | 
			
		||||
        $time_stamp = false;
 | 
			
		||||
        call_user_func_array($this->smarty->registered_resources[$_resource_type][0][1],
 | 
			
		||||
            array($_resource_name, &$time_stamp, $this->smarty));
 | 
			
		||||
        return is_numeric($time_stamp) ? (int)$time_stamp : $time_stamp;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Retuen template source from resource name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return template string
 | 
			
		||||
        return call_user_func_array($this->smarty->registered_resources[$_template->resource_type][0][0],
 | 
			
		||||
            array($_template->resource_name, &$_template->template_source, $this->smarty));
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean return false as compiled template is not stored
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        $_compile_id =  isset($_template->compile_id) ? preg_replace('![^\w\|]+!','_',$_template->compile_id) : null;
 | 
			
		||||
        // calculate Uid if not already done
 | 
			
		||||
        if ($_template->templateUid == '') {
 | 
			
		||||
            $_template->getTemplateFilepath();
 | 
			
		||||
        } 
 | 
			
		||||
        $_filepath = $_template->templateUid; 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($_template->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_template->caching) {
 | 
			
		||||
            $_cache = '.cache';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache = '';
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir = $_template->smarty->compile_dir;
 | 
			
		||||
        if (strpos('/\\', substr($_compile_dir, -1)) === false) {
 | 
			
		||||
            $_compile_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_compile_dir . $_filepath . '.' . $_template->resource_type . '.' . basename($_template->resource_name) . $_cache . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,99 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Stream
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the streams as resource for Smarty template
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource Stream
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_Stream {
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser';
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = true;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($template)
 | 
			
		||||
    {
 | 
			
		||||
        if ($template->getTemplateSource() == '') {
 | 
			
		||||
            return false;
 | 
			
		||||
        } else {
 | 
			
		||||
            return true;
 | 
			
		||||
        } 
 | 
			
		||||
    } 
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return 'string' as template source is not a file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // no filepath for strings
 | 
			
		||||
        // return resource name for compiler error messages
 | 
			
		||||
        return str_replace(':', '://', $_template->template_resource);
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean false as string resources have no timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // strings must always be compiled and have no timestamp
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Retuen template source from resource name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return template string
 | 
			
		||||
        $_template->template_source = '';
 | 
			
		||||
        $fp = fopen(str_replace(':', '://', $_template->template_resource),'r+');
 | 
			
		||||
        while (!feof($fp)) {
 | 
			
		||||
            $_template->template_source .= fgets($fp);
 | 
			
		||||
        } 
 | 
			
		||||
        fclose($fp);
 | 
			
		||||
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean return false as compiled template is not stored
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // no filepath for strings
 | 
			
		||||
        return false;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,133 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource String
 | 
			
		||||
 * 
 | 
			
		||||
 * Implements the strings as resource for Smarty template
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage TemplateResources
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Resource String
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_Resource_String {
 | 
			
		||||
    public function __construct($smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
    } 
 | 
			
		||||
    // classes used for compiling Smarty templates from file resource
 | 
			
		||||
    public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
 | 
			
		||||
    public $template_lexer_class = 'Smarty_Internal_Templatelexer';
 | 
			
		||||
    public $template_parser_class = 'Smarty_Internal_Templateparser';
 | 
			
		||||
    // properties
 | 
			
		||||
    public $usesCompiler = true;
 | 
			
		||||
    public $isEvaluated = false;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Return flag if template source is existing
 | 
			
		||||
     * 
 | 
			
		||||
     * @return boolean true
 | 
			
		||||
     */
 | 
			
		||||
    public function isExisting($template)
 | 
			
		||||
    {
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string return 'string' as template source is not a file
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateFilepath($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        $_template->templateUid = sha1($_template->resource_name);
 | 
			
		||||
        // no filepath for strings
 | 
			
		||||
        // return "string" for compiler error messages
 | 
			
		||||
        return 'string:';
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp to template source
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean false as string resources have no timestamp
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestamp($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        if ($this->isEvaluated) {
 | 
			
		||||
        	//must always be compiled and have no timestamp
 | 
			
		||||
        	return false;
 | 
			
		||||
        } else {
 | 
			
		||||
        	return 0;
 | 
			
		||||
        }
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get timestamp of template source by type and name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return int  timestamp (always 0)
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateTimestampTypeName($_resource_type, $_resource_name)
 | 
			
		||||
    { 
 | 
			
		||||
        // return timestamp 0
 | 
			
		||||
        return 0;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Retuen template source from resource name
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return string content of template source
 | 
			
		||||
     */
 | 
			
		||||
    public function getTemplateSource($_template)
 | 
			
		||||
    { 
 | 
			
		||||
        // return template string
 | 
			
		||||
        $_template->template_source = $_template->resource_name;
 | 
			
		||||
        return true;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Get filepath to compiled template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param object $_template template object
 | 
			
		||||
     * @return boolean return false as compiled template is not stored
 | 
			
		||||
     */
 | 
			
		||||
    public function getCompiledFilepath($_template)
 | 
			
		||||
    {
 | 
			
		||||
        $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
 | 
			
		||||
        // calculate Uid if not already done
 | 
			
		||||
        if ($_template->templateUid == '') {
 | 
			
		||||
            $_template->getTemplateFilepath();
 | 
			
		||||
        } 
 | 
			
		||||
        $_filepath = $_template->templateUid; 
 | 
			
		||||
        // if use_sub_dirs, break file into directories
 | 
			
		||||
        if ($_template->smarty->use_sub_dirs) {
 | 
			
		||||
            $_filepath = substr($_filepath, 0, 2) . DS
 | 
			
		||||
             . substr($_filepath, 2, 2) . DS
 | 
			
		||||
             . substr($_filepath, 4, 2) . DS
 | 
			
		||||
             . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
 | 
			
		||||
        if (isset($_compile_id)) {
 | 
			
		||||
            $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
 | 
			
		||||
        } 
 | 
			
		||||
        if ($_template->caching) {
 | 
			
		||||
            $_cache = '.cache';
 | 
			
		||||
        } else {
 | 
			
		||||
            $_cache = '';
 | 
			
		||||
        } 
 | 
			
		||||
        $_compile_dir = $_template->smarty->compile_dir;
 | 
			
		||||
        if (strpos('/\\', substr($_compile_dir, -1)) === false) {
 | 
			
		||||
            $_compile_dir .= DS;
 | 
			
		||||
        } 
 | 
			
		||||
        return $_compile_dir . $_filepath . '.' . $_template->resource_type . $_cache . '.php';
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
@@ -0,0 +1,72 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Smarty Internal Plugin Smarty Template Compiler Base
 | 
			
		||||
 * 
 | 
			
		||||
 * This file contains the basic classes and methodes for compiling Smarty templates with lexer/parser
 | 
			
		||||
 * 
 | 
			
		||||
 * @package Smarty
 | 
			
		||||
 * @subpackage Compiler
 | 
			
		||||
 * @author Uwe Tews 
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
require_once("smarty_internal_parsetree.php");
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Class SmartyTemplateCompiler
 | 
			
		||||
 */
 | 
			
		||||
class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCompilerBase {
 | 
			
		||||
    // array of vars which can be compiled in local scope
 | 
			
		||||
    public $local_var = array();
 | 
			
		||||
    /**
 | 
			
		||||
     * Initialize compiler
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct($lexer_class, $parser_class, $smarty)
 | 
			
		||||
    {
 | 
			
		||||
        $this->smarty = $smarty;
 | 
			
		||||
        parent::__construct(); 
 | 
			
		||||
        // get required plugins
 | 
			
		||||
        $this->lexer_class = $lexer_class;
 | 
			
		||||
        $this->parser_class = $parser_class;
 | 
			
		||||
    } 
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Methode to compile a Smarty template
 | 
			
		||||
     * 
 | 
			
		||||
     * @param  $_content template source
 | 
			
		||||
     * @return bool true if compiling succeeded, false if it failed
 | 
			
		||||
     */
 | 
			
		||||
    protected function doCompile($_content)
 | 
			
		||||
    {
 | 
			
		||||
        /* here is where the compiling takes place. Smarty
 | 
			
		||||
       tags in the templates are replaces with PHP code,
 | 
			
		||||
       then written to compiled files. */ 
 | 
			
		||||
        // init the lexer/parser to compile the template
 | 
			
		||||
        $this->lex = new $this->lexer_class($_content, $this);
 | 
			
		||||
        $this->parser = new $this->parser_class($this->lex, $this);
 | 
			
		||||
        if (isset($this->smarty->_parserdebug)) $this->parser->PrintTrace(); 
 | 
			
		||||
        // get tokens from lexer and parse them
 | 
			
		||||
        while ($this->lex->yylex() && !$this->abort_and_recompile) {
 | 
			
		||||
            if (isset($this->smarty->_parserdebug)) echo "<pre>Line {$this->lex->line} Parsing  {$this->parser->yyTokenName[$this->lex->token]} Token " . htmlentities($this->lex->value) . "</pre>";
 | 
			
		||||
            $this->parser->doParse($this->lex->token, $this->lex->value);
 | 
			
		||||
        } 
 | 
			
		||||
 | 
			
		||||
        if ($this->abort_and_recompile) {
 | 
			
		||||
            // exit here on abort
 | 
			
		||||
            return false;
 | 
			
		||||
        } 
 | 
			
		||||
        // finish parsing process
 | 
			
		||||
        $this->parser->doParse(0, 0); 
 | 
			
		||||
        // check for unclosed tags
 | 
			
		||||
        if (count($this->_tag_stack) > 0) {
 | 
			
		||||
            // get stacked info
 | 
			
		||||
            list($_open_tag, $_data) = array_pop($this->_tag_stack);
 | 
			
		||||
            $this->trigger_template_error("unclosed {" . $_open_tag . "} tag");
 | 
			
		||||
        } 
 | 
			
		||||
        // return compiled code
 | 
			
		||||
        // return str_replace(array("? >\n<?php","? ><?php"), array('',''), $this->parser->retvalue);
 | 
			
		||||
        return $this->parser->retvalue;
 | 
			
		||||
    } 
 | 
			
		||||
} 
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user