|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Smarty Internal Plugin Config File Compiler
|
|
|
|
* This is the config file compiler class. It calls the lexer and parser to
|
|
|
|
* perform the compiling.
|
|
|
|
*
|
|
|
|
* @package Smarty
|
|
|
|
* @subpackage Config
|
|
|
|
* @author Uwe Tews
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Main config file compiler class
|
|
|
|
*
|
|
|
|
* @package Smarty
|
|
|
|
* @subpackage Config
|
|
|
|
*/
|
|
|
|
class Smarty_Internal_Config_File_Compiler
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Lexer object
|
|
|
|
*
|
|
|
|
* @var object
|
|
|
|
*/
|
|
|
|
public $lex;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parser object
|
|
|
|
*
|
|
|
|
* @var object
|
|
|
|
*/
|
|
|
|
public $parser;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Smarty object
|
|
|
|
*
|
|
|
|
* @var Smarty object
|
|
|
|
*/
|
|
|
|
public $smarty;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Smarty object
|
|
|
|
*
|
|
|
|
* @var Smarty_Internal_Config object
|
|
|
|
*/
|
|
|
|
public $config;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compiled config data sections and variables
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $config_data = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize compiler
|
|
|
|
*
|
|
|
|
* @param Smarty $smarty base instance
|
|
|
|
*/
|
|
|
|
public function __construct($smarty)
|
|
|
|
{
|
|
|
|
$this->smarty = $smarty;
|
|
|
|
$this->config_data['sections'] = array();
|
|
|
|
$this->config_data['vars'] = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Method to compile a Smarty template.
|
|
|
|
*
|
|
|
|
* @param Smarty_Internal_Config $config config object
|
|
|
|
*
|
|
|
|
* @return bool true if compiling succeeded, false if it failed
|
|
|
|
*/
|
|
|
|
public function compileSource(Smarty_Internal_Config $config)
|
|
|
|
{
|
|
|
|
/* here is where the compiling takes place. Smarty
|
|
|
|
tags in the templates are replaces with PHP code,
|
|
|
|
then written to compiled files. */
|
|
|
|
$this->config = $config;
|
|
|
|
// get config file source
|
|
|
|
$_content = $config->source->content . "\n";
|
|
|
|
// on empty template just return
|
|
|
|
if ($_content == '') {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
// init the lexer/parser to compile the config file
|
|
|
|
$lex = new Smarty_Internal_Configfilelexer($_content, $this);
|
|
|
|
$parser = new Smarty_Internal_Configfileparser($lex, $this);
|
|
|
|
|
|
|
|
if (function_exists('mb_internal_encoding') && ((int) ini_get('mbstring.func_overload')) & 2) {
|
|
|
|
$mbEncoding = mb_internal_encoding();
|
|
|
|
mb_internal_encoding('ASCII');
|
|
|
|
} else {
|
|
|
|
$mbEncoding = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if ($this->smarty->_parserdebug) {
|
|
|
|
$parser->PrintTrace();
|
|
|
|
}
|
|
|
|
// get tokens from lexer and parse them
|
|
|
|
while ($lex->yylex()) {
|
|
|
|
if ($this->smarty->_parserdebug) {
|
|
|
|
echo "<br>Parsing {$parser->yyTokenName[$lex->token]} Token {$lex->value} Line {$lex->line} \n";
|
|
|
|
}
|
|
|
|
$parser->doParse($lex->token, $lex->value);
|
|
|
|
}
|
|
|
|
// finish parsing process
|
|
|
|
$parser->doParse(0, 0);
|
|
|
|
|
|
|
|
if ($mbEncoding) {
|
|
|
|
mb_internal_encoding($mbEncoding);
|
|
|
|
}
|
|
|
|
|
|
|
|
$config->compiled_config = '<?php $_config_vars = ' . var_export($this->config_data, true) . '; ?>';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* display compiler error messages without dying
|
|
|
|
* If parameter $args is empty it is a parser detected syntax error.
|
|
|
|
* In this case the parser is called to obtain information about expected tokens.
|
|
|
|
* If parameter $args contains a string this is used as error message
|
|
|
|
*
|
|
|
|
* @param string $args individual error message or null
|
|
|
|
*
|
|
|
|
* @throws SmartyCompilerException
|
|
|
|
*/
|
|
|
|
public function trigger_config_file_error($args = null)
|
|
|
|
{
|
|
|
|
$this->lex = Smarty_Internal_Configfilelexer::instance();
|
|
|
|
$this->parser = Smarty_Internal_Configfileparser::instance();
|
|
|
|
// get template source line which has error
|
|
|
|
$line = $this->lex->line;
|
|
|
|
if (isset($args)) {
|
|
|
|
// $line--;
|
|
|
|
}
|
|
|
|
$match = preg_split("/\n/", $this->lex->data);
|
|
|
|
$error_text = "Syntax error in config file '{$this->config->source->filepath}' on line {$line} '{$match[$line - 1]}' ";
|
|
|
|
if (isset($args)) {
|
|
|
|
// individual error message
|
|
|
|
$error_text .= $args;
|
|
|
|
} else {
|
|
|
|
// expected token from parser
|
|
|
|
foreach ($this->parser->yy_get_expected_tokens($this->parser->yymajor) as $token) {
|
|
|
|
$exp_token = $this->parser->yyTokenName[$token];
|
|
|
|
if (isset($this->lex->smarty_token_names[$exp_token])) {
|
|
|
|
// token type from lexer
|
|
|
|
$expect[] = '"' . $this->lex->smarty_token_names[$exp_token] . '"';
|
|
|
|
} else {
|
|
|
|
// otherwise internal token name
|
|
|
|
$expect[] = $this->parser->yyTokenName[$token];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// output parser error message
|
|
|
|
$error_text .= ' - Unexpected "' . $this->lex->value . '", expected one of: ' . implode(' , ', $expect);
|
|
|
|
}
|
|
|
|
throw new SmartyCompilerException($error_text);
|
|
|
|
}
|
|
|
|
}
|