1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00

Fix - #816 - check we’re not just replacing a key with itself

This commit is contained in:
Matthew Brown 2018-06-13 08:38:07 -04:00
parent 45a94af015
commit dc02ca8a7a
2 changed files with 67 additions and 5 deletions

View File

@ -743,12 +743,14 @@ class Union
foreach ($this->types as $key => $atomic_type) {
if (isset($template_types[$key])) {
$keys_to_unset[] = $key;
$this->types[$template_types[$key]] = Atomic::create($template_types[$key]);
if ($template_types[$key] !== $key) {
$keys_to_unset[] = $key;
$this->types[$template_types[$key]] = Atomic::create($template_types[$key]);
if ($input_type) {
$generic_params[$key] = clone $input_type;
$generic_params[$key]->setFromDocblock();
if ($input_type) {
$generic_params[$key] = clone $input_type;
$generic_params[$key]->setFromDocblock();
}
}
} else {
$matching_atomic_type = null;

View File

@ -596,6 +596,66 @@ class TemplateTest extends TestCase
/** @param array<stdClass> $p */
function takesArrayOfStdClass(array $p): void {}',
],
'noRepeatedTypeException' => [
'<?php
/** @template T */
class Foo
{
/**
* @psalm-var class-string
*/
private $type;
/** @var array<T> */
private $items;
/**
* @param class-string $type
* @template-typeof T $type
*/
public function __construct(string $type)
{
if (!in_array($type, [A::class, B::class], true)) {
throw new \InvalidArgumentException;
}
$this->type = $type;
$this->items = [];
}
/** @param T $item */
public function add($item): void
{
$this->items[] = $item;
}
}
class FooFacade
{
/**
* @template T
* @param T $item
*/
public function add($item): void
{
$foo = $this->ensureFoo([$item]);
$foo->add($item);
}
/**
* @template T
* @param array<mixed,T> $items
* @return Foo<T>
*/
private function ensureFoo(array $items): EntitySeries
{
$type = $items[0] instanceof A ? A::class : B::class;
return new Foo($type);
}
}
class A {}
class B {}'
],
];
}