mirror of
https://github.com/danog/psalm.git
synced 2024-11-27 04:45:20 +01:00
Change evaluation order of conditionals
This commit is contained in:
parent
e4bfe9e6be
commit
fbe0669921
@ -160,7 +160,5 @@ class TConditional extends \Psalm\Type\Atomic
|
||||
?Codebase $codebase
|
||||
) : void {
|
||||
$this->conditional_type->replaceTemplateTypesWithArgTypes($template_result, $codebase);
|
||||
$this->if_type->replaceTemplateTypesWithArgTypes($template_result, $codebase);
|
||||
$this->else_type->replaceTemplateTypesWithArgTypes($template_result, $codebase);
|
||||
}
|
||||
}
|
||||
|
@ -11,6 +11,11 @@ class TNumericString extends TString
|
||||
return 'numeric-string';
|
||||
}
|
||||
|
||||
public function __toString()
|
||||
{
|
||||
return 'numeric-string';
|
||||
}
|
||||
|
||||
public function getId(bool $nested = false)
|
||||
{
|
||||
return $this->getKey();
|
||||
|
@ -1321,6 +1321,10 @@ class Union implements TypeNode
|
||||
$atomic_type->conditional_type
|
||||
)) {
|
||||
$class_template_type = clone $atomic_type->if_type;
|
||||
$class_template_type->replaceTemplateTypesWithArgTypes(
|
||||
$template_result,
|
||||
$codebase
|
||||
);
|
||||
} elseif (TypeAnalyzer::isContainedBy(
|
||||
$codebase,
|
||||
$template_type,
|
||||
@ -1333,10 +1337,24 @@ class Union implements TypeNode
|
||||
)
|
||||
) {
|
||||
$class_template_type = clone $atomic_type->else_type;
|
||||
$class_template_type->replaceTemplateTypesWithArgTypes(
|
||||
$template_result,
|
||||
$codebase
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
if (!$class_template_type) {
|
||||
$atomic_type->if_type->replaceTemplateTypesWithArgTypes(
|
||||
$template_result,
|
||||
$codebase
|
||||
);
|
||||
|
||||
$atomic_type->else_type->replaceTemplateTypesWithArgTypes(
|
||||
$template_result,
|
||||
$codebase
|
||||
);
|
||||
|
||||
$class_template_type = Type::combineUnionTypes(
|
||||
$atomic_type->if_type,
|
||||
$atomic_type->else_type,
|
||||
@ -1385,6 +1403,8 @@ class Union implements TypeNode
|
||||
$atomic_types,
|
||||
$codebase
|
||||
)->getAtomicTypes();
|
||||
|
||||
$this->id = null;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user