mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-11 23:31:03 +01:00
Warn about pht() with non constant string
Summary: We will extract them at some point, lint before it's too late. Test Plan: New test. Linted all callsites. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D2825
This commit is contained in:
parent
22d2d6743d
commit
a9dbb937e8
2 changed files with 51 additions and 0 deletions
|
@ -56,6 +56,7 @@ final class ArcanistXHPASTLinter extends ArcanistLinter {
|
|||
const LINT_IMPLICIT_FALLTHROUGH = 30;
|
||||
const LINT_PHP_53_FEATURES = 31;
|
||||
const LINT_REUSED_AS_ITERATOR = 32;
|
||||
const LINT_PHT_WITH_DYNAMIC_STRING = 33;
|
||||
|
||||
|
||||
public function getLintNameMap() {
|
||||
|
@ -91,6 +92,7 @@ final class ArcanistXHPASTLinter extends ArcanistLinter {
|
|||
self::LINT_IMPLICIT_FALLTHROUGH => 'Implicit Fallthrough',
|
||||
self::LINT_PHP_53_FEATURES => 'Use Of PHP 5.3 Features',
|
||||
self::LINT_REUSED_AS_ITERATOR => 'Variable Reused As Iterator',
|
||||
self::LINT_PHT_WITH_DYNAMIC_STRING => 'Use of pht() on Dynamic String',
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -119,6 +121,8 @@ final class ArcanistXHPASTLinter extends ArcanistLinter {
|
|||
=> ArcanistLintSeverity::SEVERITY_WARNING,
|
||||
self::LINT_IMPLICIT_FALLTHROUGH
|
||||
=> ArcanistLintSeverity::SEVERITY_WARNING,
|
||||
self::LINT_PHT_WITH_DYNAMIC_STRING
|
||||
=> ArcanistLintSeverity::SEVERITY_WARNING,
|
||||
|
||||
// This is disabled by default because it implies a very strict policy
|
||||
// which isn't necessary in the general case.
|
||||
|
@ -200,6 +204,42 @@ final class ArcanistXHPASTLinter extends ArcanistLinter {
|
|||
$this->lintRaggedClasstreeEdges($root);
|
||||
$this->lintImplicitFallthrough($root);
|
||||
$this->lintPHP53Features($root);
|
||||
$this->lintPHT($root);
|
||||
}
|
||||
|
||||
public function lintPHT($root) {
|
||||
$calls = $root->selectDescendantsOfType('n_FUNCTION_CALL');
|
||||
foreach ($calls as $call) {
|
||||
$name = strtolower($call->getChildByIndex(0)->getConcreteString());
|
||||
if ($name != 'pht') {
|
||||
continue;
|
||||
}
|
||||
|
||||
$parameters = $call->getChildOfType(1, 'n_CALL_PARAMETER_LIST');
|
||||
if (!$parameters->getChildren()) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$identifier = $parameters->getChildByIndex(0);
|
||||
if ($identifier->getTypeName() == 'n_STRING_SCALAR') {
|
||||
continue;
|
||||
}
|
||||
|
||||
if ($identifier->getTypeName() == 'n_CONCATENATION_LIST') {
|
||||
foreach ($identifier->getChildren() as $child) {
|
||||
if ($child->getTypeName() == 'n_STRING_SCALAR' ||
|
||||
$child->getTypeName() == 'n_OPERATOR') {
|
||||
continue 2;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$this->raiseLintAtNode(
|
||||
$call,
|
||||
self::LINT_PHT_WITH_DYNAMIC_STRING,
|
||||
"The first parameter of pht() can be only a scalar string, ".
|
||||
"otherwise it can't be extracted.");
|
||||
}
|
||||
}
|
||||
|
||||
public function lintPHP53Features($root) {
|
||||
|
|
11
src/lint/linter/__tests__/xhpast/pht.lint-test
Normal file
11
src/lint/linter/__tests__/xhpast/pht.lint-test
Normal file
|
@ -0,0 +1,11 @@
|
|||
<?php
|
||||
pht('a');
|
||||
pht("a");
|
||||
pht('a'.'b');
|
||||
pht(f());
|
||||
pht();
|
||||
pht($a);
|
||||
pht('%s', $a);
|
||||
~~~~~~~~~~
|
||||
warning:5:1
|
||||
warning:7:1
|
Loading…
Reference in a new issue