1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00

If the statement contains an or, do not make assumptions

This commit is contained in:
Matthew Brown 2016-04-03 14:50:57 -04:00
parent e542b876f8
commit 78123ada52

View File

@ -198,7 +198,7 @@ class StatementsChecker
$negated_if_types = $negated_types;
// if the if has an or as the main component, we cannot safely reason about it
if ($stmt->cond instanceof PhpParser\Node\Expr\BinaryOp\BooleanOr) {
if ($stmt->cond instanceof PhpParser\Node\Expr\BinaryOp && self::_containsBooleanOr($stmt->cond)) {
$if_vars = array_merge([], $vars_in_scope);
$if_vars_possibly_in_scope = array_merge([], $vars_possibly_in_scope);
}
@ -2411,6 +2411,20 @@ class StatementsChecker
return $result_types;
}
protected static function _containsBooleanOr(PhpParser\Node\Expr\BinaryOp $stmt)
{
if ($stmt instanceof PhpParser\Node\Expr\BinaryOp\BooleanOr) {
return true;
}
if (($stmt->left instanceof PhpParser\Node\Expr\BinaryOp && self::_containsBooleanOr($stmt->left)) ||
($stmt->right instanceof PhpParser\Node\Expr\BinaryOp && self::_containsBooleanOr($stmt->right))) {
return true;
}
return false;
}
protected static function _negateTypes(array $types)
{
return array_map(function ($type) {