* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ /** * This engine knows how to render Symfony templates. * * @author Fabien Potencier */ class PhpEngine extends BasePhpEngine implements EngineInterface { protected $container; /** * Constructor. * * @param ContainerInterface $container The DI container * @param LoaderInterface $loader A loader instance */ public function __construct(ContainerInterface $container, LoaderInterface $loader) { $this->container = $container; parent::__construct($loader); } /** * @throws \InvalidArgumentException When the helper is not defined */ public function get($name) { if (!isset($this->helpers[$name])) { throw new \InvalidArgumentException(sprintf('The helper "%s" is not defined.', $name)); } if (is_string($this->helpers[$name])) { $this->helpers[$name] = $this->container->get($this->helpers[$name]); $this->helpers[$name]->setCharset($this->charset); } return $this->helpers[$name]; } /** * {@inheritdoc} */ public function setHelpers(array $helpers) { $this->helpers = $helpers; } /** * Renders a view and returns a Response. * * @param string $view The view name * @param array $parameters An array of parameters to pass to the view * @param Response $response A Response instance * * @return Response A Response instance */ public function renderResponse($view, array $parameters = array(), Response $response = null) { if (null === $response) { $response = $this->container->get('response'); } $response->setContent($this->render($view, $parameters)); return $response; } }