add new methods and optimizations

This commit is contained in:
Uwe Tews
2015-07-01 03:23:40 +02:00
parent 8567f08248
commit 2762d81d93
2 changed files with 62 additions and 36 deletions

View File

@@ -8,10 +8,6 @@
* @author Uwe Tews * @author Uwe Tews
*/ */
/**
* @ignore
*/
//include 'smarty_internal_parsetree.php';
/** /**
* Class SmartyTemplateCompiler * Class SmartyTemplateCompiler
@@ -35,20 +31,6 @@ class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCom
*/ */
public $parser_class; public $parser_class;
/**
* Lexer object
*
* @var object
*/
public $lex;
/**
* Parser object
*
* @var object
*/
public $parser;
/** /**
* array of vars which can be compiled in local scope * array of vars which can be compiled in local scope
* *
@@ -76,8 +58,10 @@ class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCom
* method to compile a Smarty template * method to compile a Smarty template
* *
* @param mixed $_content template source * @param mixed $_content template source
* @param bool $isTemplateSource
* *
* @return bool true if compiling succeeded, false if it failed * @return bool true if compiling succeeded, false if it failed
* @throws \SmartyCompilerException
*/ */
protected function doCompile($_content, $isTemplateSource = false) protected function doCompile($_content, $isTemplateSource = false)
{ {
@@ -126,7 +110,6 @@ class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCom
$this->trigger_template_error("unclosed {$this->smarty->left_delimiter}" . $openTag . "{$this->smarty->right_delimiter} tag"); $this->trigger_template_error("unclosed {$this->smarty->left_delimiter}" . $openTag . "{$this->smarty->right_delimiter} tag");
} }
// return compiled code // return compiled code
// return str_replace(array("? >\n<?php","? ><?php"), array('',''), $this->parser->retvalue);
return $this->parser->retvalue; return $this->parser->retvalue;
} }
} }

View File

