Mathieu Santostefano
Contributed by Mathieu Santostefano in #46161

Symfony includes a translation:extract command that looks for translatable contents in Twig templates and PHP files/classes to update the translation files with all the new contents found.

Behind the scenes, a PhpExtractor service uses the token_get_all() function to find those translatable strings. This works well in most cases, but it's increasingly difficult to add support for newer PHP features such as named arguments.

That's why in Symfony 6.2 we're introducing a new AST-based translation extractor. It uses the popular nikic/php-parser library to properly parse the contents of PHP files and process them as traversable nodes.

The new PhpAstExtractor service supports all kinds of trans() function calls, usages of TranslatableMessage class, messages defined in validation constraints, etc. Thanks to its solid AST-based foundation, we'll improve it and will add support for new PHP features much faster than before.

To use the new translation extractor, update your project to Symfony 6.2 and install the nikic/php-parser package using Composer. That's all. There's nothing else to configure or change in your project.

Published in #Living on the edge