diff --git a/src/Reflection/GenericParametersAcceptorResolver.php b/src/Reflection/GenericParametersAcceptorResolver.php index d9b75bf3e0..c72afeedbb 100644 --- a/src/Reflection/GenericParametersAcceptorResolver.php +++ b/src/Reflection/GenericParametersAcceptorResolver.php @@ -10,6 +10,7 @@ use PHPStan\Type\Generic\TemplateTypeMap; use PHPStan\Type\Generic\TemplateTypeVarianceMap; use PHPStan\Type\MixedType; +use PHPStan\Type\NeverType; use PHPStan\Type\Type; use PHPStan\Type\TypeCombinator; use function array_key_exists; @@ -61,6 +62,8 @@ public static function resolve(array $argTypes, ParametersAcceptor $parametersAc $argType = $namedArgTypes[$param->getName()]; } elseif ($param->getDefaultValue() !== null) { $argType = $param->getDefaultValue(); + } elseif ($param->isVariadic()) { + $argType = new NeverType(true); } else { continue; } diff --git a/tests/PHPStan/Analyser/nsrt/bug-2572.php b/tests/PHPStan/Analyser/nsrt/bug-2572.php new file mode 100644 index 0000000000..43720afb19 --- /dev/null +++ b/tests/PHPStan/Analyser/nsrt/bug-2572.php @@ -0,0 +1,49 @@ + 42)); +assertType('42', value(function ($foo) { + assertType('true', $foo); + + return 42; +}, true)); diff --git a/tests/PHPStan/Analyser/nsrt/bug-7704.php b/tests/PHPStan/Analyser/nsrt/bug-7704.php new file mode 100644 index 0000000000..45bb92fb96 --- /dev/null +++ b/tests/PHPStan/Analyser/nsrt/bug-7704.php @@ -0,0 +1,30 @@ +analyse([__DIR__ . '/data/bug-8936.php'], []); } + public function testBug2572(): void + { + $this->analyse([__DIR__ . '/../../Analyser/nsrt/bug-2572.php'], []); + } + + public function testBug7704(): void + { + $this->analyse([__DIR__ . '/../../Analyser/nsrt/bug-7704.php'], []); + } + + public function testBug9360(): void + { + $this->analyse([__DIR__ . '/../../Analyser/nsrt/bug-9360.php'], []); + } + public function testDumpFunctions(): void { $this->analyse([__DIR__ . '/data/dump-functions.php'], [