Smarty « Вызов блока шаблона Smarty с параметрами (решено)

Доброго времени суток!
Как в шаблонизаторе Smarty вызвать функцию с параметрами? под функциями я подразумеваю не PHP функцию, а блок из шаблона Smarty.

Пример (как бы хотелось):

{function name="fname"}
<h1>{$title}</h1>
{$text}
{/function}

{function name="fname" title="TITLE" text="text"}
 

Здесь мы вызвали нашу псеводфункцию function fname с параметрами, однако такой возможности в смарти нет..

Для решения этой задачи я вижу следующие пути:
1) Создавать под каждую подобную функцию отдельный файл, и вызывать их как

{include file="fname.tpl"  title="TITLE" text="text"}
 

Минус этого подхода - большое количество файлов при большом количестве шаблонов. Желательно чтобы вызываемые функции находились в том же файле.
2) Писать дополнительные плагины для smarty, чего делать совсем не хочется.

Что еще можно сделать?
Спасибо

UPD:
Решение:
Устанавливаем плагин compiler.defun http://lammfellpuschen.de/compiler.defun/
Немного меняем его:
В функции smarty_compiler_defun_close меняем
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }

return " $this->_tpl_vars = $_fun_tpl_vars; }} " . $func_key . smarty_compiler_fun($open_tag_args, $compiler);
 

на
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }

return " $this->_tpl_vars = $_fun_tpl_vars; }} " . $func_key;
 


Этим самым мы запрещаем вывод текста при объявлении функции.
Как этим пользоваться?


{defun name="fname" title="" text=""}
<h1>{$title}</h1>
{$text}
{/defun}

{fun name="fname" title="TITLE" text="text"}
 


Синтаксис : {fun name="function_name" [params=args]}
Количество аргументов любое.

Спасибо ootync за подсказку.

1 ответов


Есть стандартная штука {defun name="fname"}...{/defun}, но она с косяком: вызывается сразу же. Можно первоначально передать ей пустые аргументы чтобы было "чистое определение":


{defun name="fname" title="" text=""}
{if $title}
<h1>{$title}</h1>
{$text}
{/if}
{/defun}

{fun name="fname" title="TITLE" text="text"}