mirror of
https://github.com/danog/psalm.git
synced 2024-11-27 12:55:26 +01:00
add tests, improve count behaviour on keyed arrays using integer range
This commit is contained in:
parent
7bf9df4360
commit
a7fa63547e
@ -325,12 +325,23 @@ class FunctionCallReturnTypeFetcher
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($atomic_types['array'] instanceof Type\Atomic\TKeyedArray
|
if ($atomic_types['array'] instanceof Type\Atomic\TKeyedArray) {
|
||||||
&& $atomic_types['array']->isNonEmpty()
|
$min = 0;
|
||||||
) {
|
$max = 0;
|
||||||
return new Type\Union([
|
foreach ($atomic_types['array']->properties as $property) {
|
||||||
new Type\Atomic\TLiteralInt(count($atomic_types['array']->properties))
|
if (!$property->possibly_undefined) {
|
||||||
]);
|
$min++;
|
||||||
|
}
|
||||||
|
$max++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($atomic_types['array']->sealed) {
|
||||||
|
//the KeyedArray is sealed, we can use the min and max
|
||||||
|
return new Type\Union([new Type\Atomic\TIntRange($min, $max)]);
|
||||||
|
} else {
|
||||||
|
//the type is not sealed, we can only use the min
|
||||||
|
return new Type\Union([new Type\Atomic\TIntRange($min, null)]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Type\Union([
|
return new Type\Union([
|
||||||
|
@ -1103,6 +1103,29 @@ class TypeTest extends \Psalm\Tests\TestCase
|
|||||||
}
|
}
|
||||||
',
|
',
|
||||||
],
|
],
|
||||||
|
'CountEqual0MakesNonEmptyArray' => [
|
||||||
|
'<?php
|
||||||
|
function a(array $a): void {
|
||||||
|
if (count($a) === 0) {
|
||||||
|
throw new \LogicException;
|
||||||
|
}
|
||||||
|
expectNonEmptyArray($a);
|
||||||
|
}
|
||||||
|
function b(array $a): void {
|
||||||
|
if (count($a) !== 0) {
|
||||||
|
expectNonEmptyArray($a);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function c(array $a): void {
|
||||||
|
if (count($a) === 0) {
|
||||||
|
throw new \LogicException;
|
||||||
|
} else {
|
||||||
|
expectNonEmptyArray($a);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/** @param non-empty-array $a */
|
||||||
|
function expectNonEmptyArray(array $a): array { return $a; }'
|
||||||
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user