From 1f2d2764abf577f69b061acb44bd240f74fa412e Mon Sep 17 00:00:00 2001 From: Matt Brown Date: Wed, 7 Oct 2020 17:47:17 -0400 Subject: [PATCH] Fix #4287 - intersection of regular arrays should not result in crash --- src/Psalm/Internal/Type/TypeParser.php | 5 +++-- tests/TypeParseTest.php | 6 ++++++ 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/Psalm/Internal/Type/TypeParser.php b/src/Psalm/Internal/Type/TypeParser.php index 136c80800..e77bc710e 100644 --- a/src/Psalm/Internal/Type/TypeParser.php +++ b/src/Psalm/Internal/Type/TypeParser.php @@ -411,11 +411,12 @@ class TypeParser $parse_tree->children ); - $onlyTKeyedArray = true; - $first_type = \reset($intersection_types); $last_type = \end($intersection_types); + $onlyTKeyedArray = $first_type instanceof TKeyedArray + && $last_type instanceof TKeyedArray; + foreach ($intersection_types as $intersection_type) { if (!$intersection_type instanceof TKeyedArray && ($intersection_type !== $first_type diff --git a/tests/TypeParseTest.php b/tests/TypeParseTest.php index e9abb4d9a..69c753c89 100644 --- a/tests/TypeParseTest.php +++ b/tests/TypeParseTest.php @@ -203,6 +203,12 @@ class TypeParseTest extends TestCase Type::parseString('array{a: string}&array{a: int}'); } + public function testIntersectionOfTwoRegularArrays() : void + { + $this->expectException(\Psalm\Exception\TypeParseTreeException::class); + Type::parseString('string[]&array'); + } + public function testUnionOfIntersectionOfTKeyedArray(): void { $this->assertSame('array{a: int|string, b?: int}', (string) Type::parseString('array{a: int}|array{a: string}&array{b: int}'));