Skip to content

Commit

Permalink
minor #4481 Simplify code even more (fabpot)
Browse files Browse the repository at this point in the history
This PR was merged into the 3.x branch.

Discussion
----------

Simplify code even more

More simplifications

Commits
-------

2337c7f Simplify code even more
  • Loading branch information
fabpot committed Nov 28, 2024
2 parents ae82e8b + 2337c7f commit ef3dbab
Showing 1 changed file with 7 additions and 11 deletions.
18 changes: 7 additions & 11 deletions src/NodeVisitor/EscaperNodeVisitor.php
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ public function leaveNode(Node $node, Environment $env): ?Node
} elseif ($node instanceof PrintNode && false !== $type = $this->needEscaping()) {
$expression = $node->getNode('expr');
if ($expression instanceof ConditionalExpression) {
$node->setNode('expr', $this->escapeConditional($expression, $env, $type));
$this->escapeConditional($expression, $env, $type);
} else {
$node->setNode('expr', $this->escapeExpression($expression, $env, $type));
}
Expand All @@ -93,27 +93,23 @@ public function leaveNode(Node $node, Environment $env): ?Node
return $node;
}

private function escapeConditional(ConditionalExpression $expression, Environment $env, string $type): ConditionalExpression
private function escapeConditional(ConditionalExpression $expression, Environment $env, string $type): void
{
/** @var AbstractExpression $expr2 */
$expr2 = $expression->getNode('expr2');
if ($expr2 instanceof ConditionalExpression) {
$expr2 = $this->escapeConditional($expr2, $env, $type);
$this->escapeConditional($expr2, $env, $type);
} else {
$expr2 = $this->escapeExpression($expr2, $env, $type);
$expression->setNode('expr2', $this->escapeExpression($expr2, $env, $type));
}

/** @var AbstractExpression $expr3 */
$expr3 = $expression->getNode('expr3');
if ($expr3 instanceof ConditionalExpression) {
$expr3 = $this->escapeConditional($expr3, $env, $type);
$this->escapeConditional($expr3, $env, $type);
} else {
$expr3 = $this->escapeExpression($expr3, $env, $type);
$expression->setNode('expr3', $this->escapeExpression($expr3, $env, $type));
}

/** @var AbstractExpression $expr1 */
$expr1 = $expression->getNode('expr1');

return new ConditionalExpression($expr1, $expr2, $expr3, $expression->getTemplateLine());
}

private function escapeExpression(AbstractExpression $expression, Environment $env, string $type): AbstractExpression
Expand Down

0 comments on commit ef3dbab

Please sign in to comment.