Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php declare (strict_types=1); namespace Rector\DowngradePhp80\Rector\FuncCall; use Php..
Decoded Output download
<?php
declare (strict_types=1);
namespace Rector\DowngradePhp80\Rector\FuncCall;
use PhpParser\Node;
use PhpParser\Node\Expr\BinaryOp\Identical;
use PhpParser\Node\Expr\BinaryOp\NotIdentical;
use PhpParser\Node\Expr\BooleanNot;
use PhpParser\Node\Expr\FuncCall;
use Rector\Rector\AbstractRector;
use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;
/**
* @changelog https://wiki.php.net/rfc/str_contains
*
* @see \Rector\Tests\DowngradePhp80\Rector\FuncCall\DowngradeStrContainsRector\DowngradeStrContainsRectorTest
*/
final class DowngradeStrContainsRector extends AbstractRector
{
public function getRuleDefinition() : RuleDefinition
{
return new RuleDefinition('Replace str_contains() with strpos() !== false', [new CodeSample(<<<'CODE_SAMPLE'
class SomeClass
{
public function run()
{
return str_contains('abc', 'a');
}
}
CODE_SAMPLE
, <<<'CODE_SAMPLE'
class SomeClass
{
public function run()
{
return strpos('abc', 'a') !== false;
}
}
CODE_SAMPLE
)]);
}
/**
* @return array<class-string<Node>>
*/
public function getNodeTypes() : array
{
return [FuncCall::class, BooleanNot::class];
}
/**
* @param FuncCall|BooleanNot $node
* @return Identical|NotIdentical|null The refactored node.
*/
public function refactor(Node $node)
{
$funcCall = $this->matchStrContainsOrNotStrContains($node);
if (!$funcCall instanceof FuncCall) {
return null;
}
$args = $funcCall->getArgs();
if (\count($args) < 2) {
return null;
}
$haystack = $args[0]->value;
$needle = $args[1]->value;
$funcCall = $this->nodeFactory->createFuncCall('strpos', [$haystack, $needle]);
if ($node instanceof BooleanNot) {
return new Identical($funcCall, $this->nodeFactory->createFalse());
}
return new NotIdentical($funcCall, $this->nodeFactory->createFalse());
}
/**
* @param \PhpParser\Node\Expr\FuncCall|\PhpParser\Node\Expr\BooleanNot $expr
*/
private function matchStrContainsOrNotStrContains($expr) : ?FuncCall
{
$expr = $expr instanceof BooleanNot ? $expr->expr : $expr;
if (!$expr instanceof FuncCall) {
return null;
}
if (!$this->isName($expr, 'str_contains')) {
return null;
}
return $expr;
}
}
?>
Did this file decode correctly?
Original Code
<?php
declare (strict_types=1);
namespace Rector\DowngradePhp80\Rector\FuncCall;
use PhpParser\Node;
use PhpParser\Node\Expr\BinaryOp\Identical;
use PhpParser\Node\Expr\BinaryOp\NotIdentical;
use PhpParser\Node\Expr\BooleanNot;
use PhpParser\Node\Expr\FuncCall;
use Rector\Rector\AbstractRector;
use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;
/**
* @changelog https://wiki.php.net/rfc/str_contains
*
* @see \Rector\Tests\DowngradePhp80\Rector\FuncCall\DowngradeStrContainsRector\DowngradeStrContainsRectorTest
*/
final class DowngradeStrContainsRector extends AbstractRector
{
public function getRuleDefinition() : RuleDefinition
{
return new RuleDefinition('Replace str_contains() with strpos() !== false', [new CodeSample(<<<'CODE_SAMPLE'
class SomeClass
{
public function run()
{
return str_contains('abc', 'a');
}
}
CODE_SAMPLE
, <<<'CODE_SAMPLE'
class SomeClass
{
public function run()
{
return strpos('abc', 'a') !== false;
}
}
CODE_SAMPLE
)]);
}
/**
* @return array<class-string<Node>>
*/
public function getNodeTypes() : array
{
return [FuncCall::class, BooleanNot::class];
}
/**
* @param FuncCall|BooleanNot $node
* @return Identical|NotIdentical|null The refactored node.
*/
public function refactor(Node $node)
{
$funcCall = $this->matchStrContainsOrNotStrContains($node);
if (!$funcCall instanceof FuncCall) {
return null;
}
$args = $funcCall->getArgs();
if (\count($args) < 2) {
return null;
}
$haystack = $args[0]->value;
$needle = $args[1]->value;
$funcCall = $this->nodeFactory->createFuncCall('strpos', [$haystack, $needle]);
if ($node instanceof BooleanNot) {
return new Identical($funcCall, $this->nodeFactory->createFalse());
}
return new NotIdentical($funcCall, $this->nodeFactory->createFalse());
}
/**
* @param \PhpParser\Node\Expr\FuncCall|\PhpParser\Node\Expr\BooleanNot $expr
*/
private function matchStrContainsOrNotStrContains($expr) : ?FuncCall
{
$expr = $expr instanceof BooleanNot ? $expr->expr : $expr;
if (!$expr instanceof FuncCall) {
return null;
}
if (!$this->isName($expr, 'str_contains')) {
return null;
}
return $expr;
}
}
Function Calls
None |
Stats
MD5 | 85fb894477ab59365eb63ad99f901d6b |
Eval Count | 0 |
Decode Time | 91 ms |