mirror of
https://github.com/danog/psalm.git
synced 2025-01-21 21:31:13 +01:00
Always keep track of referenced var ids
which we can use for analysis elsewhere
This commit is contained in:
parent
4312ef380b
commit
c86e73ddb6
@ -597,7 +597,7 @@ abstract class FunctionLikeChecker extends SourceChecker implements StatementsSo
|
||||
) {
|
||||
$original_location = $statements_checker->getFirstAppearance($var_name);
|
||||
|
||||
if (!isset($context->referenced_vars[$var_name]) && $original_location) {
|
||||
if (!isset($context->referenced_var_ids[$var_name]) && $original_location) {
|
||||
if (!isset($storage->param_types[substr($var_name, 1)]) ||
|
||||
!$storage instanceof MethodStorage ||
|
||||
$storage->visibility === ClassLikeChecker::VISIBILITY_PRIVATE
|
||||
|
@ -73,12 +73,10 @@ class ForChecker
|
||||
$context->vars_possibly_in_scope
|
||||
);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$for_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$for_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
return null;
|
||||
}
|
||||
|
@ -310,12 +310,10 @@ class ForeachChecker
|
||||
$context->vars_possibly_in_scope
|
||||
);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$foreach_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$foreach_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
return null;
|
||||
}
|
||||
|
@ -142,12 +142,10 @@ class IfChecker
|
||||
$context->vars_possibly_in_scope
|
||||
);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$if_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$if_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
$temp_else_context = clone $original_context;
|
||||
|
||||
@ -345,9 +343,9 @@ class IfChecker
|
||||
}
|
||||
|
||||
if ($outer_context->collect_references) {
|
||||
$outer_context->referenced_vars = array_merge(
|
||||
$outer_context->referenced_vars,
|
||||
$if_context->referenced_vars
|
||||
$outer_context->referenced_var_ids = array_merge(
|
||||
$outer_context->referenced_var_ids,
|
||||
$if_context->referenced_var_ids
|
||||
);
|
||||
}
|
||||
|
||||
@ -777,9 +775,9 @@ class IfChecker
|
||||
}
|
||||
|
||||
if ($outer_context->collect_references) {
|
||||
$outer_context->referenced_vars = array_merge(
|
||||
$outer_context->referenced_vars,
|
||||
$elseif_context->referenced_vars
|
||||
$outer_context->referenced_var_ids = array_merge(
|
||||
$outer_context->referenced_var_ids,
|
||||
$elseif_context->referenced_var_ids
|
||||
);
|
||||
}
|
||||
|
||||
@ -871,9 +869,9 @@ class IfChecker
|
||||
}
|
||||
|
||||
if ($outer_context->collect_references) {
|
||||
$outer_context->referenced_vars = array_merge(
|
||||
$outer_context->referenced_vars,
|
||||
$else_context->referenced_vars
|
||||
$outer_context->referenced_var_ids = array_merge(
|
||||
$outer_context->referenced_var_ids,
|
||||
$else_context->referenced_var_ids
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -134,12 +134,10 @@ class SwitchChecker
|
||||
|
||||
$statements_checker->analyze($case_stmts, $case_context, $loop_context);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$case_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$case_context->referenced_var_ids
|
||||
);
|
||||
|
||||
if ($case_exit_type !== 'return_throw') {
|
||||
$vars = array_diff_key(
|
||||
|
@ -90,12 +90,10 @@ class TryChecker
|
||||
|
||||
$statements_checker->analyze($catch->stmts, $catch_context, $loop_context);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$catch_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$catch_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
if (!ScopeChecker::doesAlwaysReturnOrThrow($catch->stmts)) {
|
||||
foreach ($catch_context->vars_in_scope as $catch_var => $type) {
|
||||
|
@ -123,12 +123,10 @@ class WhileChecker
|
||||
$while_context->vars_possibly_in_scope
|
||||
);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$while_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$while_context->referenced_var_ids
|
||||
);
|
||||
|
||||
return null;
|
||||
}
|
||||
|
@ -843,9 +843,9 @@ class ExpressionChecker
|
||||
return false;
|
||||
}
|
||||
|
||||
$context->referenced_vars = array_merge(
|
||||
$op_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$op_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
foreach ($op_context->vars_in_scope as $var_id => $type) {
|
||||
@ -948,9 +948,9 @@ class ExpressionChecker
|
||||
$context->updateChecks($op_context);
|
||||
}
|
||||
|
||||
$context->referenced_vars = array_merge(
|
||||
$op_context->referenced_vars,
|
||||
$context->referenced_vars
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$op_context->referenced_var_ids,
|
||||
$context->referenced_var_ids
|
||||
);
|
||||
|
||||
$context->vars_possibly_in_scope = array_merge(
|
||||
@ -1013,12 +1013,10 @@ class ExpressionChecker
|
||||
}
|
||||
}
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$t_if_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$t_if_context->referenced_var_ids
|
||||
);
|
||||
|
||||
$t_else_context = clone $context;
|
||||
|
||||
@ -1043,12 +1041,10 @@ class ExpressionChecker
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$t_else_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$t_else_context->referenced_var_ids
|
||||
);
|
||||
|
||||
$lhs_type = null;
|
||||
|
||||
@ -2037,12 +2033,10 @@ class ExpressionChecker
|
||||
}
|
||||
}
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$t_if_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$t_if_context->referenced_var_ids
|
||||
);
|
||||
}
|
||||
|
||||
if ($negated_if_types) {
|
||||
@ -2072,12 +2066,10 @@ class ExpressionChecker
|
||||
}
|
||||
}
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$t_else_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$t_else_context->referenced_var_ids
|
||||
);
|
||||
|
||||
$lhs_type = null;
|
||||
|
||||
@ -2236,7 +2228,7 @@ class ExpressionChecker
|
||||
} elseif ($stmt instanceof PhpParser\Node\Expr\PropertyFetch) {
|
||||
self::analyzeIssetVar($statements_checker, $stmt->var, $context);
|
||||
} elseif ($stmt instanceof PhpParser\Node\Expr\Variable) {
|
||||
if ($context->collect_references && is_string($stmt->name)) {
|
||||
if (is_string($stmt->name)) {
|
||||
$context->hasVariable('$' . $stmt->name);
|
||||
}
|
||||
}
|
||||
|
@ -773,12 +773,10 @@ class StatementsChecker extends SourceChecker implements StatementsSource
|
||||
$do_context->vars_possibly_in_scope
|
||||
);
|
||||
|
||||
if ($context->collect_references) {
|
||||
$context->referenced_vars = array_merge(
|
||||
$context->referenced_vars,
|
||||
$do_context->referenced_vars
|
||||
);
|
||||
}
|
||||
$context->referenced_var_ids = array_merge(
|
||||
$context->referenced_var_ids,
|
||||
$do_context->referenced_var_ids
|
||||
);
|
||||
|
||||
return ExpressionChecker::analyze($this, $stmt->cond, $context);
|
||||
}
|
||||
|
@ -124,7 +124,7 @@ class Context
|
||||
*
|
||||
* @var array<string, bool>
|
||||
*/
|
||||
public $referenced_vars = [];
|
||||
public $referenced_var_ids = [];
|
||||
|
||||
/**
|
||||
* A list of variables that have been passed by reference (where we know their type)
|
||||
@ -313,7 +313,7 @@ class Context
|
||||
public function remove($remove_var_id)
|
||||
{
|
||||
unset(
|
||||
$this->referenced_vars[$remove_var_id],
|
||||
$this->referenced_var_ids[$remove_var_id],
|
||||
$this->vars_possibly_in_scope[$remove_var_id]
|
||||
);
|
||||
|
||||
@ -547,7 +547,7 @@ class Context
|
||||
$stripped_var = preg_replace('/(->|\[).*$/', '', $var_name);
|
||||
|
||||
if ($stripped_var[0] === '$' && $stripped_var !== '$this') {
|
||||
$this->referenced_vars[$var_name] = true;
|
||||
$this->referenced_var_ids[$var_name] = true;
|
||||
}
|
||||
|
||||
return isset($this->vars_in_scope[$var_name]);
|
||||
|
Loading…
x
Reference in New Issue
Block a user