rector/rules/CodeQuality/Rector/NotEqual/CommonNotEqualRector.php

75 lines
2.0 KiB
PHP

<?php
declare (strict_types=1);
namespace Rector\CodeQuality\Rector\NotEqual;
use PhpParser\Node;
use PhpParser\Node\Expr\BinaryOp\NotEqual;
use Rector\NodeTypeResolver\Node\AttributeKey;
use Rector\Rector\AbstractRector;
use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;
/**
* @changelog https://stackoverflow.com/a/4294663/1348344
* @see \Rector\Tests\CodeQuality\Rector\NotEqual\CommonNotEqualRector\CommonNotEqualRectorTest
*/
final class CommonNotEqualRector extends AbstractRector
{
public function getRuleDefinition() : RuleDefinition
{
return new RuleDefinition('Use common != instead of less known <> with same meaning', [new CodeSample(<<<'CODE_SAMPLE'
final class SomeClass
{
public function run($one, $two)
{
return $one <> $two;
}
}
CODE_SAMPLE
, <<<'CODE_SAMPLE'
final class SomeClass
{
public function run($one, $two)
{
return $one != $two;
}
}
CODE_SAMPLE
)]);
}
/**
* @return array<class-string<Node>>
*/
public function getNodeTypes() : array
{
return [NotEqual::class];
}
/**
* @param NotEqual $node
*/
public function refactor(Node $node) : ?NotEqual
{
if (!$this->doesNotEqualContainsShipCompareToken($node)) {
return null;
}
// invoke override to default "!="
$node->setAttribute(AttributeKey::ORIGINAL_NODE, null);
return $node;
}
private function doesNotEqualContainsShipCompareToken(NotEqual $notEqual) : bool
{
$tokenStartPos = $notEqual->getStartTokenPos();
$tokenEndPos = $notEqual->getEndTokenPos();
for ($i = $tokenStartPos; $i < $tokenEndPos; ++$i) {
$token = $this->file->getOldTokens()[$i];
if (!isset($token[1])) {
continue;
}
if ($token[1] === '<>') {
return \true;
}
}
return \false;
}
}