From 5579fd469b89c97063bb3c7062b5e9b776a3d72a Mon Sep 17 00:00:00 2001 From: robchett Date: Wed, 7 Feb 2024 20:37:00 +0000 Subject: [PATCH] Prevent mixed|null when function param is mixed with a null default value --- .../Reflector/FunctionLikeNodeScanner.php | 4 +++- tests/ArgTest.php | 14 ++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/src/Psalm/Internal/PhpVisitor/Reflector/FunctionLikeNodeScanner.php b/src/Psalm/Internal/PhpVisitor/Reflector/FunctionLikeNodeScanner.php index f04a90072d0..f0a8f34cc63 100644 --- a/src/Psalm/Internal/PhpVisitor/Reflector/FunctionLikeNodeScanner.php +++ b/src/Psalm/Internal/PhpVisitor/Reflector/FunctionLikeNodeScanner.php @@ -825,7 +825,9 @@ private function getTranslatedFunctionParam( $this->codebase->analysis_php_version_id, ); - if ($is_nullable) { + if ($param_type->isMixed()) { + $is_nullable = false; + } elseif ($is_nullable) { $param_type = $param_type->getBuilder()->addType(new TNull)->freeze(); } else { $is_nullable = $param_type->isNullable(); diff --git a/tests/ArgTest.php b/tests/ArgTest.php index 5fefdbef086..36efb359362 100644 --- a/tests/ArgTest.php +++ b/tests/ArgTest.php @@ -355,6 +355,20 @@ function foo($a, ...$b) {} var_caller("foo");', ], + 'mixedNullable' => [ + 'code' => 'default;', + 'assertions' => [ + '$_v===' => 'mixed', + ], + 'ignored_issues' => [], + 'php_version' => '8.0', + ], ]; }