mirror of
https://github.com/danog/psalm.git
synced 2024-11-30 04:39:00 +01:00
Fix issue with nullable types going into docblock
This commit is contained in:
parent
fe96868e27
commit
66fa081488
@ -423,7 +423,7 @@ abstract class FunctionLikeChecker extends SourceChecker implements StatementsSo
|
||||
if ($project_checker->alter_code
|
||||
&& isset($project_checker->getIssuesToFix()['MismatchingDocblockReturnType'])
|
||||
) {
|
||||
$this->addOrUpdateReturnType($project_checker, $storage->signature_return_type, true);
|
||||
$this->addOrUpdateReturnType($project_checker, $storage->signature_return_type);
|
||||
|
||||
return null;
|
||||
}
|
||||
@ -1331,7 +1331,7 @@ abstract class FunctionLikeChecker extends SourceChecker implements StatementsSo
|
||||
&& !$declared_return_type->isVoid()
|
||||
) {
|
||||
if ($project_checker->alter_code
|
||||
&& isset($project_checker->getIssuesToFix()['UnexpectedNullableReturnType'])
|
||||
&& isset($project_checker->getIssuesToFix()['InvalidNullableReturnType'])
|
||||
) {
|
||||
$this->addOrUpdateReturnType(
|
||||
$project_checker,
|
||||
|
@ -350,7 +350,6 @@ class FunctionDocblockManipulator
|
||||
}
|
||||
} elseif ($manipulator->return_typehint_colon_start
|
||||
&& $manipulator->new_phpdoc_return_type
|
||||
&& !$manipulator->return_type_is_php_compatible
|
||||
&& $manipulator->return_typehint_start
|
||||
&& $manipulator->return_typehint_end
|
||||
) {
|
||||
|
@ -449,7 +449,7 @@ class FileManipulationTest extends TestCase
|
||||
['InvalidReturnType'],
|
||||
true,
|
||||
],
|
||||
'fixInvalidIntReturnTypeThatIsNotPhpCompatible70' => [
|
||||
'fixInvalidStringReturnTypeThatIsNotPhpCompatible70' => [
|
||||
'<?php
|
||||
function foo() : string {
|
||||
return rand(0, 1) ? "hello" : false;
|
||||
@ -465,6 +465,22 @@ class FileManipulationTest extends TestCase
|
||||
['InvalidFalsableReturnType'],
|
||||
true,
|
||||
],
|
||||
'fixInvalidIntReturnTypeThatIsNotPhpCompatible70' => [
|
||||
'<?php
|
||||
function foo() : string {
|
||||
return rand(0, 1) ? "hello" : null;
|
||||
}',
|
||||
'<?php
|
||||
/**
|
||||
* @return string|null
|
||||
*/
|
||||
function foo() {
|
||||
return rand(0, 1) ? "hello" : null;
|
||||
}',
|
||||
'7.0',
|
||||
['InvalidNullableReturnType'],
|
||||
true,
|
||||
],
|
||||
'fixInvalidIntReturnTypeJustInTypehintWithComment70' => [
|
||||
'<?php
|
||||
function foo() /** cool : beans */ : int /** cool : beans */ {
|
||||
|
Loading…
Reference in New Issue
Block a user