PATH:
opt
/
cpanel
/
ea-wappspector
/
vendor
/
rector
/
rector
/
src
/
PHPStanStaticTypeMapper
/
TypeMapper
<?php declare (strict_types=1); namespace Rector\PHPStanStaticTypeMapper\TypeMapper; use RectorPrefix202411\Nette\Utils\Strings; use PhpParser\Node; use PhpParser\Node\Name; use PhpParser\Node\Name\FullyQualified; use PHPStan\PhpDocParser\Ast\Type\TypeNode; use PHPStan\Type\Generic\GenericObjectType; use PHPStan\Type\ObjectType; use PHPStan\Type\Type; use PHPStan\Type\TypeTraverser; use Rector\PHPStanStaticTypeMapper\Contract\TypeMapperInterface; use Rector\StaticTypeMapper\ValueObject\Type\AliasedObjectType; use Rector\StaticTypeMapper\ValueObject\Type\FullyQualifiedObjectType; use Rector\StaticTypeMapper\ValueObject\Type\NonExistingObjectType; use Rector\StaticTypeMapper\ValueObject\Type\SelfObjectType; use Rector\StaticTypeMapper\ValueObject\Type\ShortenedObjectType; /** * @implements TypeMapperInterface<ObjectType> */ final class ObjectTypeMapper implements TypeMapperInterface { public function getNodeClass() : string { return ObjectType::class; } /** * @param ObjectType $type */ public function mapToPHPStanPhpDocTypeNode(Type $type) : TypeNode { $type = TypeTraverser::map($type, static function (Type $type, callable $traverse) : Type { if (!$type instanceof ObjectType) { return $traverse($type); } $typeClass = \get_class($type); // early native ObjectType check if ($typeClass === 'PHPStan\\Type\\ObjectType') { return new ObjectType('\\' . $type->getClassName()); } if ($type instanceof FullyQualifiedObjectType) { return new ObjectType('\\' . $type->getClassName()); } if ($type instanceof GenericObjectType) { return $traverse(new GenericObjectType('\\' . $type->getClassName(), $type->getTypes())); } return $traverse($type); }); return $type->toPhpDocNode(); } /** * @param ObjectType $type */ public function mapToPhpParserNode(Type $type, string $typeKind) : ?Node { if ($type instanceof SelfObjectType) { return new Name('self'); } if ($type instanceof ShortenedObjectType) { return new FullyQualified($type->getFullyQualifiedName()); } if ($type instanceof AliasedObjectType) { return new Name($type->getClassName()); } if ($type instanceof FullyQualifiedObjectType) { $className = $type->getClassName(); if (\strncmp($className, '\\', \strlen('\\')) === 0) { // skip leading \ return new FullyQualified(Strings::substring($className, 1)); } return new FullyQualified($className); } if ($type instanceof NonExistingObjectType) { return null; } return new FullyQualified($type->getClassName()); } }
[-] 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]