neos / rector
Fund package maintenance!
shop.neos.io/neosfunding
Installs: 1 453
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 8
Forks: 4
Open Issues: 7
Requires
- neos/utility-arrays: *
- phpstan/phpstan: 1.10.14
- rector/rector: 0.15.25
- symfony/yaml: *
- webmozart/assert: ^1.11
Requires (Dev)
- phpunit/phpunit: ^9.5
- symplify/rule-doc-generator: ^11.1
This package is auto-updated.
Last update: 2025-01-14 16:28:00 UTC
README
This package contains a Rector ruleset which is used for migrating from Neos 8.x to 9.0 (and possibly also further up).
It will eventually replace Core/Code Migrations (./flow flow:core:migrate), but right now it is still in Development.
Right now we focus especially on rules to migrate from the old Content Repository API (< Neos 9.0) to the Event Sourced Content Repository (>= 9.0).
Installation
As Rector has strict dependency requirements, which might not match your own project, we strongly recommend to install neos/rector in a dedicated directory and not to add it to your project.
# inside your Distribution folder
composer create-project neos/rector:dev-main --stability=dev rector
cp rector/rector.template.php rector.php
Configuration
Now, open up the rector.php
file copied above, and adjust the Rector Paths (these are the paths which shall be
migrated). By default, all of ./DistributionPackages
will be migrated.
Right now, we ship the following sets of Rector rules:
\Neos\Rector\NeosRectorSets::CONTENTREPOSITORY_9_0
: all rules needed to migrate to the Event-Sourced Content Repository (currently still in progress)
Also you need to add the autoload paths, to allow rector to parse your code properly. By default we added ./Packages
and ./DistributionPackages
to the template.
$rectorConfig->sets([ NeosRectorSets::CONTENTREPOSITORY_9_0, //NeosRectorSets::NEOS_8_4, ]); $rectorConfig->autoloadPaths([ __DIR__ . '/Packages', __DIR__ . '/DistributionPackages', ]); $rectorConfig->paths([ // TODO: Start adding your paths here, like so: __DIR__ . '/DistributionPackages/' ]);
Running
Run the following command at the root of your distribution (i.e. where rector.php
is located).
# for trying out what would be done ./rector/vendor/bin/rector --dry-run # for running the migrations ./rector/vendor/bin/rector
Developing Rector Rules for Neos
(This section is not relevant for users, but for developers of the Neos Rector packages)
Running Rector after adjusting rules
Make sure to run Rector with the --clear-cache
flag while developing rules, when you run them on a full codebase.
Otherwise, ...
Running Tests
We develop all Rector Rules completely test-driven.
The test setup runs completely local; does not need any Distribution set up.
# if inside a Neos Distribution, change to the Package's folder cd rector # install PHPunit composer install # run PHPUnit composer test
Fusion Rector
We extended Rector specifically for migrating Fusion files, by providing a FusionFileProcessor
and a FusionRectorInterface
which you can implement if you want to build Fusion transformations.
The Fusion Rectors will usually use one of the following tooling classes:
EelExpressionTransformer
: for finding all Eel expressions inside Fusion and AFX; and transforming them in some way.- (more tooling classes to come here as we need them).
The Fusion and AFX Parsing functionality is based on the official Fusion and AFX parsers. However, the classes are
vendored/copied into this package by the ./embed-fusion-and-afx-parsers.sh
script, because of the following reasons:
- Rector needs to run even when Flow cannot compile the classes; so we cannot depend on a Flow package.
- We slightly need to patch the AFX parser, because we need position information for Eel Expressions.
The Fusion parser was subclassed by Neos\Rector\Core\FusionProcessing\CustomObjectTreeParser
for retaining position
information of AFX and Eel Expressions.
Updating Fusion and AFX Parser
To update the vendored Fusion and AFX parsers, run the ./embed-fusion-and-afx-parsers.sh
script.
Updating the AFX Parser Patch
The AFX parser needs a custom patch (see ./scripts/afx-eel-positions.patch
) to retain positions.
To create/update this patch, do the following:
cd Packages/Neos # apply the current patch patch -p1 < ../../rector/scripts/afx-eel-positions.patch # Now, do your modifications as needed. # when you are finished, create the new patch git diff -- Neos.Fusion.Afx/ > ../../rector/scripts/afx-eel-positions.patch # ... and reset the code changes inside Neos.Fusion.Afx. git restore -- Neos.Fusion.Afx/
Generating docs
composer run generate-docs