<?php
/*
* This file is part of Twig.
*
* (c) Fabien Potencier
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace ElementorDeps\Twig\Extension;
use ElementorDeps\Twig\Environment;
use ElementorDeps\Twig\TemplateWrapper;
use ElementorDeps\Twig\TwigFunction;
final class StringLoaderExtension extends AbstractExtension
{
public function getFunctions() : array
{
return [new TwigFunction('template_from_string', [self::class, 'templateFromString'], ['needs_environment' => \true])];
}
/**
* Loads a template from a string.
*
* {{ include(template_from_string("Hello {{ name }}")) }}
*
* @param string $template A template as a string or object implementing __toString()
* @param string|null $name An optional name of the template to be used in error messages
*
* @internal
*/
public static function templateFromString(Environment $env, $template, ?string $name = null) : TemplateWrapper
{
return $env->createTemplate((string) $template, $name);
}
}