diff --git a/libs/sysplugins/internal.compile_block_plugin.php b/libs/sysplugins/internal.compile_block_plugin.php index 0c17e08e..a21612e1 100644 --- a/libs/sysplugins/internal.compile_block_plugin.php +++ b/libs/sysplugins/internal.compile_block_plugin.php @@ -1,61 +1,64 @@ -compiler = $compiler; - if (strlen($tag) < 6 || substr_compare($tag, 'close', -5, 5) != 0) { - // opening tag of block plugin - $this->required_attributes = array(); - $this->optional_attributes = array('_any'); - // check and get attributes - $_attr = $this->_get_attributes($args); - // convert attributes into parameter array string - $_paramsArray = array(); - foreach ($_attr as $_key => $_value) { - $_paramsArray[] = "'$_key'=>$_value"; - } - $_params = 'array(' . implode(",", $_paramsArray) . ')'; - - $this->_open_tag($tag, array($_params, $this->compiler->nocache)); - // not cachable? - if (isset($this->compiler->smarty->registered_plugins[$tag]) && !$this->compiler->smarty->registered_plugins[$tag][2]) { - $this->compiler->nocache = true; - } - // compile code - $output = 'smarty->plugin_handler->' . $tag . '(array(' . $_params . ', null, $_smarty_tpl->smarty, &$_block_repeat, $_smarty_tpl),\'block\');while ($_block_repeat) { ob_start();?>'; - } else { - if ($this->compiler->nocache) { - $this->compiler->tag_nocache = true; - } - // closing tag of block plugin - list($_params, $this->compiler->nocache) = $this->_close_tag(substr($tag, 0, -5)); - // This tag does create output - $this->compiler->has_output = true; - // compile code - $output = 'smarty->plugin_handler->' . substr($tag, 0, -5) . '(array(' . $_params . ', $_block_content, $_smarty_tpl->smarty, &$_block_repeat, $_smarty_tpl),\'block\'); }?>'; - } - return $output; - } -} - -?> +compiler = $compiler; + if (strlen($tag) < 6 || substr_compare($tag, 'close', -5, 5) != 0) { + // opening tag of block plugin + $this->required_attributes = array(); + $this->optional_attributes = array('_any'); + // check and get attributes + $_attr = $this->_get_attributes($args); + // convert attributes into parameter array string + $_paramsArray = array(); + foreach ($_attr as $_key => $_value) { + $_paramsArray[] = "'$_key'=>$_value"; + } + $_params = 'array(' . implode(",", $_paramsArray) . ')'; + + $this->_open_tag($tag, array($_params, $this->compiler->nocache,$this->compiler->tag_nocache)); + // not cachable? + if (isset($this->compiler->smarty->registered_plugins[$tag]) && !$this->compiler->smarty->registered_plugins[$tag][2]) { + $this->compiler->nocache = true; + } + // compile code + $output = 'smarty->plugin_handler->' . $tag . '(array(' . $_params . ', null, $_smarty_tpl->smarty, &$_block_repeat, $_smarty_tpl),\'block\');while ($_block_repeat) { ob_start();?>'; + } else { + if ($this->compiler->nocache) { + $this->compiler->tag_nocache = true; + } + // closing tag of block plugin + list($_params, $this->compiler->nocache,$tag_nocache) = $this->_close_tag(substr($tag, 0, -5)); + if ($tag_nocache) { + $this->compiler->tag_nocache = true; + } + // This tag does create output + $this->compiler->has_output = true; + // compile code + $output = 'smarty->plugin_handler->' . substr($tag, 0, -5) . '(array(' . $_params . ', $_block_content, $_smarty_tpl->smarty, &$_block_repeat, $_smarty_tpl),\'block\'); }?>'; + } + return $output; + } +} + +?>