2e7c2caaf2
* 2.6: Add test for HHVM FatalErrors [2.6][Debug] Fix fatal-errors handling on HHVM [2.3][Debug] Fix fatal-errors handling on HHVM Standardize the name of the exception variables [2.3] Static Code Analysis for Components Remove duplicated paths Conflicts: src/Symfony/Component/Debug/ErrorHandler.php src/Symfony/Component/Security/Http/Firewall/BasicAuthenticationListener.php src/Symfony/Component/Security/Http/Firewall/ContextListener.php src/Symfony/Component/Security/Http/Firewall/RememberMeListener.php src/Symfony/Component/Security/Http/RememberMe/AbstractRememberMeServices.php
102 lines
3.3 KiB
PHP
102 lines
3.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Symfony\Bundle\TwigBundle;
|
|
|
|
use Symfony\Bridge\Twig\TwigEngine as BaseEngine;
|
|
use Symfony\Bundle\FrameworkBundle\Templating\EngineInterface;
|
|
use Symfony\Bundle\FrameworkBundle\Templating\TemplateReference;
|
|
use Symfony\Component\Templating\TemplateNameParserInterface;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
use Symfony\Component\Config\FileLocatorInterface;
|
|
|
|
/**
|
|
* This engine renders Twig templates.
|
|
*
|
|
* @author Fabien Potencier <fabien@symfony.com>
|
|
*/
|
|
class TwigEngine extends BaseEngine implements EngineInterface
|
|
{
|
|
protected $locator;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param \Twig_Environment $environment A \Twig_Environment instance
|
|
* @param TemplateNameParserInterface $parser A TemplateNameParserInterface instance
|
|
* @param FileLocatorInterface $locator A FileLocatorInterface instance
|
|
*/
|
|
public function __construct(\Twig_Environment $environment, TemplateNameParserInterface $parser, FileLocatorInterface $locator)
|
|
{
|
|
parent::__construct($environment, $parser);
|
|
|
|
$this->locator = $locator;
|
|
}
|
|
|
|
/**
|
|
* @deprecated since version 2.7, to be removed in 3.0.
|
|
* Inject the escaping strategy on \Twig_Environment instead.
|
|
*/
|
|
public function setDefaultEscapingStrategy($strategy)
|
|
{
|
|
@trigger_error('The '.__METHOD__.' method is deprecated since version 2.7 and will be removed in 3.0. Inject the escaping strategy in the Twig_Environment object instead.', E_USER_DEPRECATED);
|
|
|
|
$this->environment->getExtension('escaper')->setDefaultStrategy($strategy);
|
|
}
|
|
|
|
/**
|
|
* @deprecated since version 2.7, to be removed in 3.0.
|
|
* Use the 'filename' strategy instead.
|
|
*/
|
|
public function guessDefaultEscapingStrategy($filename)
|
|
{
|
|
@trigger_error('The '.__METHOD__.' method is deprecated since version 2.7 and will be removed in 3.0. Use the Twig_FileExtensionEscapingStrategy::guess method instead.', E_USER_DEPRECATED);
|
|
|
|
return \Twig_FileExtensionEscapingStrategy::guess($filename);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function render($name, array $parameters = array())
|
|
{
|
|
try {
|
|
return parent::render($name, $parameters);
|
|
} catch (\Twig_Error $e) {
|
|
if ($name instanceof TemplateReference) {
|
|
try {
|
|
// try to get the real file name of the template where the error occurred
|
|
$e->setTemplateFile(sprintf('%s', $this->locator->locate($this->parser->parse($e->getTemplateFile()))));
|
|
} catch (\Exception $e2) {
|
|
}
|
|
}
|
|
|
|
throw $e;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*
|
|
* @throws \Twig_Error if something went wrong like a thrown exception while rendering the template
|
|
*/
|
|
public function renderResponse($view, array $parameters = array(), Response $response = null)
|
|
{
|
|
if (null === $response) {
|
|
$response = new Response();
|
|
}
|
|
|
|
$response->setContent($this->render($view, $parameters));
|
|
|
|
return $response;
|
|
}
|
|
}
|