Файл: vendor/symfony/translation/Extractor/Visitor/AbstractVisitor.php
Строк: 210
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace SymfonyComponentTranslationExtractorVisitor;
use PhpParserNode;
use SymfonyComponentTranslationMessageCatalogue;
/**
* @author Mathieu Santostefano <msantostefano@protonmail.com>
*/
abstract class AbstractVisitor
{
private MessageCatalogue $catalogue;
private SplFileInfo $file;
private string $messagePrefix;
public function initialize(MessageCatalogue $catalogue, SplFileInfo $file, string $messagePrefix): void
{
$this->catalogue = $catalogue;
$this->file = $file;
$this->messagePrefix = $messagePrefix;
}
protected function addMessageToCatalogue(string $message, ?string $domain, int $line): void
{
$domain ??= 'messages';
$this->catalogue->set($message, $this->messagePrefix.$message, $domain);
$metadata = $this->catalogue->getMetadata($message, $domain) ?? [];
$normalizedFilename = preg_replace('{[\\/]+}', '/', $this->file);
$metadata['sources'][] = $normalizedFilename.':'.$line;
$this->catalogue->setMetadata($message, $metadata, $domain);
}
protected function getStringArguments(NodeExprCallLike|NodeAttribute|NodeExprNew_ $node, int|string $index, bool $indexIsRegex = false): array
{
if (is_string($index)) {
return $this->getStringNamedArguments($node, $index, $indexIsRegex);
}
$args = $node instanceof NodeExprCallLike ? $node->getRawArgs() : $node->args;
if (!($arg = $args[$index] ?? null) instanceof NodeArg) {
return [];
}
return (array) $this->getStringValue($arg->value);
}
protected function hasNodeNamedArguments(NodeExprCallLike|NodeAttribute|NodeExprNew_ $node): bool
{
$args = $node instanceof NodeExprCallLike ? $node->getRawArgs() : $node->args;
foreach ($args as $arg) {
if ($arg instanceof NodeArg && null !== $arg->name) {
return true;
}
}
return false;
}
protected function nodeFirstNamedArgumentIndex(NodeExprCallLike|NodeAttribute|NodeExprNew_ $node): int
{
$args = $node instanceof NodeExprCallLike ? $node->getRawArgs() : $node->args;
foreach ($args as $i => $arg) {
if ($arg instanceof NodeArg && null !== $arg->name) {
return $i;
}
}
return PHP_INT_MAX;
}
private function getStringNamedArguments(NodeExprCallLike|NodeAttribute $node, ?string $argumentName = null, bool $isArgumentNamePattern = false): array
{
$args = $node instanceof NodeExprCallLike ? $node->getArgs() : $node->args;
$argumentValues = [];
foreach ($args as $arg) {
if (!$isArgumentNamePattern && $arg->name?->toString() === $argumentName) {
$argumentValues[] = $this->getStringValue($arg->value);
} elseif ($isArgumentNamePattern && preg_match($argumentName, $arg->name?->toString() ?? '') > 0) {
$argumentValues[] = $this->getStringValue($arg->value);
}
}
return array_filter($argumentValues);
}
private function getStringValue(Node $node): ?string
{
if ($node instanceof NodeScalarString_) {
return $node->value;
}
if ($node instanceof NodeExprBinaryOpConcat) {
if (null === $left = $this->getStringValue($node->left)) {
return null;
}
if (null === $right = $this->getStringValue($node->right)) {
return null;
}
return $left.$right;
}
if ($node instanceof NodeExprAssign && $node->expr instanceof NodeScalarString_) {
return $node->expr->value;
}
if ($node instanceof NodeExprClassConstFetch) {
try {
$reflection = new ReflectionClass($node->class->toString());
$constant = $reflection->getReflectionConstant($node->name->toString());
if (false !== $constant && is_string($constant->getValue())) {
return $constant->getValue();
}
} catch (ReflectionException) {
}
}
return null;
}
}