From 51609351f2c4b5082b7e6f0744cd3811c325303f Mon Sep 17 00:00:00 2001 From: emkael Date: Tue, 11 Oct 2016 14:01:29 +0200 Subject: * initial template --- ...ty_internal_compile_private_object_function.php | 79 ++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 lib/smarty/sysplugins/smarty_internal_compile_private_object_function.php (limited to 'lib/smarty/sysplugins/smarty_internal_compile_private_object_function.php') diff --git a/lib/smarty/sysplugins/smarty_internal_compile_private_object_function.php b/lib/smarty/sysplugins/smarty_internal_compile_private_object_function.php new file mode 100644 index 0000000..f649084 --- /dev/null +++ b/lib/smarty/sysplugins/smarty_internal_compile_private_object_function.php @@ -0,0 +1,79 @@ +getAttributes($compiler, $args); + if ($_attr['nocache'] === true) { + $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 ($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]->{$method}({$_params},\$_smarty_tpl)"; + } else { + $_params = implode(",", $_attr); + $return = "\$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params})"; + } + if (empty($_assign)) { + // This tag does create output + $compiler->has_output = true; + $output = "\n"; + } else { + $output = "assign({$_assign},{$return});?>\n"; + } + return $output; + } + +} + +?> \ No newline at end of file -- cgit v1.2.3