for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/**
* @author Patsura Dmitry https://github.com/ovr <[email protected]>
*/
namespace PHPSA\Analyzer\Pass\FunctionCall;
use PhpParser\Node\Expr\FuncCall;
use PhpParser\Node\Name;
use PHPSA\Compiler\Expression;
use PHPSA\Context;
class ArrayShortDefinition implements PassFunctionCallInterface
{
public function pass(FuncCall $funcCall, Context $context)
$compiler = $context->getExpressionCompiler();
$funcNameCompiledExpression = $compiler->compile($funcCall->name);
$funcNameCompiledExpression
20
Very long variable names usually make code harder to read. It is therefore recommended not to make variable names too verbose.
if ($funcNameCompiledExpression->isString() && $funcNameCompiledExpression->isCorrectValue()) {
$name = $funcNameCompiledExpression->getValue();
} else {
$context->debug(
'Unexpected function name type ' . $funcNameCompiledExpression->getType(),
$funcCall->name
);
return false;
}
if ($name == 'array') {
$context->notice(
'array.short-syntax',
'Please use [] (short syntax) for array definition.',
$funcCall
Very long variable names usually make code harder to read. It is therefore recommended not to make variable names too verbose.