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\Expression\FunctionCall;
use PhpParser\Node\Expr\FuncCall;
use PhpParser\Node\Name;
use PHPSA\Compiler\Expression;
use PHPSA\Context;
class RandomApiMigration implements PassFunctionCallInterface
{
protected $map = array(
'rand' => 'mt_rand',
'srand' => 'mt_srand',
'getrandmax' => 'mt_getrandmax'
);
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 (isset($this->map[$name])) {
$context->notice(
'rand.api.migration',
sprintf('Function %s() is not recommended, please use mt_%s analog instead of it.', $name, $name),
$funcCall
Very long variable names usually make code harder to read. It is therefore recommended not to make variable names too verbose.