mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-08 22:01:02 +01:00
Fix XHPAST to detect use of undeclared variables in catch
Summary: Currently, when code has a block like: } catch (Exception $ex) { ...we attempt to mark "$ex" as declared. However, we incorrectly mark every variable used anywhere in the block as declared. This means we'll never raise this warning in a `catch` block. Instead //only// mark the caught exception as declared. Test Plan: Added a failing unit test and made it pass. Reviewers: joshuaspence, btrahan Reviewed By: btrahan Subscribers: lpriestley, epriestley Differential Revision: https://secure.phabricator.com/D9239
This commit is contained in:
parent
8274ffa44d
commit
c999f3e6b5
2 changed files with 14 additions and 5 deletions
|
@ -1202,11 +1202,11 @@ final class ArcanistXHPASTLinter extends ArcanistBaseXHPASTLinter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$catches = $body
|
// Include "catch (Exception $ex)", but not variables in the body of the
|
||||||
->selectDescendantsOfType('n_CATCH')
|
// catch block.
|
||||||
->selectDescendantsOfType('n_VARIABLE');
|
$catches = $body->selectDescendantsOfType('n_CATCH');
|
||||||
foreach ($catches as $var) {
|
foreach ($catches as $catch) {
|
||||||
$vars[] = $var;
|
$vars[] = $catch->getChildOfType(1, 'n_VARIABLE');
|
||||||
}
|
}
|
||||||
|
|
||||||
$binary = $body->selectDescendantsOfType('n_BINARY_EXPRESSION');
|
$binary = $body->selectDescendantsOfType('n_BINARY_EXPRESSION');
|
||||||
|
|
|
@ -166,6 +166,14 @@ function strings() {
|
||||||
echo "$b";
|
echo "$b";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function catchy() {
|
||||||
|
try {
|
||||||
|
dangerous();
|
||||||
|
} catch (Exception $ex) {
|
||||||
|
$y->z();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
~~~~~~~~~~
|
~~~~~~~~~~
|
||||||
disabled:3:1
|
disabled:3:1
|
||||||
error:30:3
|
error:30:3
|
||||||
|
@ -185,3 +193,4 @@ error:125:3 Should only warn once in this function.
|
||||||
error:146:8
|
error:146:8
|
||||||
error:152:9
|
error:152:9
|
||||||
error:166:9
|
error:166:9
|
||||||
|
error:173:5
|
||||||
|
|
Loading…
Reference in a new issue