mirror of
https://github.com/danog/psalm.git
synced 2025-01-21 21:31:13 +01:00
Prevent more array<mixed,...> creation
This commit is contained in:
parent
952045e2ba
commit
6ad3d039df
@ -530,11 +530,15 @@ class ArrayAssignmentAnalyzer
|
||||
} elseif (!$root_is_string) {
|
||||
if ($current_dim) {
|
||||
if ($current_dim_type = $statements_analyzer->node_data->getType($current_dim)) {
|
||||
if ($current_dim_type->isMixed()) {
|
||||
$current_dim_type = Type::getArrayKey();
|
||||
}
|
||||
|
||||
$array_atomic_key_type = ArrayFetchAnalyzer::replaceOffsetTypeWithInts(
|
||||
$current_dim_type
|
||||
);
|
||||
} else {
|
||||
$array_atomic_key_type = Type::getMixed();
|
||||
$array_atomic_key_type = Type::getArrayKey();
|
||||
}
|
||||
|
||||
if ($offset_already_existed
|
||||
|
@ -536,7 +536,9 @@ class ArrayFetchAnalyzer
|
||||
// if we're assigning to an empty array with a key offset, refashion that array
|
||||
if ($in_assignment) {
|
||||
if ($type->type_params[0]->isEmpty()) {
|
||||
$type->type_params[0] = $offset_type;
|
||||
$type->type_params[0] = $offset_type->isMixed()
|
||||
? Type::getArrayKey()
|
||||
: $offset_type;
|
||||
}
|
||||
} elseif (!$type->type_params[0]->isEmpty()) {
|
||||
$expected_offset_type = $type->type_params[0]->hasMixed()
|
||||
@ -954,7 +956,7 @@ class ArrayFetchAnalyzer
|
||||
|
||||
$new_key_type = Type::combineUnionTypes(
|
||||
$generic_key_type,
|
||||
$offset_type
|
||||
$offset_type->isMixed() ? Type::getArrayKey() : $offset_type
|
||||
);
|
||||
|
||||
$property_count = $type->sealed ? count($type->properties) : null;
|
||||
|
@ -1052,6 +1052,12 @@ class TypeAnalyzer
|
||||
return true;
|
||||
}
|
||||
|
||||
if ($container_type_part instanceof TArrayKey
|
||||
&& $input_type_part instanceof TNumeric
|
||||
) {
|
||||
return true;
|
||||
}
|
||||
|
||||
if ($container_type_part instanceof TArrayKey
|
||||
&& ($input_type_part instanceof TInt
|
||||
|| $input_type_part instanceof TString
|
||||
|
@ -1320,6 +1320,39 @@ class ArrayAssignmentTest extends TestCase
|
||||
}
|
||||
}',
|
||||
],
|
||||
'arrayMixedMixedNotAllowedFromObject' => [
|
||||
'<?php
|
||||
function foo(ArrayObject $a) : array {
|
||||
$arr = [];
|
||||
|
||||
/**
|
||||
* @psalm-suppress MixedAssignment
|
||||
* @psalm-suppress MixedArrayOffset
|
||||
*/
|
||||
foreach ($a as $k => $v) {
|
||||
$arr[$k] = $v;
|
||||
}
|
||||
|
||||
return $arr;
|
||||
}',
|
||||
],
|
||||
'arrayMixedMixedNotAllowedFromMixed' => [
|
||||
'<?php
|
||||
/** @psalm-suppress MissingParamType */
|
||||
function foo($a) : array {
|
||||
$arr = ["a" => "foo"];
|
||||
|
||||
/**
|
||||
* @psalm-suppress MixedAssignment
|
||||
* @psalm-suppress MixedArrayOffset
|
||||
*/
|
||||
foreach ($a as $k => $v) {
|
||||
$arr[$k] = $v;
|
||||
}
|
||||
|
||||
return $arr;
|
||||
}',
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user