@@ -25,6 +25,19 @@ abstract class Smarty_Internal_TemplateCompilerBase
*/ */
public $smarty = null; public $smarty = null;
/**
* Lexer object
*
* @var object
*/
public $lex;
/**
* Parser object
*
* @var object
*/
public $parser;
/** /**
* hash for nocache sections * hash for nocache sections
* *
@@ -40,11 +53,11 @@ abstract class Smarty_Internal_TemplateCompilerBase
public $suppressNocacheProcessing = false; public $suppressNocacheProcessing = false;
/** /**
* compile tag objects * compile tag objects cache
* *
* @var array * @var array
*/ */
public static $_tag_objects = array(); public $_tag_objects = array();
/** /**
* tag stack * tag stack
@@ -295,10 +308,11 @@ abstract class Smarty_Internal_TemplateCompilerBase
* method to compile a Smarty template * method to compile a Smarty template
* *
* @param mixed $_content template source * @param mixed $_content template source
* @param bool $isTemplateSource
* *
* @return bool true if compiling succeeded, false if it failed * @return bool true if compiling succeeded, false if it failed
*/ */
abstract protected function doCompile($_content); abstract protected function doCompile($_content, $isTemplateSource = false);
/** /**
* Initialize compiler * Initialize compiler
@@ -356,7 +370,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
} }
$no_sources = count($this->sources); $no_sources = count($this->sources);
$this->parent_compiler->template->properties['file_dependency'][$this->template->source->uid] = array($this->template->source->filepath, $this->parent_compiler->template->properties['file_dependency'][$this->template->source->uid] = array($this->template->source->filepath,
$this->template->source->timestamp, $this->template->source->type); $this->template->source->getTimeStamp(), $this->template->source->type);
$loop ++; $loop ++;
if ($no_sources) { if ($no_sources) {
$this->inheritance_child = true; $this->inheritance_child = true;
@@ -374,7 +388,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
// get template source // get template source
$_content = $this->template->source->content; $_content = $this->template->source->content;
if ($_content != '') { if ($_content != '') {
// run prefilter if required // run pre filter if required
if ((isset($this->smarty->autoload_filters['pre']) || isset($this->smarty->registered_filters['pre'])) && !$this->suppressFilter) { if ((isset($this->smarty->autoload_filters['pre']) || isset($this->smarty->registered_filters['pre'])) && !$this->suppressFilter) {
$_content = Smarty_Internal_Filter_Handler::runFilter('pre', $_content, $template); $_content = Smarty_Internal_Filter_Handler::runFilter('pre', $_content, $template);
} }
@@ -391,7 +405,6 @@ abstract class Smarty_Internal_TemplateCompilerBase
$this->smarty->_current_file = $this->template->source->filepath; $this->smarty->_current_file = $this->template->source->filepath;
// free memory // free memory
unset($this->parser->root_buffer, $this->parser->current_buffer, $this->parser, $this->lex); unset($this->parser->root_buffer, $this->parser->current_buffer, $this->parser, $this->lex);
self::$_tag_objects = array();
// return compiled code to template object // return compiled code to template object
$merged_code = ''; $merged_code = '';
if (!empty($this->mergedSubTemplatesCode)) { if (!empty($this->mergedSubTemplatesCode)) {
@@ -399,7 +412,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
$merged_code .= $code; $merged_code .= $code;
} }
} }
// run postfilter if required on compiled template code // run post filter if required on compiled template code
if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter && $_compiled_code != '') { if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter && $_compiled_code != '') {
$_compiled_code = Smarty_Internal_Filter_Handler::runFilter('post', $_compiled_code, $template); $_compiled_code = Smarty_Internal_Filter_Handler::runFilter('post', $_compiled_code, $template);
} }
@@ -409,7 +422,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
$_compiled_code = $template_header . Smarty_Internal_Extension_CodeFrame::create($template, $_compiled_code) . $merged_code; $_compiled_code = $template_header . Smarty_Internal_Extension_CodeFrame::create($template, $_compiled_code) . $merged_code;
} }
if (!empty($this->templateFunctionCode)) { if (!empty($this->templateFunctionCode)) {
// run postfilter if required on compiled template code // run post filter if required on compiled template code
if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter) { if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter) {
$_compiled_code .= Smarty_Internal_Filter_Handler::runFilter('post', $this->templateFunctionCode, $template); $_compiled_code .= Smarty_Internal_Filter_Handler::runFilter('post', $this->templateFunctionCode, $template);
} else { } else {
@@ -475,7 +488,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
if (in_array("'nocache'", $args) || in_array(array('nocache' => 'true'), $args) || in_array(array('nocache' => '"true"'), $args) || in_array(array('nocache' => "'true'"), $args)) { if (in_array("'nocache'", $args) || in_array(array('nocache' => 'true'), $args) || in_array(array('nocache' => '"true"'), $args) || in_array(array('nocache' => "'true'"), $args)) {
$this->tag_nocache = true; $this->tag_nocache = true;
} }
// compile the smarty tag (required compile classes to compile the tag are autoloaded) // compile the smarty tag (required compile classes to compile the tag are auto loaded)
if (($_output = $this->callTagCompiler($tag, $args, $parameter)) === false) { if (($_output = $this->callTagCompiler($tag, $args, $parameter)) === false) {
if (isset($this->parent_compiler->templateProperties['tpl_function'][$tag])) { if (isset($this->parent_compiler->templateProperties['tpl_function'][$tag])) {
// template defined by {template} tag // template defined by {template} tag
@@ -727,7 +740,7 @@ abstract class Smarty_Internal_TemplateCompilerBase
* lazy loads internal compile plugin for tag and calls the compile method * lazy loads internal compile plugin for tag and calls the compile method
* compile objects cached for reuse. * compile objects cached for reuse.
* class name format: Smarty_Internal_Compile_TagName * class name format: Smarty_Internal_Compile_TagName
* plugin filename format: Smarty_Internal_Tagname.php * plugin filename format: Smarty_Internal_TagName.php
* *
* @param string $tag tag name * @param string $tag tag name
* @param array $args list of tag attributes * @param array $args list of tag attributes
@@ -740,18 +753,18 @@ abstract class Smarty_Internal_TemplateCompilerBase
public function callTagCompiler($tag, $args, $param1 = null, $param2 = null, $param3 = null) public function callTagCompiler($tag, $args, $param1 = null, $param2 = null, $param3 = null)
{ {
// re-use object if already exists // re-use object if already exists
if (!isset(self::$_tag_objects[$tag])) { if (!isset($this->_tag_objects[$tag])) {
// lazy load internal compiler plugin // lazy load internal compiler plugin
$class_name = 'Smarty_Internal_Compile_' . ucfirst($tag); $class_name = 'Smarty_Internal_Compile_' . ucfirst($tag);
if (class_exists($class_name) && (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this))) { if (class_exists($class_name) && (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this))) {
self::$_tag_objects[$tag] = new $class_name; $this->_tag_objects[$tag] = new $class_name;
} else { } else {
self::$_tag_objects[$tag] = false; $this->_tag_objects[$tag] = false;
return false; return false;
} }
} }
// compile this tag // compile this tag
return self::$_tag_objects[$tag] === false ? false : self::$_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3); return $this->_tag_objects[$tag] === false ? false : $this->_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3);
} }
/** /**
@@ -918,6 +931,36 @@ abstract class Smarty_Internal_TemplateCompilerBase
return $_output; return $_output;
} }
/**
* Get Id
*
* @param string $input
*
* @return bool|string
*/
public function getId($input)
{
if (preg_match('~^[\'"]*([0-9]*[a-zA-Z_]\w*)[\'"]*$~', $input, $match)) {
return $match[1];
}
return false;
}
/**
* Get variable name from string
*
* @param string $input
*
* @return bool|string
*/
public function getVariableName($input)
{
if (preg_match('~^[$]_smarty_tpl->tpl_vars\[[\'"]*([0-9]*[a-zA-Z_]\w*)[\'"]*\]~', $input, $match)) {
return $match[1];
}
return false;
}
/** /**
* Generate nocache code string * Generate nocache code string
* *