rector/rules/php71/src/IsArrayAndDualCheckToAble.php

90 lines
2.4 KiB
PHP
Raw Normal View History

2019-10-13 07:59:52 +02:00
<?php
declare(strict_types=1);
2018-10-03 22:11:30 +08:00
2019-09-23 18:05:19 +02:00
namespace Rector\Php71;
2018-10-03 22:11:30 +08:00
2018-11-07 21:53:19 +01:00
use PhpParser\Node\Arg;
use PhpParser\Node\Expr;
2018-10-03 22:11:30 +08:00
use PhpParser\Node\Expr\BinaryOp\BooleanOr;
use PhpParser\Node\Expr\FuncCall;
use PhpParser\Node\Expr\Instanceof_;
use PhpParser\Node\Expr\Variable;
use PhpParser\Node\Name;
use Rector\Core\PhpParser\Node\Manipulator\BinaryOpManipulator;
use Rector\NodeNameResolver\NodeNameResolver;
2018-10-03 22:11:30 +08:00
final class IsArrayAndDualCheckToAble
2018-10-03 22:11:30 +08:00
{
/**
* @var NodeNameResolver
*/
private $nodeNameResolver;
2018-11-07 18:04:38 +01:00
/**
* @var BinaryOpManipulator
2018-11-07 18:04:38 +01:00
*/
private $binaryOpManipulator;
2018-11-07 18:04:38 +01:00
2020-07-26 09:49:22 +02:00
public function __construct(BinaryOpManipulator $binaryOpManipulator, NodeNameResolver $nodeNameResolver)
{
$this->nodeNameResolver = $nodeNameResolver;
$this->binaryOpManipulator = $binaryOpManipulator;
}
2019-02-22 18:25:31 +01:00
public function processBooleanOr(BooleanOr $booleanOr, string $type, string $newMethodName): ?FuncCall
2018-10-03 22:11:30 +08:00
{
$twoNodeMatch = $this->binaryOpManipulator->matchFirstAndSecondConditionNode(
2019-02-22 18:25:31 +01:00
$booleanOr,
Instanceof_::class,
FuncCall::class
2018-11-07 18:04:38 +01:00
);
if ($twoNodeMatch === null) {
2018-10-03 22:11:30 +08:00
return null;
}
2018-11-07 18:22:27 +01:00
/** @var Instanceof_ $instanceOfNode */
$instanceOfNode = $twoNodeMatch->getFirstExpr();
2018-11-07 18:22:27 +01:00
/** @var FuncCall $funcCallNode */
$funcCallNode = $twoNodeMatch->getSecondExpr();
2018-10-03 22:11:30 +08:00
$instanceOfClass = $instanceOfNode->class;
if ($instanceOfClass instanceof Expr) {
2020-06-21 16:51:14 +02:00
return null;
}
if ((string) $instanceOfClass !== $type) {
2018-10-03 22:11:30 +08:00
return null;
}
$nodeNameResolverGetName = $this->nodeNameResolver->getName($funcCallNode);
2018-10-03 22:11:30 +08:00
if ($nodeNameResolverGetName !== 'is_array') {
2018-10-03 22:11:30 +08:00
return null;
}
// both use same var
if (! $funcCallNode->args[0]->value instanceof Variable) {
return null;
}
/** @var Variable $firstVarNode */
$firstVarNode = $funcCallNode->args[0]->value;
if (! $instanceOfNode->expr instanceof Variable) {
return null;
}
/** @var Variable $secondVarNode */
$secondVarNode = $instanceOfNode->expr;
// are they same variables
if ($firstVarNode->name !== $secondVarNode->name) {
return null;
}
2018-11-07 21:53:19 +01:00
return new FuncCall(new Name($newMethodName), [new Arg($firstVarNode)]);
2018-10-03 22:11:30 +08:00
}
}