rector/packages/PHPStanStaticTypeMapper/TypeMapper/IterableTypeMapper.php

78 lines
3.2 KiB
PHP
Raw Normal View History

2020-01-14 20:19:41 +00:00
<?php
declare (strict_types=1);
2020-01-14 20:19:41 +00:00
namespace Rector\PHPStanStaticTypeMapper\TypeMapper;
use PhpParser\Node;
2020-05-10 21:02:46 +00:00
use PhpParser\Node\Name;
2020-01-15 02:11:11 +00:00
use PHPStan\PhpDocParser\Ast\Type\ArrayTypeNode;
2020-01-14 20:19:41 +00:00
use PHPStan\PhpDocParser\Ast\Type\TypeNode;
2020-01-15 02:11:11 +00:00
use PHPStan\PhpDocParser\Ast\Type\UnionTypeNode;
2020-01-14 20:19:41 +00:00
use PHPStan\Type\IterableType;
use PHPStan\Type\Type;
use Rector\BetterPhpDocParser\ValueObject\Type\BracketsAwareUnionTypeNode;
use Rector\BetterPhpDocParser\ValueObject\Type\SpacingAwareArrayTypeNode;
2020-01-14 20:19:41 +00:00
use Rector\PHPStanStaticTypeMapper\Contract\TypeMapperInterface;
use Rector\PHPStanStaticTypeMapper\Enum\TypeKind;
2020-01-15 02:11:11 +00:00
use Rector\PHPStanStaticTypeMapper\PHPStanStaticTypeMapper;
use RectorPrefix20211210\Symfony\Contracts\Service\Attribute\Required;
/**
* @implements TypeMapperInterface<IterableType>
*/
final class IterableTypeMapper implements \Rector\PHPStanStaticTypeMapper\Contract\TypeMapperInterface
2020-01-14 20:19:41 +00:00
{
2020-01-15 02:11:11 +00:00
/**
* @var \Rector\PHPStanStaticTypeMapper\PHPStanStaticTypeMapper
2020-01-15 02:11:11 +00:00
*/
private $phpStanStaticTypeMapper;
/**
* @required
*/
public function autowire(\Rector\PHPStanStaticTypeMapper\PHPStanStaticTypeMapper $phpStanStaticTypeMapper) : void
2020-01-15 02:11:11 +00:00
{
$this->phpStanStaticTypeMapper = $phpStanStaticTypeMapper;
}
/**
* @return class-string<Type>
*/
public function getNodeClass() : string
2020-01-14 20:19:41 +00:00
{
return \PHPStan\Type\IterableType::class;
2020-01-14 20:19:41 +00:00
}
/**
* @param \PHPStan\Type\Type $type
* @param \Rector\PHPStanStaticTypeMapper\Enum\TypeKind $typeKind
2020-01-14 20:19:41 +00:00
*/
public function mapToPHPStanPhpDocTypeNode($type, $typeKind) : \PHPStan\PhpDocParser\Ast\Type\TypeNode
2020-01-14 20:19:41 +00:00
{
$itemTypeNode = $this->phpStanStaticTypeMapper->mapToPHPStanPhpDocTypeNode($type->getItemType(), $typeKind);
if ($itemTypeNode instanceof \PHPStan\PhpDocParser\Ast\Type\UnionTypeNode) {
2020-01-15 02:11:11 +00:00
return $this->convertUnionArrayTypeNodesToArrayTypeOfUnionTypeNodes($itemTypeNode);
}
return new \Rector\BetterPhpDocParser\ValueObject\Type\SpacingAwareArrayTypeNode($itemTypeNode);
2020-01-14 20:19:41 +00:00
}
/**
* @param \PHPStan\Type\Type $type
* @param \Rector\PHPStanStaticTypeMapper\Enum\TypeKind $typeKind
2020-01-14 20:19:41 +00:00
*/
public function mapToPhpParserNode($type, $typeKind) : ?\PhpParser\Node
2020-01-14 20:19:41 +00:00
{
return new \PhpParser\Node\Name('iterable');
2020-01-14 20:19:41 +00:00
}
private function convertUnionArrayTypeNodesToArrayTypeOfUnionTypeNodes(\PHPStan\PhpDocParser\Ast\Type\UnionTypeNode $unionTypeNode) : \Rector\BetterPhpDocParser\ValueObject\Type\BracketsAwareUnionTypeNode
{
2020-01-15 02:11:11 +00:00
$unionedArrayType = [];
foreach ($unionTypeNode->types as $unionedType) {
if ($unionedType instanceof \PHPStan\PhpDocParser\Ast\Type\UnionTypeNode) {
2020-01-15 02:11:11 +00:00
foreach ($unionedType->types as $key => $subUnionedType) {
$unionedType->types[$key] = new \PHPStan\PhpDocParser\Ast\Type\ArrayTypeNode($subUnionedType);
2020-01-15 02:11:11 +00:00
}
$unionedArrayType[] = $unionedType;
continue;
}
$unionedArrayType[] = new \PHPStan\PhpDocParser\Ast\Type\ArrayTypeNode($unionedType);
2020-01-15 02:11:11 +00:00
}
return new \Rector\BetterPhpDocParser\ValueObject\Type\BracketsAwareUnionTypeNode($unionedArrayType);
2020-01-15 02:11:11 +00:00
}
2020-01-14 20:19:41 +00:00
}