mirror of
https://github.com/rectorphp/rector.git
synced 2025-01-18 05:48:21 +01:00
Rector - Reconstruct your Legacy Code to Modern Codebase
This tool will upgrade your application for you.
All Reconstructors
At the moment these packages are supported:
Install
composer require rector/rector --dev
Install on PHP < 7.1
You must have separated environment with PHP 7.1 (for example in Docker container). When you have it then run following command.
composer create-project rector/rector your-path-to-rector
When do you have it then you can run all commands like
your-path-to-rector/bin/rector process /var/www/old-project --level=nette24
your-path-to-rector/bin/rector process /var/www/another-old-project --level=symfony40
How To Reconstruct your Code?
- Create
rector.yml
with desired Rectors
rectors:
- Rector\Rector\Contrib\Nette\Application\InjectPropertyRector
- Run rector on your
/src
directory
vendor/bin/rector process src
- Check the Git
git diff
6 Steps to Add New Rector
Just extend Rector\Rector\AbstractRector
.
It will prepare 2 methods processing the node.
public function isCandidate(Node $node): bool
{
}
public function refactor(Node $node): ?Node
{
}
- Put it under
namespace Rector\Contrib\<set>;
namespace
<?php declare(strict_types=1);
namespace Rector\Contrib\Symfony;
use Rector\Rector\AbstractRector;
final class MyRector extends AbstractRector
{
// ...
}
-
Add a Test Case
-
Add to specific level, e.g.
/src/config/level/nette/nette24.yml
-
Submit PR
-
👍
READMEs for Subpackages
How to Contribute
Just follow 3 rules:
-
1 feature per pull-request
-
New feature needs tests
-
Tests, coding standard and PHPStan checks must pass
composer all
Don you need to fix coding standards? Run:
composer fix-cs
We would be happy to merge your feature then.
Description
Languages
PHP
99.9%