From ea5767df0aefa3fee3050aadf69dadf9d6616760 Mon Sep 17 00:00:00 2001 From: Christian Flothmann Date: Wed, 30 Apr 2025 12:53:06 +0200 Subject: [PATCH] use deprecation catching error handler only when parsing Twig templates --- .../Validator/Constraints/TwigValidator.php | 42 ++++++++++--------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/src/Symfony/Bridge/Twig/Validator/Constraints/TwigValidator.php b/src/Symfony/Bridge/Twig/Validator/Constraints/TwigValidator.php index de92a36272963..3064341f3b10d 100644 --- a/src/Symfony/Bridge/Twig/Validator/Constraints/TwigValidator.php +++ b/src/Symfony/Bridge/Twig/Validator/Constraints/TwigValidator.php @@ -45,26 +45,33 @@ public function validate(mixed $value, Constraint $constraint): void $value = (string) $value; - if (!$constraint->skipDeprecations) { - $prevErrorHandler = set_error_handler(static function ($level, $message, $file, $line) use (&$prevErrorHandler) { - if (\E_USER_DEPRECATED !== $level) { - return $prevErrorHandler ? $prevErrorHandler($level, $message, $file, $line) : false; - } - - $templateLine = 0; - if (preg_match('/ at line (\d+)[ .]/', $message, $matches)) { - $templateLine = $matches[1]; - } - - throw new Error($message, $templateLine); - }); - } - $realLoader = $this->twig->getLoader(); try { $temporaryLoader = new ArrayLoader([$value]); $this->twig->setLoader($temporaryLoader); - $this->twig->parse($this->twig->tokenize(new Source($value, ''))); + + if (!$constraint->skipDeprecations) { + $prevErrorHandler = set_error_handler(static function ($level, $message, $file, $line) use (&$prevErrorHandler) { + if (\E_USER_DEPRECATED !== $level) { + return $prevErrorHandler ? $prevErrorHandler($level, $message, $file, $line) : false; + } + + $templateLine = 0; + if (preg_match('/ at line (\d+)[ .]/', $message, $matches)) { + $templateLine = $matches[1]; + } + + throw new Error($message, $templateLine); + }); + } + + try { + $this->twig->parse($this->twig->tokenize(new Source($value, ''))); + } finally { + if (!$constraint->skipDeprecations) { + restore_error_handler(); + } + } } catch (Error $e) { $this->context->buildViolation($constraint->message) ->setParameter('{{ error }}', $e->getMessage()) @@ -73,9 +80,6 @@ public function validate(mixed $value, Constraint $constraint): void ->addViolation(); } finally { $this->twig->setLoader($realLoader); - if (!$constraint->skipDeprecations) { - restore_error_handler(); - } } } }