/
home
/
obinna
/
html
/
restaurants
/
vendor
/
symfony
/
twig-bundle
/
Loader
/
Upload File
HOME
<?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\Loader; @trigger_error('The '.FilesystemLoader::class.' class is deprecated since version 4.3 and will be removed in 5.0; use Twig notation for templates instead.', \E_USER_DEPRECATED); use Symfony\Component\Config\FileLocatorInterface; use Symfony\Component\Templating\TemplateNameParserInterface; use Symfony\Component\Templating\TemplateReferenceInterface; use Twig\Error\LoaderError; use Twig\Loader\FilesystemLoader as BaseFilesystemLoader; /** * FilesystemLoader extends the default Twig filesystem loader * to work with the Symfony paths and template references. * * @author Fabien Potencier <fabien@symfony.com> * * @deprecated since version 4.3, to be removed in 5.0; use Twig notation for templates instead. */ class FilesystemLoader extends BaseFilesystemLoader { protected $locator; protected $parser; /** * @param string|null $rootPath The root path common to all relative paths (null for getcwd()) */ public function __construct(FileLocatorInterface $locator, TemplateNameParserInterface $parser, string $rootPath = null) { parent::__construct([], $rootPath); $this->locator = $locator; $this->parser = $parser; } /** * {@inheritdoc} * * The name parameter might also be a TemplateReferenceInterface. * * @return bool */ public function exists($name) { return parent::exists((string) $name); } /** * Returns the path to the template file. * * The file locator is used to locate the template when the naming convention * is the symfony one (i.e. the name can be parsed). * Otherwise the template is located using the locator from the twig library. * * @param string|TemplateReferenceInterface $template The template * @param bool $throw When true, a LoaderError exception will be thrown if a template could not be found * * @return string The path to the template file * * @throws LoaderError if the template could not be found */ protected function findTemplate($template, $throw = true) { $logicalName = (string) $template; if (isset($this->cache[$logicalName])) { return $this->cache[$logicalName]; } $file = null; try { $file = parent::findTemplate($logicalName); } catch (LoaderError $e) { $twigLoaderException = $e; // for BC try { $template = $this->parser->parse($template); $file = $this->locator->locate($template); } catch (\Exception $e) { } } if (false === $file || null === $file) { if ($throw) { throw $twigLoaderException; } return null; } return $this->cache[$logicalName] = $file; } }