Skip to content

Commit 2f66c45

Browse files
committed
Preserve constant array when assigning a union of scalars
1 parent 0a777ef commit 2f66c45

6 files changed

Lines changed: 28 additions & 9 deletions

File tree

src/Type/Constant/ConstantArrayTypeBuilder.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -286,7 +286,7 @@ public function setOffsetValueType(?Type $offsetType, Type $valueType, bool $opt
286286
return;
287287
}
288288

289-
if (!$hasMatch && count($this->keyTypes) > 0) {
289+
if (!$hasMatch) {
290290
foreach ($scalarTypes as $scalarType) {
291291
$this->keyTypes[] = $scalarType;
292292
$this->valueTypes[] = $valueType;

tests/PHPStan/Analyser/nsrt/array-change-key-case.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -78,7 +78,7 @@ public function sayHello(
7878
assertType('array{foo: 1, bar?: 2}', array_change_key_case($arr9));
7979
assertType('array{foo: 1, bar?: 2}', array_change_key_case($arr9, CASE_LOWER));
8080
assertType('array{FOO: 1, BAR?: 2}', array_change_key_case($arr9, CASE_UPPER));
81-
assertType("non-empty-array<'BAR'|'bar'|'FOO'|'foo', 1|2>", array_change_key_case($arr9, $case));
81+
assertType("non-empty-array{foo?: 1, FOO?: 1, bar?: 2, BAR?: 2}", array_change_key_case($arr9, $case));
8282

8383
assertType("array<'bar'|'foo', string>", array_change_key_case($arr10));
8484
assertType("array<'bar'|'foo', string>", array_change_key_case($arr10, CASE_LOWER));

tests/PHPStan/Analyser/nsrt/bug-13786.php

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,10 @@
1414
foreach ($cols as $col) {
1515
$total[$id][$col] = '0';
1616
}
17-
assertType("non-empty-array<'a'|'b'|'c'|'d', '0'>", $total[$id]);
17+
assertType("non-empty-array{a?: '0', b?: '0', c?: '0', d?: '0'}", $total[$id]);
1818
$total[$id]['d'] = '0';
19-
assertType("non-empty-array<'a'|'b'|'c'|'d', '0'>&hasOffsetValue('d', '0')", $total[$id]);
19+
assertType("array{a?: '0', b?: '0', c?: '0', d: '0'}", $total[$id]);
2020
}
2121

2222
$total[$id]['e'] = '1';
23-
assertType("non-empty-array<'a'|'b'|'c'|'d'|'e', '0'|'1'>&hasOffsetValue('e', '1')", $total[$id]);
23+
assertType("array{a?: '0', b?: '0', c?: '0', d?: '0', e: '1'}", $total[$id]);

tests/PHPStan/Analyser/nsrt/bug-14333.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -83,7 +83,7 @@ function testMultipleScalarKeyValues(bool $key): void
8383

8484
// $key could be 1 (true) so $b[1] = 3 might also update $a
8585
$b[1] = 3;
86-
assertType('1|2|3', $a);
86+
assertType('2|3', $a);
8787
}
8888

8989
/** @param 'a'|'b' $key */

tests/PHPStan/Analyser/nsrt/bug-14489.php

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ function () {
2323
}
2424

2525
$values = array_values($cData);
26-
assertType('non-empty-list<non-empty-array<0|1, 1|4>>', $values);
26+
assertType('list{0?: non-empty-array<0|1, 1|4>, 1?: non-empty-array<0|1, 1|4>}', $values);
2727
};
2828

2929
function () {
@@ -35,12 +35,12 @@ function () {
3535
$cData = [];
3636
while (rand(0, 1)) {
3737
if (array_key_exists($c, $cData)) {
38-
assertType('non-empty-array<\'c1\'|\'c2\', array{1}|array{4}>', $cData);
38+
assertType('non-empty-array{c1?: array{1}|array{4}, c2?: array{1}|array{4}}', $cData);
3939
assertType('array{1}|array{4}', $cData[$c]);
4040
$cData[$c] = $cData[$c];
4141
} else {
4242
$cData[$c] = $ids;
4343
}
4444
}
45-
assertType('array<\'c1\'|\'c2\', array{1}|array{4}>', $cData);
45+
assertType('array{}|array{c1?: array{1}|array{4}, c2?: array{1}|array{4}}', $cData);
4646
};
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
<?php
2+
3+
namespace SetUnionOffsetPreserveConstantArray;
4+
5+
use function PHPStan\Testing\assertType;
6+
7+
class Foo
8+
{
9+
10+
public function doFoo(): void
11+
{
12+
$a = [];
13+
14+
$k = rand(0, 1) ? 1 : 2;
15+
$a[$k] = true;
16+
assertType('array{1?: true, 2?: true}', $a);
17+
}
18+
19+
}

0 commit comments

Comments
 (0)