class TwigTransTokenParser in Drupal 9
Same name and namespace in other branches
- 8 core/lib/Drupal/Core/Template/TwigTransTokenParser.php \Drupal\Core\Template\TwigTransTokenParser
A class that defines the Twig 'trans' token parser for Drupal.
The token parser converts a token stream created from template source code into an Abstract Syntax Tree (AST). The AST will later be compiled into PHP code usable for runtime execution of the template.
Hierarchy
- class \Drupal\Core\Template\TwigTransTokenParser extends \Twig\TokenParser\AbstractTokenParser
Expanded class hierarchy of TwigTransTokenParser
See also
https://twig-extensions.readthedocs.io/en/latest/i18n.html
https://github.com/fabpot/Twig-extensions
File
- core/
lib/ Drupal/ Core/ Template/ TwigTransTokenParser.php, line 25
Namespace
Drupal\Core\TemplateView source
class TwigTransTokenParser extends AbstractTokenParser {
/**
* {@inheritdoc}
*/
public function parse(Token $token) {
$lineno = $token
->getLine();
$stream = $this->parser
->getStream();
$body = NULL;
$options = NULL;
$count = NULL;
$plural = NULL;
if (!$stream
->test(Token::BLOCK_END_TYPE) && $stream
->test(Token::STRING_TYPE)) {
$body = $this->parser
->getExpressionParser()
->parseExpression();
}
if (!$stream
->test(Token::BLOCK_END_TYPE) && $stream
->test(Token::NAME_TYPE, 'with')) {
$stream
->next();
$options = $this->parser
->getExpressionParser()
->parseExpression();
}
if (!$body) {
$stream
->expect(Token::BLOCK_END_TYPE);
$body = $this->parser
->subparse([
$this,
'decideForFork',
]);
if ('plural' === $stream
->next()
->getValue()) {
$count = $this->parser
->getExpressionParser()
->parseExpression();
$stream
->expect(Token::BLOCK_END_TYPE);
$plural = $this->parser
->subparse([
$this,
'decideForEnd',
], TRUE);
}
}
$stream
->expect(Token::BLOCK_END_TYPE);
$this
->checkTransString($body, $lineno);
$node = new TwigNodeTrans($body, $plural, $count, $options, $lineno, $this
->getTag());
return $node;
}
/**
* Detect a 'plural' switch or the end of a 'trans' tag.
*/
public function decideForFork($token) {
return $token
->test([
'plural',
'endtrans',
]);
}
/**
* Detect the end of a 'trans' tag.
*/
public function decideForEnd($token) {
return $token
->test('endtrans');
}
/**
* {@inheritdoc}
*/
public function getTag() {
return 'trans';
}
/**
* Ensure that any nodes that are parsed are only of allowed types.
*
* @param \Twig\Node\Node $body
* The expression to check.
* @param int $lineno
* The source line.
*
* @throws \Twig\Error\SyntaxError
*/
protected function checkTransString(Node $body, $lineno) {
foreach ($body as $node) {
if ($node instanceof TextNode || $node instanceof PrintNode && $node
->getNode('expr') instanceof NameExpression || $node instanceof PrintNode && $node
->getNode('expr') instanceof GetAttrExpression || $node instanceof PrintNode && $node
->getNode('expr') instanceof FilterExpression) {
continue;
}
throw new SyntaxError(sprintf('The text to be translated with "trans" can only contain references to simple variables'), $lineno);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
TwigTransTokenParser:: |
protected | function | Ensure that any nodes that are parsed are only of allowed types. | |
TwigTransTokenParser:: |
public | function | Detect the end of a 'trans' tag. | |
TwigTransTokenParser:: |
public | function | Detect a 'plural' switch or the end of a 'trans' tag. | |
TwigTransTokenParser:: |
public | function | ||
TwigTransTokenParser:: |
public | function |