mirror of
https://github.com/smarty-php/smarty.git
synced 2025-07-31 16:37:14 +02:00
@@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
### Fixed
|
### Fixed
|
||||||
- Registered output filters wouldn't run [#899](https://github.com/smarty-php/smarty/issues/899)
|
- Registered output filters wouldn't run [#899](https://github.com/smarty-php/smarty/issues/899)
|
||||||
- Use of negative numbers in {math} equations [#895](https://github.com/smarty-php/smarty/issues/895)
|
- Use of negative numbers in {math} equations [#895](https://github.com/smarty-php/smarty/issues/895)
|
||||||
|
- Do not auto-html-escape custom function results [#906](https://github.com/smarty-php/smarty/issues/906)
|
||||||
- Fix case-sensitive tag names [#907](https://github.com/smarty-php/smarty/issues/907)
|
- Fix case-sensitive tag names [#907](https://github.com/smarty-php/smarty/issues/907)
|
||||||
|
|
||||||
### Removed
|
### Removed
|
||||||
|
@@ -1143,7 +1143,7 @@ class Template extends BaseCompiler {
|
|||||||
if ($this->smarty->getFunctionHandler($base_tag)) {
|
if ($this->smarty->getFunctionHandler($base_tag)) {
|
||||||
if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($base_tag, $this)) {
|
if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($base_tag, $this)) {
|
||||||
return (new \Smarty\Compile\PrintExpressionCompiler())->compile(
|
return (new \Smarty\Compile\PrintExpressionCompiler())->compile(
|
||||||
[],
|
['nofilter'], // functions are never auto-escaped
|
||||||
$this,
|
$this,
|
||||||
['value' => $this->compileFunctionCall($base_tag, $args, $parameter)]
|
['value' => $this->compileFunctionCall($base_tag, $args, $parameter)]
|
||||||
);
|
);
|
||||||
|
@@ -30,4 +30,35 @@ class AutoEscapeTest extends PHPUnit_Smarty
|
|||||||
$tpl->assign('foo', '<a@b.c>');
|
$tpl->assign('foo', '<a@b.c>');
|
||||||
$this->assertEquals("<a@b.c>", $this->smarty->fetch($tpl));
|
$this->assertEquals("<a@b.c>", $this->smarty->fetch($tpl));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* test 'escapeHtml' property
|
||||||
|
* @group issue906
|
||||||
|
*/
|
||||||
|
public function testAutoEscapeDoesNotEscapeFunctionPlugins()
|
||||||
|
{
|
||||||
|
$this->smarty->registerPlugin(
|
||||||
|
\Smarty\Smarty::PLUGIN_FUNCTION,
|
||||||
|
'horizontal_rule',
|
||||||
|
function ($params, $smarty) { return "<hr>"; }
|
||||||
|
);
|
||||||
|
$tpl = $this->smarty->createTemplate('eval:{horizontal_rule}');
|
||||||
|
$this->assertEquals("<hr>", $this->smarty->fetch($tpl));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* test 'escapeHtml' property
|
||||||
|
* @group issue906
|
||||||
|
*/
|
||||||
|
public function testAutoEscapeDoesNotEscapeBlockPlugins()
|
||||||
|
{
|
||||||
|
$this->smarty->registerPlugin(
|
||||||
|
\Smarty\Smarty::PLUGIN_BLOCK,
|
||||||
|
'paragraphify',
|
||||||
|
function ($params, $content) { return $content == null ? null : "<p>".$content."</p>"; }
|
||||||
|
);
|
||||||
|
$tpl = $this->smarty->createTemplate('eval:{paragraphify}hi{/paragraphify}');
|
||||||
|
$this->assertEquals("<p>hi</p>", $this->smarty->fetch($tpl));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user