Commit 673c613
Fix in_array false positive with possibly-empty non-constant array
- For non-constant arrays that might be empty (isIterableAtLeastOnce is not yes),
return null (indeterminate) when the needle type is compatible with the haystack
value type, since the array could be empty making in_array return false
- Still correctly reports "always false" when needle type is incompatible with
haystack value type regardless of array emptiness
- Added regression test for the reported issue
Closes phpstan/phpstan#137991 parent 1b1f48c commit 673c613
File tree
3 files changed
+33
-0
lines changed- src/Rules/Comparison
- tests/PHPStan/Rules/Comparison
- data
3 files changed
+33
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
141 | 141 | | |
142 | 142 | | |
143 | 143 | | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
144 | 149 | | |
145 | 150 | | |
146 | 151 | | |
| |||
Lines changed: 6 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1195 | 1195 | | |
1196 | 1196 | | |
1197 | 1197 | | |
| 1198 | + | |
| 1199 | + | |
| 1200 | + | |
| 1201 | + | |
| 1202 | + | |
| 1203 | + | |
1198 | 1204 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
0 commit comments