2011-10-05 06:22:53 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Twig.
|
|
|
|
*
|
2018-05-10 12:24:53 +02:00
|
|
|
* (c) Fabien Potencier
|
2011-10-05 06:22:53 +02:00
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads a template from an array.
|
|
|
|
*
|
|
|
|
* When using this loader with a cache mechanism, you should know that a new cache
|
|
|
|
* key is generated each time a template content "changes" (the cache key being the
|
|
|
|
* source code of the template). If you don't want to see your cache grows out of
|
|
|
|
* control, you need to take care of clearing the old cache file by yourself.
|
|
|
|
*
|
2018-05-10 12:24:53 +02:00
|
|
|
* This loader should only be used for unit testing.
|
|
|
|
*
|
|
|
|
* @final
|
|
|
|
*
|
2013-08-01 21:20:12 +02:00
|
|
|
* @author Fabien Potencier <fabien@symfony.com>
|
2011-10-05 06:22:53 +02:00
|
|
|
*/
|
2018-05-10 12:24:53 +02:00
|
|
|
class Twig_Loader_Array implements Twig_LoaderInterface, Twig_ExistsLoaderInterface, Twig_SourceContextLoaderInterface
|
2011-10-05 06:22:53 +02:00
|
|
|
{
|
2013-09-19 08:08:25 +02:00
|
|
|
protected $templates = array();
|
2011-10-05 06:22:53 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $templates An array of templates (keys are the names, and values are the source code)
|
|
|
|
*/
|
2018-05-10 12:24:53 +02:00
|
|
|
public function __construct(array $templates = array())
|
2011-10-05 06:22:53 +02:00
|
|
|
{
|
2013-09-19 08:08:25 +02:00
|
|
|
$this->templates = $templates;
|
2011-10-05 06:22:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds or overrides a template.
|
|
|
|
*
|
|
|
|
* @param string $name The template name
|
|
|
|
* @param string $template The template source
|
|
|
|
*/
|
|
|
|
public function setTemplate($name, $template)
|
|
|
|
{
|
2013-08-01 21:20:12 +02:00
|
|
|
$this->templates[(string) $name] = $template;
|
2011-10-05 06:22:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getSource($name)
|
|
|
|
{
|
2018-05-10 12:24:53 +02:00
|
|
|
@trigger_error(sprintf('Calling "getSource" on "%s" is deprecated since 1.27. Use getSourceContext() instead.', get_class($this)), E_USER_DEPRECATED);
|
|
|
|
|
2013-08-01 21:20:12 +02:00
|
|
|
$name = (string) $name;
|
2011-10-05 06:22:53 +02:00
|
|
|
if (!isset($this->templates[$name])) {
|
|
|
|
throw new Twig_Error_Loader(sprintf('Template "%s" is not defined.', $name));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->templates[$name];
|
|
|
|
}
|
|
|
|
|
2018-05-10 12:24:53 +02:00
|
|
|
public function getSourceContext($name)
|
|
|
|
{
|
|
|
|
$name = (string) $name;
|
|
|
|
if (!isset($this->templates[$name])) {
|
|
|
|
throw new Twig_Error_Loader(sprintf('Template "%s" is not defined.', $name));
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Twig_Source($this->templates[$name], $name);
|
|
|
|
}
|
|
|
|
|
2013-08-01 21:20:12 +02:00
|
|
|
public function exists($name)
|
|
|
|
{
|
|
|
|
return isset($this->templates[(string) $name]);
|
|
|
|
}
|
|
|
|
|
2011-10-05 06:22:53 +02:00
|
|
|
public function getCacheKey($name)
|
|
|
|
{
|
2013-08-01 21:20:12 +02:00
|
|
|
$name = (string) $name;
|
2011-10-05 06:22:53 +02:00
|
|
|
if (!isset($this->templates[$name])) {
|
|
|
|
throw new Twig_Error_Loader(sprintf('Template "%s" is not defined.', $name));
|
|
|
|
}
|
|
|
|
|
2018-05-10 12:24:53 +02:00
|
|
|
return $name.':'.$this->templates[$name];
|
2011-10-05 06:22:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function isFresh($name, $time)
|
|
|
|
{
|
2013-08-01 21:20:12 +02:00
|
|
|
$name = (string) $name;
|
|
|
|
if (!isset($this->templates[$name])) {
|
|
|
|
throw new Twig_Error_Loader(sprintf('Template "%s" is not defined.', $name));
|
|
|
|
}
|
|
|
|
|
2011-10-05 06:22:53 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2018-05-10 12:24:53 +02:00
|
|
|
|
|
|
|
class_alias('Twig_Loader_Array', 'Twig\Loader\ArrayLoader', false);
|