mirror of
https://github.com/danog/psalm.git
synced 2024-12-15 10:57:08 +01:00
40 lines
1.2 KiB
PHP
40 lines
1.2 KiB
PHP
|
<?php
|
||
|
namespace Psalm\Internal\Analyzer\Statements\Expression;
|
||
|
|
||
|
use PhpParser;
|
||
|
use Psalm\Internal\Analyzer\StatementsAnalyzer;
|
||
|
use Psalm\CodeLocation;
|
||
|
use Psalm\Context;
|
||
|
use Psalm\IssueBuffer;
|
||
|
use Psalm\Type;
|
||
|
|
||
|
class EmptyAnalyzer
|
||
|
{
|
||
|
public static function analyze(
|
||
|
StatementsAnalyzer $statements_analyzer,
|
||
|
PhpParser\Node\Expr\Empty_ $stmt,
|
||
|
Context $context
|
||
|
) : void {
|
||
|
IssetAnalyzer::analyzeIssetVar($statements_analyzer, $stmt->expr, $context);
|
||
|
|
||
|
if (($stmt_expr_type = $statements_analyzer->node_data->getType($stmt->expr))
|
||
|
&& $stmt_expr_type->hasBool()
|
||
|
&& $stmt_expr_type->isSingle()
|
||
|
&& !$stmt_expr_type->from_docblock
|
||
|
) {
|
||
|
if (IssueBuffer::accepts(
|
||
|
new \Psalm\Issue\InvalidArgument(
|
||
|
'Calling empty on a boolean value is almost certainly unintended',
|
||
|
new CodeLocation($statements_analyzer->getSource(), $stmt->expr),
|
||
|
'empty'
|
||
|
),
|
||
|
$statements_analyzer->getSuppressedIssues()
|
||
|
)) {
|
||
|
// fall through
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$statements_analyzer->node_data->setType($stmt, Type::getBool());
|
||
|
}
|
||
|
}
|