123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- <?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\Component\Templating\Loader;
- use Symfony\Component\Templating\Storage\Storage;
- use Symfony\Component\Templating\Storage\FileStorage;
- use Symfony\Component\Templating\TemplateReferenceInterface;
- /**
- * FilesystemLoader is a loader that read templates from the filesystem.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- *
- * @api
- */
- class FilesystemLoader extends Loader
- {
- protected $templatePathPatterns;
- /**
- * Constructor.
- *
- * @param array $templatePathPatterns An array of path patterns to look for templates
- *
- * @api
- */
- public function __construct($templatePathPatterns)
- {
- $this->templatePathPatterns = (array) $templatePathPatterns;
- }
- /**
- * Loads a template.
- *
- * @param TemplateReferenceInterface $template A template
- *
- * @return Storage|Boolean false if the template cannot be loaded, a Storage instance otherwise
- *
- * @api
- */
- public function load(TemplateReferenceInterface $template)
- {
- $file = $template->get('name');
- if (self::isAbsolutePath($file) && is_file($file)) {
- return new FileStorage($file);
- }
- $replacements = array();
- foreach ($template->all() as $key => $value) {
- $replacements['%'.$key.'%'] = $value;
- }
- $logs = array();
- foreach ($this->templatePathPatterns as $templatePathPattern) {
- if (is_file($file = strtr($templatePathPattern, $replacements)) && is_readable($file)) {
- if (null !== $this->debugger) {
- $this->debugger->log(sprintf('Loaded template file "%s"', $file));
- }
- return new FileStorage($file);
- }
- if (null !== $this->debugger) {
- $logs[] = sprintf('Failed loading template file "%s"', $file);
- }
- }
- if (null !== $this->debugger) {
- foreach ($logs as $log) {
- $this->debugger->log($log);
- }
- }
- return false;
- }
- /**
- * Returns true if the template is still fresh.
- *
- * @param TemplateReferenceInterface $template A template
- * @param integer $time The last modification time of the cached template (timestamp)
- *
- * @return Boolean true if the template is still fresh, false otherwise
- *
- * @api
- */
- public function isFresh(TemplateReferenceInterface $template, $time)
- {
- if (false === $storage = $this->load($template)) {
- return false;
- }
- return filemtime((string) $storage) < $time;
- }
- /**
- * Returns true if the file is an existing absolute path.
- *
- * @param string $file A path
- *
- * @return Boolean true if the path exists and is absolute, false otherwise
- */
- protected static function isAbsolutePath($file)
- {
- if ($file[0] == '/' || $file[0] == '\\'
- || (strlen($file) > 3 && ctype_alpha($file[0])
- && $file[1] == ':'
- && ($file[2] == '\\' || $file[2] == '/')
- )
- || null !== parse_url($file, PHP_URL_SCHEME)
- ) {
- return true;
- }
- return false;
- }
- }
|