-
Notifications
You must be signed in to change notification settings - Fork 25
Expand file tree
/
Copy pathNamedToUnnamedArgs.php
More file actions
116 lines (100 loc) · 3.61 KB
/
NamedToUnnamedArgs.php
File metadata and controls
116 lines (100 loc) · 3.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
<?php
declare(strict_types=1);
namespace Rector\DowngradePhp80\NodeAnalyzer;
use PhpParser\Node\Arg;
use PhpParser\Node\Expr;
use PhpParser\Node\Identifier;
use PHPStan\Reflection\FunctionReflection;
use PHPStan\Reflection\MethodReflection;
use PHPStan\Reflection\ParameterReflection;
use PHPStan\Reflection\Php\PhpParameterReflection;
use Rector\DowngradePhp80\Reflection\DefaultParameterValueResolver;
use Rector\DowngradePhp80\Reflection\SimplePhpParameterReflection;
use Rector\NodeNameResolver\NodeNameResolver;
use ReflectionFunction;
final readonly class NamedToUnnamedArgs
{
public function __construct(
private NodeNameResolver $nodeNameResolver,
private DefaultParameterValueResolver $defaultParameterValueResolver
) {
}
/**
* @param ParameterReflection[]|PhpParameterReflection[] $parameters
* @param array<int, Arg> $currentArgs
* @param string[] $toFillArgs
* @param array<int, Arg> $unnamedArgs
* @return array<int, Arg>
*/
public function fillFromNamedArgs(
array $parameters,
array $currentArgs,
array $toFillArgs,
array $unnamedArgs
): array {
foreach ($parameters as $paramPosition => $parameterReflection) {
$parameterReflectionName = $parameterReflection->getName();
if (! in_array($parameterReflectionName, $toFillArgs, true)) {
continue;
}
foreach ($currentArgs as $currentArg) {
if (! $currentArg->name instanceof Identifier) {
continue;
}
if (! $this->nodeNameResolver->isName($currentArg->name, $parameterReflectionName)) {
continue;
}
$unnamedArgs[$paramPosition] = new Arg(
$currentArg->value,
$currentArg->byRef,
$currentArg->unpack,
[]
);
}
}
return $unnamedArgs;
}
/**
* @param array<int, Arg> $unnamedArgs
* @param ParameterReflection[]|PhpParameterReflection[] $parameters
* @return array<int, Arg>
*/
public function fillFromJumpedNamedArgs(
FunctionReflection | MethodReflection | ReflectionFunction $functionLikeReflection,
array $unnamedArgs,
array $parameters
): array {
$keys = array_keys($unnamedArgs);
if ($keys === []) {
return $unnamedArgs;
}
$highestParameterPosition = max($keys);
$parametersCount = count($parameters);
for ($i = 0; $i < $parametersCount; ++$i) {
if (in_array($i, $keys, true)) {
continue;
}
if ($i > $highestParameterPosition) {
continue;
}
/** @var ParameterReflection|PhpParameterReflection $parameterReflection */
if ($functionLikeReflection instanceof ReflectionFunction) {
$parameterReflection = new SimplePhpParameterReflection($functionLikeReflection, $i);
} else {
$parameterReflection = $parameters[$i];
}
$defaultValue = $this->defaultParameterValueResolver->resolveFromParameterReflection($parameterReflection);
if (! $defaultValue instanceof Expr) {
continue;
}
$unnamedArgs[$i] = new Arg(
$defaultValue,
$parameterReflection->passedByReference()
->yes(),
$parameterReflection->isVariadic(),
[]
);
}
return $unnamedArgs;
}
}