Valinor/tests/Fake/Definition/FakeParameterDefinition.php
Romain Canon b6b3296638 feat: handle variadic parameters in constructors
Using variadic parameters is now handled properly by the library,
meaning the following example will run:

```php
final class SomeClass
{
    /** @var string[] */
    private array $values;

    public function __construct(string ...$values)
    {
        $this->values = $values;
    }
}

(new \CuyZ\Valinor\MapperBuilder())
    ->mapper()
    ->map(SomeClass::class, ['foo', 'bar', 'baz']);
```
2022-02-19 20:17:03 +01:00

50 lines
1.3 KiB
PHP

<?php
declare(strict_types=1);
namespace CuyZ\Valinor\Tests\Fake\Definition;
use CuyZ\Valinor\Definition\ParameterDefinition;
use CuyZ\Valinor\Tests\Fake\Type\FakeType;
use CuyZ\Valinor\Type\Type;
use ReflectionParameter;
final class FakeParameterDefinition
{
private function __construct()
{
}
public static function new(string $name = 'someParameter', Type $type = null): ParameterDefinition
{
return new ParameterDefinition(
$name,
$name,
$type ?? new FakeType(),
false,
false,
null,
new FakeAttributes()
);
}
public static function fromReflection(ReflectionParameter $reflection): ParameterDefinition
{
$type = new FakeType();
if ($reflection->hasType()) {
$type = FakeType::from($reflection->getType()->getName()); // @phpstan-ignore-line
}
return new ParameterDefinition(
$reflection->name,
'Signature::' . $reflection->name,
$type,
$reflection->isOptional(),
$reflection->isVariadic(),
$reflection->isDefaultValueAvailable() ? $reflection->getDefaultValue() : null,
new FakeAttributes()
);
}
}