1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00

Allow references to enum cases in class constants

This commit is contained in:
Bruce Weirdan 2021-11-15 05:56:09 +02:00
parent 0b7183107c
commit 0a9154b8bb
No known key found for this signature in database
GPG Key ID: CFC3AAB181751B0D
4 changed files with 67 additions and 30 deletions

View File

@ -1627,10 +1627,7 @@ class ClassLikes
$storage = $this->classlike_storage_provider->get($class_name); $storage = $this->classlike_storage_provider->get($class_name);
if (!isset($storage->constants[$constant_name])) { if (isset($storage->constants[$constant_name])) {
return null;
}
$constant_storage = $storage->constants[$constant_name]; $constant_storage = $storage->constants[$constant_name];
if ($visibility === ReflectionProperty::IS_PUBLIC if ($visibility === ReflectionProperty::IS_PUBLIC
@ -1656,6 +1653,10 @@ class ClassLikes
} }
return $constant_storage->type; return $constant_storage->type;
} elseif (isset($storage->enum_cases[$constant_name])) {
return new Type\Union([new Type\Atomic\TEnumCase($storage->name, $constant_name)]);
}
return null;
} }
private function checkMethodReferences(ClassLikeStorage $classlike_storage, Methods $methods): void private function checkMethodReferences(ClassLikeStorage $classlike_storage, Methods $methods): void

View File

@ -7,7 +7,7 @@ class ConstantTest extends TestCase
use Traits\ValidCodeAnalysisTestTrait; use Traits\ValidCodeAnalysisTestTrait;
/** /**
* @return iterable<string,array{string,assertions?:array<string,string>,error_levels?:string[]}> * @return iterable<string,array{string,assertions?:array<string,string>,error_levels?:string[], php_version?: string}>
*/ */
public function providerValidCodeParse(): iterable public function providerValidCodeParse(): iterable
{ {
@ -1180,6 +1180,22 @@ class ConstantTest extends TestCase
}', }',
], ],
'classConstantReferencingEnumCase' => [
'<?php
enum E {
case Z;
}
class C {
public const CC = E::Z;
}
$c = C::CC;
',
'assertions' => [
'$c===' => 'enum(E::Z)'
],
[],
'8.1'
],
]; ];
} }

View File

@ -154,6 +154,26 @@ class EnumTest extends TestCase
[], [],
'8.1' '8.1'
], ],
'SKIPPED-wildcardEnum' => [
'<?php
enum A {
case C_1;
case C_2;
case C_3;
/**
* @param self::C_* $i
*/
public static function foo(self $i) : void {}
}
A::foo(A::C_1);
A::foo(A::C_2);
A::foo(A::C_3);',
'assertions' => [],
[],
'8.1',
],
]; ];
} }

View File

@ -15,7 +15,7 @@ use const PHP_VERSION;
trait ValidCodeAnalysisTestTrait trait ValidCodeAnalysisTestTrait
{ {
/** /**
* @return iterable<string,array{string,assertions?:array<string,string>,error_levels?:string[]}> * @return iterable<string,array{string,assertions?:array<string,string>,error_levels?:string[],php_version?:string}>
*/ */
abstract public function providerValidCodeParse(): iterable; abstract public function providerValidCodeParse(): iterable;