1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-13 09:47:29 +01:00

fix build

This commit is contained in:
orklah 2021-08-16 21:56:37 +02:00
parent 9264ea5cbb
commit 7308c86bb2

View File

@ -32,6 +32,10 @@ use function strtolower;
*/ */
class ClassConstFetchAnalyzer class ClassConstFetchAnalyzer
{ {
/**
* @psalm-suppress ComplexMethod to be refactored. We should probably regroup the two big if about $stmt->class and
* analyse the ::class int $stmt->name separately
*/
public static function analyze( public static function analyze(
StatementsAnalyzer $statements_analyzer, StatementsAnalyzer $statements_analyzer,
PhpParser\Node\Expr\ClassConstFetch $stmt, PhpParser\Node\Expr\ClassConstFetch $stmt,
@ -475,9 +479,7 @@ class ClassConstFetchAnalyzer
$statements_analyzer, $statements_analyzer,
$stmt->class, $stmt->class,
$fq_class_name, $fq_class_name,
$context->calling_method_id, $context->calling_method_id
false,
false
); );
} }
@ -485,41 +487,6 @@ class ClassConstFetchAnalyzer
$fq_class_name = $codebase->classlikes->getUnAliasedName($fq_class_name); $fq_class_name = $codebase->classlikes->getUnAliasedName($fq_class_name);
} }
if ($stmt->name instanceof PhpParser\Node\Identifier && $stmt->name->name === 'class') {
if ($codebase->classlikes->classExists($fq_class_name)) {
$const_class_storage = $codebase->classlike_storage_provider->get($fq_class_name);
$fq_class_name = $const_class_storage->name;
if ($const_class_storage->deprecated && $fq_class_name !== $context->self) {
if (IssueBuffer::accepts(
new DeprecatedClass(
'Class ' . $fq_class_name . ' is deprecated',
new CodeLocation($statements_analyzer->getSource(), $stmt),
$fq_class_name
),
$statements_analyzer->getSuppressedIssues()
)) {
// fall through
}
}
}
$statements_analyzer->node_data->setType($stmt, Type::getLiteralClassString($fq_class_name));
if ($codebase->store_node_types
&& !$context->collect_initializations
&& !$context->collect_mutations
) {
$codebase->analyzer->addNodeReference(
$statements_analyzer->getFilePath(),
$stmt->class,
$fq_class_name
);
}
return true;
}
// if we're ignoring that the class doesn't exist, exit anyway // if we're ignoring that the class doesn't exist, exit anyway
if (!$codebase->classlikes->classOrInterfaceOrEnumExists($fq_class_name)) { if (!$codebase->classlikes->classOrInterfaceOrEnumExists($fq_class_name)) {
$statements_analyzer->node_data->setType($stmt, Type::getMixed()); $statements_analyzer->node_data->setType($stmt, Type::getMixed());