Photo de Matteo del Piano sur Unsplash
Dans le monde en constante évolution du développement PHP, il est crucial de garder votre base de code propre, à jour et efficace. C'est là que Rector PHP entre en jeu. Si vous vous demandez comment utiliser Rector PHP, comment l'installer ou ce qu'est exactement Rector PHP, ce guide complet est fait pour vous. Nous vous expliquerons les bases, fournirons un didacticiel Rector PHP détaillé et vous offrirons des informations sur PHP Rector et comment l'utiliser efficacement. À la fin de cet article, vous aurez une solide compréhension de Rector PHP et de la manière dont il peut améliorer votre flux de travail de développement.
Rector a été lancé en 2020, mais n'a obtenu sa version 1.0 qu'en 2024. Il s'agit d'un outil de ligne de commande qui effectue une analyse statique d'une base de code. À partir de cette analyse, des changements peuvent être appliqués. Je suppose qu'un bon exemple de ceci serait ce qui se passerait si votre base de code était criblée d'appels array() alors que cela est maintenant considéré comme une vieille pratique, maintenant remplacée par la syntaxe de tableau court [].
Parcourir une base de code pour remplacer cela est fastidieux. Nous pourrions utiliser un simple outil de recherche et de remplacement, mais que se passerait-il s'il y avait un array() encapsulant une chaîne ou à l'intérieur d'un commentaire qui ne devrait pas être modifié ? Nous devons désormais vérifier chaque instance que nous sommes remplacés.
Ce genre de problème est dans lequel Rector excelle. Au lieu de cela, Rector est capable de regarder le code et de savoir définitivement s'il s'agit d'un tableau à remplacer.
Vous vous demandez peut-être, PHP CS Fixer peut également le faire, ce qui est vrai. Mais Rector fait également fonctionner PHPStan sous le capot non seulement pour reconnaître la syntaxe, mais également pour analyser les types. Cela signifie que Rector peut détecter quand une classe a une classe parent particulière, quand une variable est d'un type particulier ou quel est le type de retour attendu d'une fonction. Ce qui lui donne une portée beaucoup plus grande pour apporter des modifications en masse à une base de code.
Cela peut sembler évident pour les développeurs PHP expérimentés, mais il existe deux manières principales et cela dépend vraiment de la manière dont vous souhaitez utiliser Rector.
Si vous souhaitez utiliser Rector dans le cadre d'une intégration continue, il est logique d'installer Rector différemment dans vos projets via composer.
composer require --dev rector/rector
Mais si vous souhaitez expérimenter Rector sur un ou plusieurs projets pour effectuer des mises à niveau, vous feriez peut-être mieux d'installer Rector globalement en utilisant
composer global require rector/rector
Quelle que soit l'étape que vous choisissez, l'étape suivante consistera à créer une configuration dans le répertoire racine d'un projet et à inclure tous les dossiers contenant du code PHP que vous souhaitez mettre à niveau. Cela n’inclut bien sûr pas le dossier du fournisseur car nous ne voulons pas le modifier.
Voici à quoi pourrait ressembler une configuration pour, par exemple, un projet Laravel :
use Rector\Config\RectorConfig; use Rector\Php71\Rector\List_\ListToArrayDestructRector; return RectorConfig::configure() ->withPaths([__DIR__. '/config', __DIR__. '/src', __DIR__. '/tests', __DIR__. '/routes']) ->withImportNames(removeUnusedImports: true);
Comme dans la section précédente, l'utilisation de Rector peut être déterminée par la manière dont vous souhaitez l'utiliser. Le recteur applique les modifications à travers les sélections de règles. C'est la même chose que PHP CS Fixer. Ces règles détecteront le problème, puis tenteront de résoudre le problème pour lequel elles sont conçues.
Si nous souhaitons utiliser Rector de manière intégrée continue, parce que nous voulons que tout le code soit aussi optimisé que possible au fur et à mesure que nous le développons, nous pouvons utiliser uniquement un ensemble particulier de règles.
Rector dispose d'un ensemble de règles, souvent décrites comme Dead Code ou Code Quality, qui suppriment le code ou améliorent et optimisent respectivement. Il est très avantageux de s’en tenir uniquement à ces ensembles car nous pouvons être sûrs qu’ils fonctionnent la plupart du temps. Mais vous devez absolument être conscient que la façon dont Rector écrit le code n’est jamais parfaite. Souvent, lorsque des règles sont écrites, elles peuvent couvrir des scénarios typiques et manquer certaines circonstances liées à votre base de code. Cela pourrait entraîner un code cassé.
Dans le cas où vous souhaiteriez utiliser Rector, vous devez absolument avoir des tests écrits pour votre application. Sans eux, Rector peut facilement conduire à l'introduction de bugs que vous ne découvrirez pas tant qu'il ne s'agira pas d'un problème.
Une autre chose à considérer lors de l'utilisation de Rector est que vous devez utiliser un outil de peluchage comme PHP CS Fixer. Rector ne regarde pas les espaces, les espaces et les nouvelles lignes entre les appels de méthode et ses arguments, etc. L'utilisation d'un outil de peluchage devrait conserver le formatage du code à la norme que vous attendez une fois que Rector a appliqué ses correctifs.
Maintenant que nous avons installé Rector et que nous sommes prêts à l'essayer, essayons d'appliquer une règle. Commençons par mettre à jour notre fichier de configuration que nous avons créé plus tôt.
use Rector\Config\RectorConfig; use Rector\Php71\Rector\List_\ListToArrayDestructRector; return RectorConfig::configure() ->withPaths([__DIR__. '/config', __DIR__. '/src', __DIR__. '/tests', __DIR__. '/routes']) ->withImportNames(removeUnusedImports: true) ->withRules([ ListToArrayDestructRector::class, ]);
Dans le cas de cette configuration, nous allons remplacer l'utilisation de lists afin d'utiliser à la place la restructuration de tableaux. Les changements que nous nous attendons à apporter sont les suivants :
-list($a, $b) = ['a', 'b']; [$a, $b] = ['a', 'b'];
Nous pouvons maintenant tester cette configuration en effectuant un essai à sec de Rector.
rector --dry-run
Si tout a réussi, nous devrions maintenant voir une sortie contenant un différentiel de toutes les modifications apportées à chaque fichier, avec une liste des règles qui ont effectué les modifications. Notre configuration ne répertorie qu'une seule règle, donc une seule règle est appliquée, mais si d'autres règles sont ajoutées, nous en verrons une ou plusieurs ici.
C'est alors le moment idéal pour examiner les modifications et vous assurer que la règle fonctionne comme prévu. Une fois que nous serons satisfaits, nous pourrons à nouveau diriger Rector. Sans l'indicateur d'exécution à sec, les modifications seront écrites dans les fichiers.
rector
Une fois l'opération terminée, nous devrions exécuter notre outil de peluchage préféré, puis exécuter nos tests. C'est ça. Nous avons maintenant utilisé Rector.
Rector PHP est un outil puissant qui peut améliorer considérablement votre flux de travail de développement PHP en automatisant la refactorisation du code et en garantissant que votre base de code reste propre et moderne. En comprenant ce qu'est Rector PHP, en apprenant comment l'installer et en maîtrisant comment l'utiliser efficacement, vous pouvez tirer parti de ses capacités pour rationaliser les mises à jour du code, améliorer la qualité du code et réduire le risque que le code ressemble à un projet « hérité ». Que vous intégriez Rector dans votre pipeline d'intégration continue ou que vous l'utilisiez pour des mises à niveau de base de code à grande échelle, Rector est un atout indispensable pour tout développeur PHP cherchant à maintenir un niveau élevé d'excellence du code.
Si vous souhaitez approfondir vos connaissances sur Rector, je vous suggère d'aller sur https://getrector.com/.
Je m'appelle Peter Fox, un développeur de logiciels au Royaume-Uni qui travaille avec Laravel. Merci d'avoir lu mon article, j'en ai beaucoup d'autres à lire sur https://articles.peterfox.me. Je suis également désormais sponsorisé sur GitHub. Si vous souhaitez m'encourager à écrire davantage d'articles comme celui-ci, pensez à faire un petit don ponctuel.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3