PATH:
opt
/
cpanel
/
ea-wappspector
/
vendor
/
rector
/
rector
/
src
/
PHPStanStaticTypeMapper
/
TypeMapper
<?php declare (strict_types=1); namespace Rector\PHPStanStaticTypeMapper\TypeMapper; use PhpParser\Node; use PhpParser\Node\Name\FullyQualified; use PHPStan\PhpDocParser\Ast\Node as AstNode; use PHPStan\PhpDocParser\Ast\Type\ArrayShapeItemNode; use PHPStan\PhpDocParser\Ast\Type\IdentifierTypeNode; use PHPStan\PhpDocParser\Ast\Type\TypeNode; use PHPStan\PhpDocParser\Ast\Type\UnionTypeNode; use PHPStan\Type\IntersectionType; use PHPStan\Type\MixedType; use PHPStan\Type\ObjectType; use PHPStan\Type\ObjectWithoutClassType; use PHPStan\Type\Type; use Rector\Php\PhpVersionProvider; use Rector\PhpDocParser\PhpDocParser\PhpDocNodeTraverser; use Rector\PHPStanStaticTypeMapper\Contract\TypeMapperInterface; use Rector\PHPStanStaticTypeMapper\Enum\TypeKind; use Rector\StaticTypeMapper\Mapper\ScalarStringToTypeMapper; use Rector\ValueObject\PhpVersionFeature; /** * @implements TypeMapperInterface<IntersectionType> */ final class IntersectionTypeMapper implements TypeMapperInterface { /** * @readonly * @var \Rector\Php\PhpVersionProvider */ private $phpVersionProvider; /** * @readonly * @var \Rector\PHPStanStaticTypeMapper\TypeMapper\ObjectWithoutClassTypeMapper */ private $objectWithoutClassTypeMapper; /** * @readonly * @var \Rector\PHPStanStaticTypeMapper\TypeMapper\ObjectTypeMapper */ private $objectTypeMapper; /** * @readonly * @var \Rector\StaticTypeMapper\Mapper\ScalarStringToTypeMapper */ private $scalarStringToTypeMapper; public function __construct(PhpVersionProvider $phpVersionProvider, \Rector\PHPStanStaticTypeMapper\TypeMapper\ObjectWithoutClassTypeMapper $objectWithoutClassTypeMapper, \Rector\PHPStanStaticTypeMapper\TypeMapper\ObjectTypeMapper $objectTypeMapper, ScalarStringToTypeMapper $scalarStringToTypeMapper) { $this->phpVersionProvider = $phpVersionProvider; $this->objectWithoutClassTypeMapper = $objectWithoutClassTypeMapper; $this->objectTypeMapper = $objectTypeMapper; $this->scalarStringToTypeMapper = $scalarStringToTypeMapper; } public function getNodeClass() : string { return IntersectionType::class; } /** * @param IntersectionType $type */ public function mapToPHPStanPhpDocTypeNode(Type $type) : TypeNode { $typeNode = $type->toPhpDocNode(); $phpDocNodeTraverser = new PhpDocNodeTraverser(); $phpDocNodeTraverser->traverseWithCallable($typeNode, '', function (AstNode $astNode) { if ($astNode instanceof UnionTypeNode) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } if ($astNode instanceof ArrayShapeItemNode) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } if (!$astNode instanceof IdentifierTypeNode) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } $type = $this->scalarStringToTypeMapper->mapScalarStringToType($astNode->name); if ($type->isScalar()->yes()) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } if ($type->isArray()->yes()) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } if ($type instanceof MixedType && $type->isExplicitMixed()) { return PhpDocNodeTraverser::DONT_TRAVERSE_CURRENT_AND_CHILDREN; } $astNode->name = '\\' . \ltrim($astNode->name, '\\'); return $astNode; }); return $typeNode; } /** * @param IntersectionType $type */ public function mapToPhpParserNode(Type $type, string $typeKind) : ?Node { if (!$this->phpVersionProvider->isAtLeastPhpVersion(PhpVersionFeature::INTERSECTION_TYPES)) { return null; } $intersectionedTypeNodes = []; foreach ($type->getTypes() as $type) { if ($type instanceof ObjectWithoutClassType) { return $this->objectWithoutClassTypeMapper->mapToPhpParserNode($type, $typeKind); } if (!$type instanceof ObjectType) { return null; } $resolvedType = $this->objectTypeMapper->mapToPhpParserNode($type, $typeKind); if (!$resolvedType instanceof FullyQualified) { return null; } $intersectionedTypeNodes[] = $resolvedType; } if ($intersectionedTypeNodes === []) { return null; } if (\count($intersectionedTypeNodes) === 1) { return \current($intersectionedTypeNodes); } if ($typeKind === TypeKind::UNION && !$this->phpVersionProvider->isAtLeastPhpVersion(PhpVersionFeature::UNION_INTERSECTION_TYPES)) { return null; } return new Node\IntersectionType($intersectionedTypeNodes); } }
[-] MixedTypeMapper.php
[edit]
[-] NeverTypeMapper.php
[edit]
[-] ObjectWithoutClassTypeMapper.php
[edit]
[-] ResourceTypeMapper.php
[edit]
[-] NonEmptyArrayTypeMapper.php
[edit]
[-] HasOffsetValueTypeTypeMapper.php
[edit]
[-] StringTypeMapper.php
[edit]
[-] IntegerTypeMapper.php
[edit]
[-] ArrayTypeMapper.php
[edit]
[-] IntersectionTypeMapper.php
[edit]
[+]
..
[-] ClosureTypeMapper.php
[edit]
[-] ConditionalTypeMapper.php
[edit]
[-] HasPropertyTypeMapper.php
[edit]
[-] ParentStaticTypeMapper.php
[edit]
[-] CallableTypeMapper.php
[edit]
[-] StrictMixedTypeMapper.php
[edit]
[-] GenericClassStringTypeMapper.php
[edit]
[-] VoidTypeMapper.php
[edit]
[-] ClassStringTypeMapper.php
[edit]
[-] UnionTypeMapper.php
[edit]
[-] ThisTypeMapper.php
[edit]
[-] OversizedArrayTypeMapper.php
[edit]
[-] AccessoryNonEmptyStringTypeMapper.php
[edit]
[-] TypeWithClassNameTypeMapper.php
[edit]
[-] FloatTypeMapper.php
[edit]
[-] HasMethodTypeMapper.php
[edit]
[-] ObjectTypeMapper.php
[edit]
[-] BooleanTypeMapper.php
[edit]
[-] NullTypeMapper.php
[edit]
[-] HasOffsetTypeMapper.php
[edit]
[-] AccessoryNumericStringTypeMapper.php
[edit]
[-] SelfObjectTypeMapper.php
[edit]
[-] StaticTypeMapper.php
[edit]
[-] ConditionalTypeForParameterMapper.php
[edit]
[-] AccessoryNonFalsyStringTypeMapper.php
[edit]
[-] IterableTypeMapper.php
[edit]
[-] AccessoryLiteralStringTypeMapper.php
[edit]