1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00
This commit is contained in:
Brown 2020-03-23 13:29:00 -04:00
parent 27a0651b6c
commit a7245b4459
2 changed files with 16 additions and 7 deletions

View File

@ -504,7 +504,12 @@ class AtomicMethodCallAnalyzer extends CallAnalyzer
$name_code_location,
$statements_analyzer->getSuppressedIssues()
) === false) {
self::updateResultReturnType($result, $return_type_candidate, $all_intersection_return_type);
self::updateResultReturnType(
$result,
$return_type_candidate,
$all_intersection_return_type,
$method_name_lc
);
return;
}
@ -703,14 +708,20 @@ class AtomicMethodCallAnalyzer extends CallAnalyzer
}
}
self::updateResultReturnType($result, $return_type_candidate, $all_intersection_return_type);
self::updateResultReturnType(
$result,
$return_type_candidate,
$all_intersection_return_type,
$method_name_lc
);
}
private static function updateResultReturnType(
AtomicMethodCallAnalysisResult $result,
?Type\Union $return_type_candidate,
?Type\Union $all_intersection_return_type
) {
?Type\Union $all_intersection_return_type,
string $method_name
) : void {
if ($return_type_candidate) {
if ($all_intersection_return_type) {
$return_type_candidate = Type::intersectUnionTypes(
@ -730,7 +741,7 @@ class AtomicMethodCallAnalyzer extends CallAnalyzer
} else {
$result->return_type = Type::combineUnionTypes($all_intersection_return_type, $result->return_type);
}
} elseif (strtolower($stmt->name->name) === '__tostring') {
} elseif ($method_name === '__tostring') {
$result->return_type = Type::getString();
} else {
$result->return_type = Type::getMixed();

View File

@ -79,8 +79,6 @@ class MethodCallReturnTypeFetcher
}
}
$return_type_candidate = null;
$class_storage = $codebase->methods->getClassLikeStorageForMethod($method_id);
if (CallMap::inCallMap((string) $call_map_id)) {