mirror of
https://github.com/rectorphp/rector.git
synced 2025-02-24 11:44:14 +01:00
5ec4cff203
[Php56] Handle jump not Expression stmt next initialized on AddDefaultValueForUndefinedVariableRector (#2725)
68 lines
2.9 KiB
PHP
68 lines
2.9 KiB
PHP
<?php
|
|
|
|
declare (strict_types=1);
|
|
namespace Rector\BetterPhpDocParser\PhpDocNodeVisitor;
|
|
|
|
use PHPStan\PhpDocParser\Ast\Node;
|
|
use PHPStan\PhpDocParser\Ast\PhpDoc\TemplateTagValueNode;
|
|
use PHPStan\PhpDocParser\Lexer\Lexer;
|
|
use Rector\BetterPhpDocParser\Attributes\AttributeMirrorer;
|
|
use Rector\BetterPhpDocParser\Contract\BasePhpDocNodeVisitorInterface;
|
|
use Rector\BetterPhpDocParser\DataProvider\CurrentTokenIteratorProvider;
|
|
use Rector\BetterPhpDocParser\ValueObject\Parser\BetterTokenIterator;
|
|
use Rector\BetterPhpDocParser\ValueObject\PhpDoc\SpacingAwareTemplateTagValueNode;
|
|
use Rector\BetterPhpDocParser\ValueObject\PhpDocAttributeKey;
|
|
use Rector\BetterPhpDocParser\ValueObject\StartAndEnd;
|
|
use Rector\Core\Exception\ShouldNotHappenException;
|
|
use RectorPrefix202208\Symplify\Astral\PhpDocParser\PhpDocNodeVisitor\AbstractPhpDocNodeVisitor;
|
|
final class TemplatePhpDocNodeVisitor extends AbstractPhpDocNodeVisitor implements BasePhpDocNodeVisitorInterface
|
|
{
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\BetterPhpDocParser\DataProvider\CurrentTokenIteratorProvider
|
|
*/
|
|
private $currentTokenIteratorProvider;
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\BetterPhpDocParser\Attributes\AttributeMirrorer
|
|
*/
|
|
private $attributeMirrorer;
|
|
public function __construct(CurrentTokenIteratorProvider $currentTokenIteratorProvider, AttributeMirrorer $attributeMirrorer)
|
|
{
|
|
$this->currentTokenIteratorProvider = $currentTokenIteratorProvider;
|
|
$this->attributeMirrorer = $attributeMirrorer;
|
|
}
|
|
public function enterNode(Node $node) : ?Node
|
|
{
|
|
if (!$node instanceof TemplateTagValueNode) {
|
|
return null;
|
|
}
|
|
if ($node instanceof SpacingAwareTemplateTagValueNode) {
|
|
return null;
|
|
}
|
|
$betterTokenIterator = $this->currentTokenIteratorProvider->provide();
|
|
$startAndEnd = $node->getAttribute(PhpDocAttributeKey::START_AND_END);
|
|
if (!$startAndEnd instanceof StartAndEnd) {
|
|
throw new ShouldNotHappenException();
|
|
}
|
|
$prepositions = $this->resolvePreposition($betterTokenIterator, $startAndEnd);
|
|
$spacingAwareTemplateTagValueNode = new SpacingAwareTemplateTagValueNode($node->name, $node->bound, $node->description, $prepositions);
|
|
$this->attributeMirrorer->mirror($node, $spacingAwareTemplateTagValueNode);
|
|
return $spacingAwareTemplateTagValueNode;
|
|
}
|
|
private function resolvePreposition(BetterTokenIterator $betterTokenIterator, StartAndEnd $startAndEnd) : string
|
|
{
|
|
$partialTokens = $betterTokenIterator->partialTokens($startAndEnd->getStart(), $startAndEnd->getEnd());
|
|
foreach ($partialTokens as $partialToken) {
|
|
if ($partialToken[1] !== Lexer::TOKEN_IDENTIFIER) {
|
|
continue;
|
|
}
|
|
if (!\in_array($partialToken[0], ['as', 'of'], \true)) {
|
|
continue;
|
|
}
|
|
return $partialToken[0];
|
|
}
|
|
return 'of';
|
|
}
|
|
}
|