mirror of
https://github.com/danog/psalm.git
synced 2024-12-12 09:19:40 +01:00
Callable type expansion for more readable error message
This commit is contained in:
parent
0456ef82a5
commit
7fba401fdd
@ -243,8 +243,9 @@ class ArgumentsAnalyzer
|
|||||||
|
|
||||||
$context->inside_call = $was_inside_call;
|
$context->inside_call = $was_inside_call;
|
||||||
|
|
||||||
if ($high_order_callable_info) {
|
if ($high_order_callable_info && $high_order_template_result) {
|
||||||
HighOrderFunctionArgHandler::enhanceCallableArgType(
|
HighOrderFunctionArgHandler::enhanceCallableArgType(
|
||||||
|
$context,
|
||||||
$arg->value,
|
$arg->value,
|
||||||
$statements_analyzer,
|
$statements_analyzer,
|
||||||
$high_order_callable_info,
|
$high_order_callable_info,
|
||||||
|
@ -12,6 +12,7 @@ use Psalm\Internal\MethodIdentifier;
|
|||||||
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
|
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
|
||||||
use Psalm\Internal\Type\TemplateResult;
|
use Psalm\Internal\Type\TemplateResult;
|
||||||
use Psalm\Internal\Type\TemplateStandinTypeReplacer;
|
use Psalm\Internal\Type\TemplateStandinTypeReplacer;
|
||||||
|
use Psalm\Internal\Type\TypeExpander;
|
||||||
use Psalm\Storage\FunctionLikeParameter;
|
use Psalm\Storage\FunctionLikeParameter;
|
||||||
use Psalm\Type;
|
use Psalm\Type;
|
||||||
use Psalm\Type\Atomic\TCallable;
|
use Psalm\Type\Atomic\TCallable;
|
||||||
@ -73,19 +74,33 @@ final class HighOrderFunctionArgHandler
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static function enhanceCallableArgType(
|
public static function enhanceCallableArgType(
|
||||||
|
Context $context,
|
||||||
PhpParser\Node\Expr $arg_expr,
|
PhpParser\Node\Expr $arg_expr,
|
||||||
StatementsAnalyzer $statements_analyzer,
|
StatementsAnalyzer $statements_analyzer,
|
||||||
HighOrderFunctionArgInfo $high_order_callable_info,
|
HighOrderFunctionArgInfo $high_order_callable_info,
|
||||||
?TemplateResult $high_order_template_result
|
TemplateResult $high_order_template_result
|
||||||
): void {
|
): void {
|
||||||
if ($high_order_callable_info->getType() === HighOrderFunctionArgInfo::TYPE_CALLABLE) {
|
if ($high_order_callable_info->getType() === HighOrderFunctionArgInfo::TYPE_CALLABLE) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$statements_analyzer->node_data->setType($arg_expr, TemplateInferredTypeReplacer::replace(
|
$replaced = TemplateInferredTypeReplacer::replace(
|
||||||
$high_order_callable_info->getFunctionType(),
|
$high_order_callable_info->getFunctionType(),
|
||||||
$high_order_template_result ?? new TemplateResult([], []),
|
$high_order_template_result,
|
||||||
$statements_analyzer->getCodebase(),
|
$statements_analyzer->getCodebase(),
|
||||||
|
);
|
||||||
|
|
||||||
|
$statements_analyzer->node_data->setType($arg_expr, TypeExpander::expandUnion(
|
||||||
|
$statements_analyzer->getCodebase(),
|
||||||
|
$replaced,
|
||||||
|
$context->self,
|
||||||
|
$context->self,
|
||||||
|
$context->parent,
|
||||||
|
true,
|
||||||
|
true,
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
true,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user