mirror of
https://github.com/smarty-php/smarty.git
synced 2025-08-04 10:24:26 +02:00
put objects in own array, add object param format support, change
object syntax from foo.bar to foo->bar
This commit is contained in:
@@ -194,7 +194,7 @@ class Smarty
|
||||
var $_cache_info = array(); // info that makes up a cache file
|
||||
var $_file_perms = 0644; // default file permissions
|
||||
var $_dir_perms = 0771; // default dir permissions
|
||||
var $_object_wrapper = false; // default object params structure
|
||||
var $_reg_objects = array(); // registered objects
|
||||
var $_plugins = array( // table keeping track of plugins
|
||||
'modifier' => array(),
|
||||
'function' => array(),
|
||||
@@ -338,10 +338,10 @@ class Smarty
|
||||
Function: register_object
|
||||
Purpose: Registers object to be used in templates
|
||||
\*======================================================================*/
|
||||
function register_object($object, &$object_impl)
|
||||
function register_object($object, &$object_impl, $smarty_args = true)
|
||||
{
|
||||
$this->_plugins['object'][$object] =
|
||||
array(&$object_impl, null, null, false);
|
||||
$this->_reg_objects[$object] =
|
||||
array(&$object_impl, $smarty_args);
|
||||
}
|
||||
|
||||
/*======================================================================*\
|
||||
@@ -350,7 +350,7 @@ class Smarty
|
||||
\*======================================================================*/
|
||||
function unregister_object($object)
|
||||
{
|
||||
unset($this->_plugins['object'][$object]);
|
||||
unset($this->_reg_objects[$object]);
|
||||
}
|
||||
|
||||
|
||||
@@ -1138,6 +1138,7 @@ function _generate_debug_output() {
|
||||
$smarty_compiler->secure_dir = $this->secure_dir;
|
||||
$smarty_compiler->security_settings = $this->security_settings;
|
||||
$smarty_compiler->trusted_dir = $this->trusted_dir;
|
||||
$smarty_compiler->_reg_objects = &$this->_reg_objects;
|
||||
$smarty_compiler->_plugins = &$this->_plugins;
|
||||
$smarty_compiler->_tpl_vars = &$this->_tpl_vars;
|
||||
$smarty_compiler->default_modifiers = $this->default_modifiers;
|
||||
@@ -1906,11 +1907,8 @@ function _run_insert_handler($args)
|
||||
*/
|
||||
if (isset($plugin)) {
|
||||
if (!$plugin[3]) {
|
||||
// no line number, see if it is valid
|
||||
if ($type == 'function' && !function_exists($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not implemented", $tpl_file, $tpl_line, __FILE__, __LINE__);
|
||||
} elseif ($type == 'object' && !is_object($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not an object", $tpl_file, $tpl_line, __FILE__, __LINE__);
|
||||
if (!function_exists($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not implemented", $tpl_file, $tpl_line);
|
||||
} else {
|
||||
$plugin[1] = $tpl_file;
|
||||
$plugin[2] = $tpl_line;
|
||||
|
@@ -147,7 +147,7 @@ class Smarty_Compiler extends Smarty {
|
||||
|
||||
// matches valid registered object:
|
||||
// foo.bar
|
||||
$this->_reg_obj_regexp = '[a-zA-Z_]\w*\.[a-zA-Z_]\w*';
|
||||
$this->_reg_obj_regexp = '[a-zA-Z_]\w*->[a-zA-Z_]\w*';
|
||||
|
||||
// matches valid parameter values:
|
||||
// true
|
||||
@@ -647,8 +647,7 @@ class Smarty_Compiler extends Smarty {
|
||||
\*======================================================================*/
|
||||
function _compile_registered_object_tag($tag_command, $attrs, $tag_modifier)
|
||||
{
|
||||
list($object, $obj_comp) = explode('.', $tag_command);
|
||||
$this->_add_plugin('object', $object);
|
||||
list($object, $obj_comp) = explode('->', $tag_command);
|
||||
|
||||
$arg_list = array();
|
||||
if(count($attrs)) {
|
||||
@@ -656,6 +655,7 @@ class Smarty_Compiler extends Smarty {
|
||||
foreach ($attrs as $arg_name => $arg_value) {
|
||||
if($arg_name == 'assign') {
|
||||
$_assign_var = $arg_value;
|
||||
unset($attrs['assign']);
|
||||
continue;
|
||||
}
|
||||
if (is_bool($arg_value))
|
||||
@@ -664,14 +664,20 @@ class Smarty_Compiler extends Smarty {
|
||||
}
|
||||
}
|
||||
|
||||
if(!$this->_plugins['object'][$object][0]) {
|
||||
$this->_trigger_plugin_error("Smarty error: Registered '$object' is not an object");
|
||||
} elseif(method_exists($this->_plugins['object'][$object][0], $obj_comp)) {
|
||||
if(!$this->_reg_objects[$object][0]) {
|
||||
$this->trigger_error("Smarty error: registered '$object' is not an object");
|
||||
} elseif(method_exists($this->_reg_objects[$object][0], $obj_comp)) {
|
||||
// method
|
||||
$return = "\$this->_plugins['object']['$object'][0]->$obj_comp(array(".implode(',', (array)$arg_list)."), \$this)";
|
||||
if($this->_reg_objects[$object][1]) {
|
||||
// smarty object argument format
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp(array(".implode(',', (array)$arg_list)."), \$this)";
|
||||
} else {
|
||||
// traditional argument format
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp(".implode(',', array_values($attrs)).")";
|
||||
}
|
||||
} else {
|
||||
// property
|
||||
$return = "\$this->_plugins['object']['$object'][0]->$obj_comp";
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp";
|
||||
}
|
||||
|
||||
if($tag_modifier != '') {
|
||||
@@ -681,7 +687,7 @@ class Smarty_Compiler extends Smarty {
|
||||
if($_assign_var) {
|
||||
return "<?php \$this->assign('" . $this->_dequote($_assign_var) ."', $return); ?>\n";
|
||||
} else {
|
||||
return '<?php echo ' . $return . " ; ?>\n";
|
||||
return '<?php echo ' . $return . "; ?>\n";
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -194,7 +194,7 @@ class Smarty
|
||||
var $_cache_info = array(); // info that makes up a cache file
|
||||
var $_file_perms = 0644; // default file permissions
|
||||
var $_dir_perms = 0771; // default dir permissions
|
||||
var $_object_wrapper = false; // default object params structure
|
||||
var $_reg_objects = array(); // registered objects
|
||||
var $_plugins = array( // table keeping track of plugins
|
||||
'modifier' => array(),
|
||||
'function' => array(),
|
||||
@@ -338,10 +338,10 @@ class Smarty
|
||||
Function: register_object
|
||||
Purpose: Registers object to be used in templates
|
||||
\*======================================================================*/
|
||||
function register_object($object, &$object_impl)
|
||||
function register_object($object, &$object_impl, $smarty_args = true)
|
||||
{
|
||||
$this->_plugins['object'][$object] =
|
||||
array(&$object_impl, null, null, false);
|
||||
$this->_reg_objects[$object] =
|
||||
array(&$object_impl, $smarty_args);
|
||||
}
|
||||
|
||||
/*======================================================================*\
|
||||
@@ -350,7 +350,7 @@ class Smarty
|
||||
\*======================================================================*/
|
||||
function unregister_object($object)
|
||||
{
|
||||
unset($this->_plugins['object'][$object]);
|
||||
unset($this->_reg_objects[$object]);
|
||||
}
|
||||
|
||||
|
||||
@@ -1138,6 +1138,7 @@ function _generate_debug_output() {
|
||||
$smarty_compiler->secure_dir = $this->secure_dir;
|
||||
$smarty_compiler->security_settings = $this->security_settings;
|
||||
$smarty_compiler->trusted_dir = $this->trusted_dir;
|
||||
$smarty_compiler->_reg_objects = &$this->_reg_objects;
|
||||
$smarty_compiler->_plugins = &$this->_plugins;
|
||||
$smarty_compiler->_tpl_vars = &$this->_tpl_vars;
|
||||
$smarty_compiler->default_modifiers = $this->default_modifiers;
|
||||
@@ -1906,11 +1907,8 @@ function _run_insert_handler($args)
|
||||
*/
|
||||
if (isset($plugin)) {
|
||||
if (!$plugin[3]) {
|
||||
// no line number, see if it is valid
|
||||
if ($type == 'function' && !function_exists($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not implemented", $tpl_file, $tpl_line, __FILE__, __LINE__);
|
||||
} elseif ($type == 'object' && !is_object($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not an object", $tpl_file, $tpl_line, __FILE__, __LINE__);
|
||||
if (!function_exists($plugin[0])) {
|
||||
$this->_trigger_plugin_error("$type '$name' is not implemented", $tpl_file, $tpl_line);
|
||||
} else {
|
||||
$plugin[1] = $tpl_file;
|
||||
$plugin[2] = $tpl_line;
|
||||
|
@@ -147,7 +147,7 @@ class Smarty_Compiler extends Smarty {
|
||||
|
||||
// matches valid registered object:
|
||||
// foo.bar
|
||||
$this->_reg_obj_regexp = '[a-zA-Z_]\w*\.[a-zA-Z_]\w*';
|
||||
$this->_reg_obj_regexp = '[a-zA-Z_]\w*->[a-zA-Z_]\w*';
|
||||
|
||||
// matches valid parameter values:
|
||||
// true
|
||||
@@ -647,8 +647,7 @@ class Smarty_Compiler extends Smarty {
|
||||
\*======================================================================*/
|
||||
function _compile_registered_object_tag($tag_command, $attrs, $tag_modifier)
|
||||
{
|
||||
list($object, $obj_comp) = explode('.', $tag_command);
|
||||
$this->_add_plugin('object', $object);
|
||||
list($object, $obj_comp) = explode('->', $tag_command);
|
||||
|
||||
$arg_list = array();
|
||||
if(count($attrs)) {
|
||||
@@ -656,6 +655,7 @@ class Smarty_Compiler extends Smarty {
|
||||
foreach ($attrs as $arg_name => $arg_value) {
|
||||
if($arg_name == 'assign') {
|
||||
$_assign_var = $arg_value;
|
||||
unset($attrs['assign']);
|
||||
continue;
|
||||
}
|
||||
if (is_bool($arg_value))
|
||||
@@ -664,14 +664,20 @@ class Smarty_Compiler extends Smarty {
|
||||
}
|
||||
}
|
||||
|
||||
if(!$this->_plugins['object'][$object][0]) {
|
||||
$this->_trigger_plugin_error("Smarty error: Registered '$object' is not an object");
|
||||
} elseif(method_exists($this->_plugins['object'][$object][0], $obj_comp)) {
|
||||
if(!$this->_reg_objects[$object][0]) {
|
||||
$this->trigger_error("Smarty error: registered '$object' is not an object");
|
||||
} elseif(method_exists($this->_reg_objects[$object][0], $obj_comp)) {
|
||||
// method
|
||||
$return = "\$this->_plugins['object']['$object'][0]->$obj_comp(array(".implode(',', (array)$arg_list)."), \$this)";
|
||||
if($this->_reg_objects[$object][1]) {
|
||||
// smarty object argument format
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp(array(".implode(',', (array)$arg_list)."), \$this)";
|
||||
} else {
|
||||
// traditional argument format
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp(".implode(',', array_values($attrs)).")";
|
||||
}
|
||||
} else {
|
||||
// property
|
||||
$return = "\$this->_plugins['object']['$object'][0]->$obj_comp";
|
||||
$return = "\$this->_reg_objects['$object'][0]->$obj_comp";
|
||||
}
|
||||
|
||||
if($tag_modifier != '') {
|
||||
@@ -681,7 +687,7 @@ class Smarty_Compiler extends Smarty {
|
||||
if($_assign_var) {
|
||||
return "<?php \$this->assign('" . $this->_dequote($_assign_var) ."', $return); ?>\n";
|
||||
} else {
|
||||
return '<?php echo ' . $return . " ; ?>\n";
|
||||
return '<?php echo ' . $return . "; ?>\n";
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user