From d1262b0beccc74772d1650499806a61ad4004431 Mon Sep 17 00:00:00 2001 From: Matt Brown Date: Sun, 23 May 2021 14:39:54 -0400 Subject: [PATCH] =?UTF-8?q?Fix=20#5799=20=E2=80=94=20improve=20expansion?= =?UTF-8?q?=20of=20templated=20types?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Type/TemplateInferredTypeReplacer.php | 17 +++++++----- tests/Template/ClassTemplateTest.php | 26 +++++++++++++++++++ 2 files changed, 37 insertions(+), 6 deletions(-) diff --git a/src/Psalm/Internal/Type/TemplateInferredTypeReplacer.php b/src/Psalm/Internal/Type/TemplateInferredTypeReplacer.php index 2922f3b8d..46d028351 100644 --- a/src/Psalm/Internal/Type/TemplateInferredTypeReplacer.php +++ b/src/Psalm/Internal/Type/TemplateInferredTypeReplacer.php @@ -117,7 +117,7 @@ class TemplateInferredTypeReplacer $is_mixed = true; } - $new_types[$template_type_part->getKey()] = $template_type_part; + $new_types[] = $template_type_part; } } } elseif ($atomic_type instanceof Atomic\TTemplateParamClass) { @@ -153,7 +153,7 @@ class TemplateInferredTypeReplacer if ($class_template_type) { $keys_to_unset[] = $key; - $new_types[$class_template_type->getKey()] = $class_template_type; + $new_types[] = $class_template_type; } } elseif ($atomic_type instanceof Atomic\TTemplateIndexedAccess) { $keys_to_unset[] = $key; @@ -194,10 +194,10 @@ class TemplateInferredTypeReplacer $is_mixed = true; } - $new_types[$template_type_part->getKey()] = $template_type_part; + $new_types[] = $template_type_part; } } else { - $new_types[$key] = new Atomic\TMixed(); + $new_types[] = new Atomic\TMixed(); } } elseif ($atomic_type instanceof Atomic\TConditional && $codebase @@ -347,7 +347,7 @@ class TemplateInferredTypeReplacer $keys_to_unset[] = $key; foreach ($class_template_type->getAtomicTypes() as $class_template_atomic_type) { - $new_types[$class_template_atomic_type->getKey()] = $class_template_atomic_type; + $new_types[] = $class_template_atomic_type; } } } @@ -359,7 +359,12 @@ class TemplateInferredTypeReplacer throw new \UnexpectedValueException('This array should be full'); } - $union->replaceTypes($new_types); + $union->replaceTypes( + TypeCombiner::combine( + $new_types, + $codebase + )->getAtomicTypes() + ); return; } diff --git a/tests/Template/ClassTemplateTest.php b/tests/Template/ClassTemplateTest.php index 90398a89b..5b8824612 100644 --- a/tests/Template/ClassTemplateTest.php +++ b/tests/Template/ClassTemplateTest.php @@ -3371,6 +3371,32 @@ class ClassTemplateTest extends TestCase } ', ], + 'combineTwoTemplatedArrays' => [ + 'v : $else; + } + } + + $opt = new Option([1, 3]); + + $b = $opt->getOrElse([2, 4])[0];', + [ + '$b===' => '1|2' + ] + ], ]; }