mirror of
https://github.com/danog/psalm.git
synced 2024-12-16 11:26:55 +01:00
47 lines
1.4 KiB
PHP
47 lines
1.4 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
|
|
{
|
|
/**
|
|
* @param StatementsAnalyzer $statements_analyzer
|
|
* @param PhpParser\Node\Expr\Empty_ $stmt
|
|
* @param Context $context
|
|
*
|
|
* @return void
|
|
*/
|
|
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());
|
|
}
|
|
}
|