From 471d7610f095061dd34c9108513efd10ee62aa21 Mon Sep 17 00:00:00 2001 From: Matthew Brown Date: Fri, 17 Jan 2020 09:52:43 -0500 Subject: [PATCH] Fix #2644 - improve type inference of autoloaded constants --- .../Expression/Fetch/ConstFetchAnalyzer.php | 26 +++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/src/Psalm/Internal/Analyzer/Statements/Expression/Fetch/ConstFetchAnalyzer.php b/src/Psalm/Internal/Analyzer/Statements/Expression/Fetch/ConstFetchAnalyzer.php index 4516c9f74..3e68e23e7 100644 --- a/src/Psalm/Internal/Analyzer/Statements/Expression/Fetch/ConstFetchAnalyzer.php +++ b/src/Psalm/Internal/Analyzer/Statements/Expression/Fetch/ConstFetchAnalyzer.php @@ -101,6 +101,24 @@ class ConstFetchAnalyzer return Type::getResource(); } + if ($fq_const_name) { + $stubbed_const_type = $codebase->getStubbedConstantType( + $fq_const_name + ); + + if ($stubbed_const_type) { + return $stubbed_const_type; + } + } + + $stubbed_const_type = $codebase->getStubbedConstantType( + $const_name + ); + + if ($stubbed_const_type) { + return $stubbed_const_type; + } + $predefined_constants = $codebase->config->getPredefinedConstants(); if (($fq_const_name && array_key_exists($fq_const_name, $predefined_constants)) @@ -156,14 +174,6 @@ class ConstFetchAnalyzer return ClassLikeAnalyzer::getTypeFromValue($predefined_constants[$const_name]); } - $stubbed_const_type = $codebase->getStubbedConstantType( - $fq_const_name ?: $const_name - ); - - if ($stubbed_const_type) { - return $stubbed_const_type; - } - return null; } }