From ff3716d83b2a8eac99dc81513fb4b883038f3283 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Fri, 18 Aug 2023 11:55:00 +0200 Subject: [PATCH 01/21] =?UTF-8?q?=E2=9C=A8=20New=20article=20:=20Generics?= =?UTF-8?q?=20in=20PHP?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../fr/2023-08-23-typage-generique-en-php.md | 261 ++++++++++++++++++ 1 file changed, 261 insertions(+) create mode 100644 _posts/fr/2023-08-23-typage-generique-en-php.md diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-08-23-typage-generique-en-php.md new file mode 100644 index 000000000..d04e628eb --- /dev/null +++ b/_posts/fr/2023-08-23-typage-generique-en-php.md @@ -0,0 +1,261 @@ +--- +lang: fr +date: 2023-08-23 +slug: typage-generique-en-php +title: Typage générique en php +excerpt: Le typage générique en php, c'est impossible ? Pas si sûr... +categories: + - php +keywords: + - typage générique +authors: + - ajacquemin +--- + +### Introduction + +Le typage générique, non seulement c'est super, mais en plus, c'est classe. Dans un monde idéal, voilà à quoi ça ressemblerait en php : + +```php +class Collection { /* class definition ... */ } + + +$users = new Collection(); +``` + +Cela signifie que notre instance de collection `$users` ne peut accepter que des objets de type `User`. +Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parlé. Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire même de parser ces types génériques. + +Alors, pourquoi ces types ce sont-ils pas déjà disponibles dans notre langage préféré ? + +### Pourquoi c'est impossible en pratique + +Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. + +Or, c'est donc justement au runtime que se font toutes le assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performmance. Encore une fois, aujourd'hui pour la majorité des langages, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. +De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en valerait pas la peine dans le contexte actuel. + +PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à faire, et le nombre de développeurs qui maintiennent le coeur de PHP n'est pas mirobolant; il y a donc également un problème de ressource. + +Enfin, proposer une RFC pour les types génériques n'est pas si simple : il faut se mettre d'accord parmi les nombreuses possibilités d'implémentation possibles, trouver la meilleure, puis prendre le temps de l'implémenter. Des débats sans fin sont à prévoir. + +Pour toutes ces raisons, allant du design même du langage à la complexité d'implémentation, les génériques ne sont pas d'actualité pour le moment. +Mais, ne jamais dire jamais... + +### Typage générique statique, la solution ? + +Alors, que fait-on maintenant ? On se roule en boule dans un coin et on regrette d'avoir choisi PHP ? + +... Ou alors, on se tourne vers un des super pouvoirs de PHP; son écosystème d'anlyseurs statiques. +En effet, nous avons la chance en PHP d'avoir pléthore d'*analyseurs statiques*, tous extrêmement bien développés. + +Grâce à eux, notre IDE favori (PhpStorm bien entendu) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. +Problème de typage ? Argument oublié dans une fonction ? Variable inutilisée ? Condition toujours vraie ? Accolade ou point virgule oublié ? Et j'en passe ... +Créez même vos propres règles de lint, de bonnes pratiques à suivre dans votre équipe. Ces outils, comme PHPCs ou PHPStan, ... permettent tout cela. + +Et bien bonne nouvelle, certains de ces outils vous permettent de définir puis vérifier vos *types génériques*. + +Comment ? Tenez vous bien, en utilisant... les annotations de la PHPDoc... + +Bon je sais, certains ne sont pas convaincus, mais dites-vous bien la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. +Vous allez voir, après nos exemples, vous ne reviendrez plus en arrière. + +### Typage générique par l'exemple + +Alors, on trépigne d'impatience à l'idée de créer nos premiers types génériques ? + +Ne perdons plus de temps. Tout d'abord, pour créer un type, nous utiliseront toujours le même tag : `@template`. + +Par exemple au dessus d'une classe : + +```php +/** @template T */ +abstract class BaseRepository +{ + // ... +} +``` + +Ou au dessus d'une fonction : + +```php +/** @template T */ +function foo() +{ + // ... +} +``` + +

Note

+Si votre IDE n'est pas encore compatible avec l'annotation template ou avec le typage générique T, utilisez le prefix @phpstan, par exemple : @phpstan-template +
+ +Par convention, on nommera plutôt ce type `T`, mais soyez conscient que vous pouvez le nommer absolument comme vous le souhaitez. + +Et voilà, vous avez créé votre type générique `T` ! À quoi sert-t-il ? Comme vous vous en doutez, `T` est type qui ne signifie rien en tant que tel. Il est uniquement là pour être remplacé par un autre type (un vrai type cette fois-ci), que nous ne connaissons pas à l'avance. `T` est donc un type en contrat d'intérim, qui attend qu'un vrai type vienne faire le job. + +Il est temps à présent de s'amuser un peu avec. +Prenons l'exemple d'une fonction qui prend un paramètre en entrée, et renvoie cette même variable à la fin de son traitement. + +```php +function foo($bar) +{ + // Do something ... + + return $bar; +} +``` + +Mettons que nous ne savons pas à l'avance le type de `$bar`, mais nous voulons nous assurer que le type de retour est le même que ce qui est passé en paramètre. + +Vous l'avez compris, `T` est tout indiqué ici ! Nous pouvons faire cela : + +```php +/** + * @template T + * @param T $bar + * @return T + */ +function foo($bar) +{ + // Do something ... + + return $bar; +} +``` + +Et voilà, grâce aux tags `@param` et `@return`, vous indiquez à votre IDE que quelque soit le type de `$bar` en entrée, noté `T`, il devra avoir le même type lors du retour de la fonction. +Et si vous changez le type de `$bar` en cours de route en lui affectant une valeur de type différent, une erreur sera remontée lors de la prochaine exécution de PHPStan. +Exécutez simplement : + +```bash +./vendor/bin/phpstan +``` + +Et vous pourrez constater l'erreur de type retournée. Vous n'avez plus qu'à ajouter PHPStan dans votre CI, et vous ne pourrez plus pousser du code sans que vos types soient cohérents. + +Maintenant, mettons que vous en savez un peu plus sur le type que vous allez recevoir. Vous savez que vous ne recevrez jamais de type scalaire (`int`, `float`, `bool`, ...), mais toujours un `object`, sans savoir quelle classe exactement. +Vous pouvez limiter les types qui peuvent remplacer `T` avec la notation suivante : + +```php +/** + * @template T of object + * @param T $bar + * @return T + */ +function foo($bar) +{ + // ... +} +``` + +Grâce à cette notation, vous indiquez à votre analyseur statique que quelque soit le type reçu par votre méthode, il devrai forcément être un sous-type de `object`. + +

Note

+Vous pouvez mettre n'importe quel nom de classe à la place de `object`, par exemple `\Exception` peut être pratique pour accepter seulement des objets de types `Exception` sans savoir à l'avance quelle instance d'Exception exactement sera reçue. +
+ +Typer génériquement au niveau des classes peut-être très puissant également, prenons l'exemple classique des `Collection`. + +```php +/** @template T */ +class Collection +{ + /** @param T $item */ + public function add($item): void + { + // Add item to your collection + } +} +``` + +Que se passe-t-il si vous souhaitez une `Collection` qui ne contient uniquement des objets de type `Astronaut` ? + +Et bien comme vous avez ajouté du typage générique à votre classe, vous pouvez faire cela : + +```php +/** @param Collection $astronauts */ +public function foo(Collection $astronauts): void +{ + $astronauts->add(new Astronaut()); +} +``` + +Peut-être avez vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. Ici, indique simplement qu'il faut remplacer le type générique `T`, par celui précisé entre les chevrons. Ainsi pour toutes la fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre (ici, `Astronaut`), qui sera utilisé. +Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un nouveau type, dès que cela est indiqué dans le code. + +Voyons à présent un autre tag très important, le `@extends`. Il permet de tirer profit des types génériques avec **l'héritage**. + +L'exemple du `@extends` ci-dessous est tiré de notre [Codelabs à propos du concept de ***composition over inheritance***](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine). +Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans tous les cas, je vous le recommande pour sa dernière partie qui met en application les types génériques que nous sommes en train d'apprendre ici. + +Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...). + +

Note

+Pour rappel, un repository est une classe qui vous permet d'interagir avec votre base de données via les fonctions mises à votre disposition, et donc de manipuler vos objets. +
+ +```php +/** @template T of object */ +abstract class BaseRepository +{ + /** @param T $object */ + public function store(object $object): void + { + $this->entityManager->persist($object); + } + + /** @return ?T */ + public function find(int $id): ?object + { + return $this->repository->find($id); + } +} +``` + +Cette classe est censée être étendue par nos Repository métier, par exemple un `PostRepository` ou encore un `UserRepository`. +Or, elles étendrons nos fonctions `store` et `find`, qui sont typés `object`, car on ne sait pas à l'avance quel Repository va les utiliser. + +La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe, jusqu'ici, tout devrait vous paraître clair comme de l'eau de roche. + +Prenons à présent un de nos réels Repository, mettons le `UserRepository`. Voilà comment l'écrire : + +```php +/** @extends BaseRepository */ +class UserRepository extends BaseRepository +{ + // Repository body ... +} +``` + +Bien que le tag `@extends` est nouveau, la notation avec les chevrons devrait vous rappeler ce que nous avons fait avec les Collections. +Et ainsi comprendre ce qui se passe ici : grâce à cette annotation, on indique qu'en héritant du `BaseRepository`, on souhaite remplacer tous ses types `T` par nos types `User`. +Voilà ce qui en résultera : + +```php +public function index(UserRepository $userRepository): void +{ + // PHPStan is satisfied + $object = new User(); + $userRepository->store($object); + + // PHPStan throw an error + $object = new Post(); + $userRepository->store($object); +} +``` + +Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui n'aurait de toute façon pas été possible à l'exécution du code. Grâce au typage générique, vous augmentez la taille du filet qui attrape les erreurs dans votre code, avant que celui-ci ne se retrouve en production. + +Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le plutôt comme un pense-bête sur l'utilisation des génériques en PHP. +Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Codelabs](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. + +### Conclusion + +Oui, ce serait génial si dans le futur, PHP trouvait un moyen d'introduire les types génériques nativement dans notre langage préféré, mais en attendant, profiter de la puissance de nos analyseurs statiques est une option plus que satisfaisante pour améliorer notre expérience de développement, grâce à leur propre syntaxe du typage générique. + +Sachez que d'autres outils que PHPStan permettent d'interpréter ces annotations de la même manière, tel que Psalm. + +Il y aurait bien d'autrez choses à voir sur les types génériques, en particulier le tag `@template-covariant`, mais ce sera pour une partie 2, pourquoi pas ! En attendant, vous avez tout le nécessaire pour vous en sortir dans la grande majorité des situations. + +N'oubliez pas d'aller jeter un oeil à notre Codelabs, amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! From ef9cd2096ba2be87990a518f3819fff6f8821ffb Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Fri, 18 Aug 2023 12:14:42 +0200 Subject: [PATCH 02/21] =?UTF-8?q?=F0=9F=92=84=20Improve=20UI?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- _posts/fr/2023-08-23-typage-generique-en-php.md | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-08-23-typage-generique-en-php.md index d04e628eb..519bb4211 100644 --- a/_posts/fr/2023-08-23-typage-generique-en-php.md +++ b/_posts/fr/2023-08-23-typage-generique-en-php.md @@ -24,7 +24,9 @@ $users = new Collection(); ``` Cela signifie que notre instance de collection `$users` ne peut accepter que des objets de type `User`. -Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parlé. Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire même de parser ces types génériques. +Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parlé. + +Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire même de parser ces types génériques. Alors, pourquoi ces types ce sont-ils pas déjà disponibles dans notre langage préféré ? @@ -33,6 +35,7 @@ Alors, pourquoi ces types ce sont-ils pas déjà disponibles dans notre langage Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. Or, c'est donc justement au runtime que se font toutes le assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performmance. Encore une fois, aujourd'hui pour la majorité des langages, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. + De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en valerait pas la peine dans le contexte actuel. PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à faire, et le nombre de développeurs qui maintiennent le coeur de PHP n'est pas mirobolant; il y a donc également un problème de ressource. @@ -40,6 +43,9 @@ PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à Enfin, proposer une RFC pour les types génériques n'est pas si simple : il faut se mettre d'accord parmi les nombreuses possibilités d'implémentation possibles, trouver la meilleure, puis prendre le temps de l'implémenter. Des débats sans fin sont à prévoir. Pour toutes ces raisons, allant du design même du langage à la complexité d'implémentation, les génériques ne sont pas d'actualité pour le moment. + +![pikachu crying](https://media.giphy.com/media/L95W4wv8nnb9K/giphy.gif) + Mais, ne jamais dire jamais... ### Typage générique statique, la solution ? @@ -51,6 +57,7 @@ En effet, nous avons la chance en PHP d'avoir pléthore d'*analyseurs statiques* Grâce à eux, notre IDE favori (PhpStorm bien entendu) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. Problème de typage ? Argument oublié dans une fonction ? Variable inutilisée ? Condition toujours vraie ? Accolade ou point virgule oublié ? Et j'en passe ... + Créez même vos propres règles de lint, de bonnes pratiques à suivre dans votre équipe. Ces outils, comme PHPCs ou PHPStan, ... permettent tout cela. Et bien bonne nouvelle, certains de ces outils vous permettent de définir puis vérifier vos *types génériques*. From 110757c117ab81607c261da76cdac804e9048e1f Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Fri, 18 Aug 2023 12:40:22 +0200 Subject: [PATCH 03/21] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20Fix=20typos?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../fr/2023-08-23-typage-generique-en-php.md | 35 ++++++++++++------- 1 file changed, 23 insertions(+), 12 deletions(-) diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-08-23-typage-generique-en-php.md index 519bb4211..019386062 100644 --- a/_posts/fr/2023-08-23-typage-generique-en-php.md +++ b/_posts/fr/2023-08-23-typage-generique-en-php.md @@ -28,13 +28,13 @@ Nous aurions alors, notamment grâce à nos IDE intelligents, des informations p Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire même de parser ces types génériques. -Alors, pourquoi ces types ce sont-ils pas déjà disponibles dans notre langage préféré ? +Alors, pourquoi ces types ne sont-ils pas déjà disponibles dans notre langage préféré ? ### Pourquoi c'est impossible en pratique Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. -Or, c'est donc justement au runtime que se font toutes le assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performmance. Encore une fois, aujourd'hui pour la majorité des langages, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. +Or, c'est donc justement au runtime que se font toutes le assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en valerait pas la peine dans le contexte actuel. @@ -64,7 +64,7 @@ Et bien bonne nouvelle, certains de ces outils vous permettent de définir puis Comment ? Tenez vous bien, en utilisant... les annotations de la PHPDoc... -Bon je sais, certains ne sont pas convaincus, mais dites-vous bien la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. +Bon je sais, certains ne sont pas convaincus, mais dites-vous bien que la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. Vous allez voir, après nos exemples, vous ne reviendrez plus en arrière. ### Typage générique par l'exemple @@ -94,12 +94,14 @@ function foo() ```

Note

-Si votre IDE n'est pas encore compatible avec l'annotation template ou avec le typage générique T, utilisez le prefix @phpstan, par exemple : @phpstan-template +Si votre IDE n'est pas encore compatible avec l'annotation @template ou avec le typage générique T, utilisez le prefix @phpstan, par exemple : @phpstan-template
Par convention, on nommera plutôt ce type `T`, mais soyez conscient que vous pouvez le nommer absolument comme vous le souhaitez. -Et voilà, vous avez créé votre type générique `T` ! À quoi sert-t-il ? Comme vous vous en doutez, `T` est type qui ne signifie rien en tant que tel. Il est uniquement là pour être remplacé par un autre type (un vrai type cette fois-ci), que nous ne connaissons pas à l'avance. `T` est donc un type en contrat d'intérim, qui attend qu'un vrai type vienne faire le job. +Et voilà, vous avez créé votre type générique `T` ! Mais à quoi sert-t-il ? + +Comme vous vous en doutez, `T` est un type qui ne signifie rien en tant que tel. Il est uniquement là pour être remplacé par un autre type (un vrai type cette fois-ci), que nous ne connaissons pas à l'avance. `T` est donc un type en contrat d'intérim, qui attend qu'un vrai type vienne faire le job. Il est temps à présent de s'amuser un peu avec. Prenons l'exemple d'une fonction qui prend un paramètre en entrée, et renvoie cette même variable à la fin de son traitement. @@ -132,7 +134,9 @@ function foo($bar) ``` Et voilà, grâce aux tags `@param` et `@return`, vous indiquez à votre IDE que quelque soit le type de `$bar` en entrée, noté `T`, il devra avoir le même type lors du retour de la fonction. + Et si vous changez le type de `$bar` en cours de route en lui affectant une valeur de type différent, une erreur sera remontée lors de la prochaine exécution de PHPStan. + Exécutez simplement : ```bash @@ -142,6 +146,7 @@ Exécutez simplement : Et vous pourrez constater l'erreur de type retournée. Vous n'avez plus qu'à ajouter PHPStan dans votre CI, et vous ne pourrez plus pousser du code sans que vos types soient cohérents. Maintenant, mettons que vous en savez un peu plus sur le type que vous allez recevoir. Vous savez que vous ne recevrez jamais de type scalaire (`int`, `float`, `bool`, ...), mais toujours un `object`, sans savoir quelle classe exactement. + Vous pouvez limiter les types qui peuvent remplacer `T` avec la notation suivante : ```php @@ -156,10 +161,10 @@ function foo($bar) } ``` -Grâce à cette notation, vous indiquez à votre analyseur statique que quelque soit le type reçu par votre méthode, il devrai forcément être un sous-type de `object`. +Grâce à cette notation, vous indiquez à votre analyseur statique que quelque soit le type reçu par votre méthode, il devra forcément être un sous-type de `object`.

Note

-Vous pouvez mettre n'importe quel nom de classe à la place de `object`, par exemple `\Exception` peut être pratique pour accepter seulement des objets de types `Exception` sans savoir à l'avance quelle instance d'Exception exactement sera reçue. +Vous pouvez mettre n'importe quel nom de classe à la place de object, par exemple \Exception peut être pratique pour accepter seulement des objets de types Exception sans savoir à l'avance quelle instance d'Exception exactement sera reçue.
Typer génériquement au niveau des classes peut-être très puissant également, prenons l'exemple classique des `Collection`. @@ -188,7 +193,10 @@ public function foo(Collection $astronauts): void } ``` -Peut-être avez vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. Ici, indique simplement qu'il faut remplacer le type générique `T`, par celui précisé entre les chevrons. Ainsi pour toutes la fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre (ici, `Astronaut`), qui sera utilisé. +Peut-être avez vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. + +Ici, indique simplement qu'il faut remplacer le type générique `T`, par celui précisé entre les chevrons. Ainsi pour toutes la fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre type (ici, `Astronaut`), qui sera utilisé. + Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un nouveau type, dès que cela est indiqué dans le code. Voyons à présent un autre tag très important, le `@extends`. Il permet de tirer profit des types génériques avec **l'héritage**. @@ -220,12 +228,14 @@ abstract class BaseRepository } ``` -Cette classe est censée être étendue par nos Repository métier, par exemple un `PostRepository` ou encore un `UserRepository`. +Cette classe est censée être étendue par nos Repository métiers, par exemple un `PostRepository` ou encore un `UserRepository`. Or, elles étendrons nos fonctions `store` et `find`, qui sont typés `object`, car on ne sait pas à l'avance quel Repository va les utiliser. La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe, jusqu'ici, tout devrait vous paraître clair comme de l'eau de roche. -Prenons à présent un de nos réels Repository, mettons le `UserRepository`. Voilà comment l'écrire : +Prenons à présent un de nos réels Repository, le `UserRepository`. + +Voilà comment l'écrire : ```php /** @extends BaseRepository */ @@ -237,7 +247,7 @@ class UserRepository extends BaseRepository Bien que le tag `@extends` est nouveau, la notation avec les chevrons devrait vous rappeler ce que nous avons fait avec les Collections. Et ainsi comprendre ce qui se passe ici : grâce à cette annotation, on indique qu'en héritant du `BaseRepository`, on souhaite remplacer tous ses types `T` par nos types `User`. -Voilà ce qui en résultera : +Voilà ce qui en résultera en pratique : ```php public function index(UserRepository $userRepository): void @@ -252,9 +262,10 @@ public function index(UserRepository $userRepository): void } ``` -Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui n'aurait de toute façon pas été possible à l'exécution du code. Grâce au typage générique, vous augmentez la taille du filet qui attrape les erreurs dans votre code, avant que celui-ci ne se retrouve en production. +Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui n'aurait de toute façon pas été possible à l'exécution du code. Grâce au typage générique, vous augmentez la taille du filet qui attrape les erreurs dans votre code, avant que celui-ci ne soit exécuté en production. Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le plutôt comme un pense-bête sur l'utilisation des génériques en PHP. + Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Codelabs](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. ### Conclusion From 703564ba6e95c49e500d174e218468f5e2e30bfc Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 21 Aug 2023 09:10:17 +0200 Subject: [PATCH 04/21] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20Fix=20typos?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../fr/2023-08-23-typage-generique-en-php.md | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-08-23-typage-generique-en-php.md index 019386062..56f01d83b 100644 --- a/_posts/fr/2023-08-23-typage-generique-en-php.md +++ b/_posts/fr/2023-08-23-typage-generique-en-php.md @@ -24,23 +24,23 @@ $users = new Collection(); ``` Cela signifie que notre instance de collection `$users` ne peut accepter que des objets de type `User`. -Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parlé. +Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parler. -Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire même de parser ces types génériques. +Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire de parser ces types génériques. Alors, pourquoi ces types ne sont-ils pas déjà disponibles dans notre langage préféré ? ### Pourquoi c'est impossible en pratique -Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. +Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété ; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. -Or, c'est donc justement au runtime que se font toutes le assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. +Or, c'est donc justement au runtime que se font toutes les assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en valerait pas la peine dans le contexte actuel. -PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à faire, et le nombre de développeurs qui maintiennent le coeur de PHP n'est pas mirobolant; il y a donc également un problème de ressource. +PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à faire, et le nombre de développeurs qui maintiennent le coeur de PHP n'est pas mirobolant, il y a donc également un problème de ressource. -Enfin, proposer une RFC pour les types génériques n'est pas si simple : il faut se mettre d'accord parmi les nombreuses possibilités d'implémentation possibles, trouver la meilleure, puis prendre le temps de l'implémenter. Des débats sans fin sont à prévoir. +Enfin, proposer une RFC pour les types génériques n'est pas si simple : il faut se mettre d'accord parmi les nombreuses possibilités d'implémentation envisageables, trouver la meilleure, puis prendre le temps de l'implémenter. Des débats sans fin sont à prévoir. Pour toutes ces raisons, allant du design même du langage à la complexité d'implémentation, les génériques ne sont pas d'actualité pour le moment. @@ -52,7 +52,7 @@ Mais, ne jamais dire jamais... Alors, que fait-on maintenant ? On se roule en boule dans un coin et on regrette d'avoir choisi PHP ? -... Ou alors, on se tourne vers un des super pouvoirs de PHP; son écosystème d'anlyseurs statiques. +... Ou alors, on se tourne vers un des super pouvoirs de PHP : son écosystème d'analyseurs statiques. En effet, nous avons la chance en PHP d'avoir pléthore d'*analyseurs statiques*, tous extrêmement bien développés. Grâce à eux, notre IDE favori (PhpStorm bien entendu) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. @@ -181,7 +181,7 @@ class Collection } ``` -Que se passe-t-il si vous souhaitez une `Collection` qui ne contient uniquement des objets de type `Astronaut` ? +Que se passe-t-il si vous souhaitez une `Collection` qui contient uniquement des objets de type `Astronaut` ? Et bien comme vous avez ajouté du typage générique à votre classe, vous pouvez faire cela : @@ -195,7 +195,7 @@ public function foo(Collection $astronauts): void Peut-être avez vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. -Ici, indique simplement qu'il faut remplacer le type générique `T`, par celui précisé entre les chevrons. Ainsi pour toutes la fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre type (ici, `Astronaut`), qui sera utilisé. +Ici, on indique simplement qu'il faut remplacer le type générique `T` par celui précisé entre les chevrons. Ainsi pour toutes les fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre type (ici, `Astronaut`), qui sera utilisé. Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un nouveau type, dès que cela est indiqué dans le code. @@ -229,7 +229,7 @@ abstract class BaseRepository ``` Cette classe est censée être étendue par nos Repository métiers, par exemple un `PostRepository` ou encore un `UserRepository`. -Or, elles étendrons nos fonctions `store` et `find`, qui sont typés `object`, car on ne sait pas à l'avance quel Repository va les utiliser. +Or, elles étendrons nos fonctions `store` et `find`, qui sont typées `object`, car on ne sait pas à l'avance quel Repository va les utiliser. La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe, jusqu'ici, tout devrait vous paraître clair comme de l'eau de roche. @@ -274,6 +274,6 @@ Oui, ce serait génial si dans le futur, PHP trouvait un moyen d'introduire les Sachez que d'autres outils que PHPStan permettent d'interpréter ces annotations de la même manière, tel que Psalm. -Il y aurait bien d'autrez choses à voir sur les types génériques, en particulier le tag `@template-covariant`, mais ce sera pour une partie 2, pourquoi pas ! En attendant, vous avez tout le nécessaire pour vous en sortir dans la grande majorité des situations. +Il y aurait bien d'autres choses à voir sur les types génériques, en particulier le tag `@template-covariant`, mais ce sera pour une partie 2, pourquoi pas ! En attendant, vous avez tout le nécessaire pour vous en sortir dans la grande majorité des situations. N'oubliez pas d'aller jeter un oeil à notre Codelabs, amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! From 1133e35f11f90f1ead0d81dd9c9dad8d6cb785a6 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 15:59:44 +0100 Subject: [PATCH 05/21] fix: Add more context about entity manager --- _posts/fr/2023-08-23-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-08-23-typage-generique-en-php.md index 56f01d83b..33e2dbb38 100644 --- a/_posts/fr/2023-08-23-typage-generique-en-php.md +++ b/_posts/fr/2023-08-23-typage-generique-en-php.md @@ -207,7 +207,7 @@ Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans t Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...).

Note

-Pour rappel, un repository est une classe qui vous permet d'interagir avec votre base de données via les fonctions mises à votre disposition, et donc de manipuler vos objets. +Pour rappel, un repository est une classe qui vous permet d'interagir avec votre base de données via les fonctions mises à votre disposition, pour y récupérer des données, voire de les manipuler (insertion, mise à jour, suppression) grâce à l'Entity Manager présent dans le Repository.
```php From 6bd99892f9e2633f9f3f2f5d2e38e44ae0d492ca Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 16:37:15 +0100 Subject: [PATCH 06/21] fix: Update release data --- ...enerique-en-php.md => 2023-11-22-typage-generique-en-php.md} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename _posts/fr/{2023-08-23-typage-generique-en-php.md => 2023-11-22-typage-generique-en-php.md} (99%) diff --git a/_posts/fr/2023-08-23-typage-generique-en-php.md b/_posts/fr/2023-11-22-typage-generique-en-php.md similarity index 99% rename from _posts/fr/2023-08-23-typage-generique-en-php.md rename to _posts/fr/2023-11-22-typage-generique-en-php.md index 33e2dbb38..2fbf3e3ef 100644 --- a/_posts/fr/2023-08-23-typage-generique-en-php.md +++ b/_posts/fr/2023-11-22-typage-generique-en-php.md @@ -1,6 +1,6 @@ --- lang: fr -date: 2023-08-23 +date: 2023-11-22 slug: typage-generique-en-php title: Typage générique en php excerpt: Le typage générique en php, c'est impossible ? Pas si sûr... From b9d76dc5b4f767c8261a3b7379458f923d28af47 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 17:20:16 +0100 Subject: [PATCH 07/21] Move post in _articles --- {_posts => _articles}/fr/2023-11-22-typage-generique-en-php.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename {_posts => _articles}/fr/2023-11-22-typage-generique-en-php.md (100%) diff --git a/_posts/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md similarity index 100% rename from _posts/fr/2023-11-22-typage-generique-en-php.md rename to _articles/fr/2023-11-22-typage-generique-en-php.md From f6a2e06be27d9b2a60b8029d54aa789a58c74105 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 17:24:55 +0100 Subject: [PATCH 08/21] fixup! Move post in _articles --- _articles/fr/2023-11-22-typage-generique-en-php.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index 2fbf3e3ef..b829d41f0 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -1,4 +1,5 @@ --- +contentType: article lang: fr date: 2023-11-22 slug: typage-generique-en-php @@ -8,6 +9,9 @@ categories: - php keywords: - typage générique + - phpstan + - symfony + - doctrine authors: - ajacquemin --- From af63e5d1bda9071b08b8ee47296ecd1d4a6c98bd Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 17:37:15 +0100 Subject: [PATCH 09/21] Update link towards codelabs --- _articles/fr/2023-11-22-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index b829d41f0..a6950fe89 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -205,7 +205,7 @@ Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un Voyons à présent un autre tag très important, le `@extends`. Il permet de tirer profit des types génériques avec **l'héritage**. -L'exemple du `@extends` ci-dessous est tiré de notre [Codelabs à propos du concept de ***composition over inheritance***](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine). +L'exemple du `@extends` ci-dessous est tiré de mon [Codelabs à propos du concept de ***composition over inheritance***](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine). Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans tous les cas, je vous le recommande pour sa dernière partie qui met en application les types génériques que nous sommes en train d'apprendre ici. Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...). From fca643fd0305ad23f195eb0bb7d9458eb2f9db95 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 17:47:19 +0100 Subject: [PATCH 10/21] Rename Codelabs => Tutoriel --- _articles/fr/2023-11-22-typage-generique-en-php.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index a6950fe89..6d8554227 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -205,7 +205,7 @@ Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un Voyons à présent un autre tag très important, le `@extends`. Il permet de tirer profit des types génériques avec **l'héritage**. -L'exemple du `@extends` ci-dessous est tiré de mon [Codelabs à propos du concept de ***composition over inheritance***](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine). +L'exemple du `@extends` ci-dessous est tiré de mon [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) à propos du concept de ***composition over inheritance***]. Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans tous les cas, je vous le recommande pour sa dernière partie qui met en application les types génériques que nous sommes en train d'apprendre ici. Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...). @@ -270,7 +270,7 @@ Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le plutôt comme un pense-bête sur l'utilisation des génériques en PHP. -Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Codelabs](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. +Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. ### Conclusion @@ -280,4 +280,4 @@ Sachez que d'autres outils que PHPStan permettent d'interpréter ces annotations Il y aurait bien d'autres choses à voir sur les types génériques, en particulier le tag `@template-covariant`, mais ce sera pour une partie 2, pourquoi pas ! En attendant, vous avez tout le nécessaire pour vous en sortir dans la grande majorité des situations. -N'oubliez pas d'aller jeter un oeil à notre Codelabs, amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! +N'oubliez pas d'aller jeter un oeil à notre Tutoriel, amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! From 6f1fea02b01a80a476c046aebaf9617eba842dff Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Mon, 6 Nov 2023 17:53:34 +0100 Subject: [PATCH 11/21] fixup! Rename Codelabs => Tutoriel --- _articles/fr/2023-11-22-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index 6d8554227..8d9b094fa 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -205,7 +205,7 @@ Il faut vraiment voir `T` comme un type de substitution qui sera écrasé par un Voyons à présent un autre tag très important, le `@extends`. Il permet de tirer profit des types génériques avec **l'héritage**. -L'exemple du `@extends` ci-dessous est tiré de mon [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) à propos du concept de ***composition over inheritance***]. +L'exemple du `@extends` ci-dessous est tiré de mon [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) à propos du concept de ***composition over inheritance***. Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans tous les cas, je vous le recommande pour sa dernière partie qui met en application les types génériques que nous sommes en train d'apprendre ici. Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...). From be61a5451de318ad9cd27e46d7dbe86b63cbcffe Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Tue, 7 Nov 2023 11:45:11 +0100 Subject: [PATCH 12/21] fixup! fixup! Rename Codelabs => Tutoriel --- _articles/fr/2023-11-22-typage-generique-en-php.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index 8d9b094fa..474a7f2ad 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -171,7 +171,7 @@ Grâce à cette notation, vous indiquez à votre analyseur statique que quelque Vous pouvez mettre n'importe quel nom de classe à la place de object, par exemple \Exception peut être pratique pour accepter seulement des objets de types Exception sans savoir à l'avance quelle instance d'Exception exactement sera reçue. -Typer génériquement au niveau des classes peut-être très puissant également, prenons l'exemple classique des `Collection`. +Typer génériquement au niveau des classes peut-être très puissant également, prenons l'exemple classique des `Collection`, et regardez bien les annotations que j'y ai ajouté. ```php /** @template T */ @@ -185,9 +185,9 @@ class Collection } ``` -Que se passe-t-il si vous souhaitez une `Collection` qui contient uniquement des objets de type `Astronaut` ? +À présent, se passe-t-il si vous souhaitez une `Collection` qui ne contient uniquement des objets de type `Astronaut` ? -Et bien comme vous avez ajouté du typage générique à votre classe, vous pouvez faire cela : +Et bien grâce au typage générique que j'ai ajouté dans la classe `Collection`, vous pouvez faire cela : ```php /** @param Collection $astronauts */ @@ -235,7 +235,7 @@ abstract class BaseRepository Cette classe est censée être étendue par nos Repository métiers, par exemple un `PostRepository` ou encore un `UserRepository`. Or, elles étendrons nos fonctions `store` et `find`, qui sont typées `object`, car on ne sait pas à l'avance quel Repository va les utiliser. -La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe, jusqu'ici, tout devrait vous paraître clair comme de l'eau de roche. +La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe. Jusqu'ici, rien de nouveau. Prenons à présent un de nos réels Repository, le `UserRepository`. @@ -270,7 +270,7 @@ Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le plutôt comme un pense-bête sur l'utilisation des génériques en PHP. -Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://codelabs.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. +Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. ### Conclusion From 33f2fcaa80939e15c7d73bd274326e4939442d18 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Tue, 7 Nov 2023 12:11:51 +0100 Subject: [PATCH 13/21] fixup! Merge branch 'feat/add-post-typage-generique-en-php' of github.com:eleven-labs/blog.eleven-labs.com into feat/add-post-typage-generique-en-php --- _articles/fr/2023-11-22-typage-generique-en-php.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index 474a7f2ad..d563c1dab 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -18,7 +18,7 @@ authors: ### Introduction -Le typage générique, non seulement c'est super, mais en plus, c'est classe. Dans un monde idéal, voilà à quoi ça ressemblerait en php : +Le typage générique, non seulement c'est super, mais en plus, c'est classe. Dans un monde idéal, voilà à quoi ça ressemblerait en PHP : ```php class Collection { /* class definition ... */ } @@ -185,7 +185,7 @@ class Collection } ``` -À présent, se passe-t-il si vous souhaitez une `Collection` qui ne contient uniquement des objets de type `Astronaut` ? +À présent, que se passe-t-il si vous souhaitez une `Collection` qui contient uniquement des objets de type `Astronaut` ? Et bien grâce au typage générique que j'ai ajouté dans la classe `Collection`, vous pouvez faire cela : From 68759de0117db97fb36c49b88592d85fe60ba5c6 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Tue, 28 Nov 2023 13:57:41 +0100 Subject: [PATCH 14/21] Feedback: typo & link --- _articles/fr/2023-11-22-typage-generique-en-php.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2023-11-22-typage-generique-en-php.md index d563c1dab..559e8510a 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2023-11-22-typage-generique-en-php.md @@ -36,7 +36,7 @@ Alors, pourquoi ces types ne sont-ils pas déjà disponibles dans notre langage ### Pourquoi c'est impossible en pratique -Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété ; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite éxécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. +Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété ; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite exécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. Or, c'est donc justement au runtime que se font toutes les assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. @@ -280,4 +280,4 @@ Sachez que d'autres outils que PHPStan permettent d'interpréter ces annotations Il y aurait bien d'autres choses à voir sur les types génériques, en particulier le tag `@template-covariant`, mais ce sera pour une partie 2, pourquoi pas ! En attendant, vous avez tout le nécessaire pour vous en sortir dans la grande majorité des situations. -N'oubliez pas d'aller jeter un oeil à notre Tutoriel, amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! +N'oubliez pas d'aller jeter un oeil à notre [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine), amusez-vous bien avec ces outils, développez-bien, et à la prochaine ! From 0158b7a07b072c7d1283df7c97bed8708e798178 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Wed, 6 Dec 2023 11:22:17 +0100 Subject: [PATCH 15/21] Update release date --- ...enerique-en-php.md => 2024-01-10-typage-generique-en-php.md} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename _articles/fr/{2023-11-22-typage-generique-en-php.md => 2024-01-10-typage-generique-en-php.md} (99%) diff --git a/_articles/fr/2023-11-22-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md similarity index 99% rename from _articles/fr/2023-11-22-typage-generique-en-php.md rename to _articles/fr/2024-01-10-typage-generique-en-php.md index 559e8510a..c0d7f11be 100644 --- a/_articles/fr/2023-11-22-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -1,7 +1,7 @@ --- contentType: article lang: fr -date: 2023-11-22 +date: 2024-01-10 slug: typage-generique-en-php title: Typage générique en php excerpt: Le typage générique en php, c'est impossible ? Pas si sûr... From 24c5d3bed01e9a1d737e10fedb2ca50b24c0056d Mon Sep 17 00:00:00 2001 From: Arthur Date: Wed, 10 Jan 2024 11:08:20 +0100 Subject: [PATCH 16/21] Update 2024-01-10-typage-generique-en-php.md --- _articles/fr/2024-01-10-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index c0d7f11be..b6d801ad0 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -40,7 +40,7 @@ Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensu Or, c'est donc justement au runtime que se font toutes les assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. -De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en valerait pas la peine dans le contexte actuel. +De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en vaudrait pas la peine dans le contexte actuel. PHP a beaucoup évolué ces derniers temps, mais il reste beaucoup de choses à faire, et le nombre de développeurs qui maintiennent le coeur de PHP n'est pas mirobolant, il y a donc également un problème de ressource. From 3ec8134b6487ce9621f5393c1d140fe8ea3076a4 Mon Sep 17 00:00:00 2001 From: ElevenTom Date: Wed, 10 Jan 2024 14:51:55 +0100 Subject: [PATCH 17/21] Update 2024-01-10-typage-generique-en-php.md --- .../fr/2024-01-10-typage-generique-en-php.md | 46 +++++++++---------- 1 file changed, 23 insertions(+), 23 deletions(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index b6d801ad0..43d5e8a7b 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -2,9 +2,9 @@ contentType: article lang: fr date: 2024-01-10 -slug: typage-generique-en-php -title: Typage générique en php -excerpt: Le typage générique en php, c'est impossible ? Pas si sûr... +slug: typage-php +title: Typage générique en php : définition, bonnes pratiques et exemples +excerpt: Découvrez comment réaliser du typage générique en PHP : introduction et définition du concept, conseils et explications pas-à-pas de cas pratique. categories: - php keywords: @@ -16,7 +16,7 @@ authors: - ajacquemin --- -### Introduction +### Introduction au typage générique en PHP Le typage générique, non seulement c'est super, mais en plus, c'est classe. Dans un monde idéal, voilà à quoi ça ressemblerait en PHP : @@ -28,17 +28,17 @@ $users = new Collection(); ``` Cela signifie que notre instance de collection `$users` ne peut accepter que des objets de type `User`. -Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire de par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP, qui ne possède pas d'étape de compilation à proprement parler. +Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP qui ne possède pas d'étape de compilation à proprement parler. -Pour de nombreux langages, cette étape de compilation permet de soulever des erreurs dans le code, voire de parser ces types génériques. +Pour de nombreux langages de programmation utilisés en développement Web, cette étape de compilation permet de soulever des erreurs dans le code, voire de parser ces types génériques. Alors, pourquoi ces types ne sont-ils pas déjà disponibles dans notre langage préféré ? -### Pourquoi c'est impossible en pratique +### En quoi le typage générique en PHP est impossible dans la pratique ? Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété ; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite exécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. -Or, c'est donc justement au runtime que se font toutes les assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique, toutes ces assertions de type sont effectuées à la compilation, avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. +Or, c'est donc justement au runtime que se font toutes les assertions de type. Rajouter des étapes de vérification de types génériques serait une atteinte à la performance. Encore une fois, aujourd'hui pour la majorité des langages proposant le typage générique toutes ces assertions de type sont effectuées à la compilation avant que le code ne soit exécuté. La perfomance à l'exécution n'est donc pas un problème comme en PHP. De plus, on estime que rajouter cette gestion des types génériques dans le coeur de PHP demanderait un effort de refactoring très ambitieux, à tel point que le rapport ***bénéfice*** / ***temps passé à l'implémentation*** n'en vaudrait pas la peine dans le contexte actuel. @@ -52,7 +52,7 @@ Pour toutes ces raisons, allant du design même du langage à la complexité d'i Mais, ne jamais dire jamais... -### Typage générique statique, la solution ? +### Le typage générique PHP statique, la solution ? Alors, que fait-on maintenant ? On se roule en boule dans un coin et on regrette d'avoir choisi PHP ? @@ -62,18 +62,18 @@ En effet, nous avons la chance en PHP d'avoir pléthore d'*analyseurs statiques* Grâce à eux, notre IDE favori (PhpStorm bien entendu) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. Problème de typage ? Argument oublié dans une fonction ? Variable inutilisée ? Condition toujours vraie ? Accolade ou point virgule oublié ? Et j'en passe ... -Créez même vos propres règles de lint, de bonnes pratiques à suivre dans votre équipe. Ces outils, comme PHPCs ou PHPStan, ... permettent tout cela. +Créez même vos propres règles de lint, de bonnes pratiques à suivre dans votre équipe. Ces outils, comme PHPCs ou PHPStan, permettent tout cela. -Et bien bonne nouvelle, certains de ces outils vous permettent de définir puis vérifier vos *types génériques*. +Et bonne nouvelle, certains de ces outils vous permettent de définir puis vérifier vos *types génériques*. Comment ? Tenez vous bien, en utilisant... les annotations de la PHPDoc... Bon je sais, certains ne sont pas convaincus, mais dites-vous bien que la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. -Vous allez voir, après nos exemples, vous ne reviendrez plus en arrière. +Vous allez voir, après quelques exemples, vous ne reviendrez plus en arrière. ### Typage générique par l'exemple -Alors, on trépigne d'impatience à l'idée de créer nos premiers types génériques ? +Alors, on trépigne d'impatience à l'idée de créer ses premiers types génériques ? Ne perdons plus de temps. Tout d'abord, pour créer un type, nous utiliseront toujours le même tag : `@template`. @@ -165,10 +165,10 @@ function foo($bar) } ``` -Grâce à cette notation, vous indiquez à votre analyseur statique que quelque soit le type reçu par votre méthode, il devra forcément être un sous-type de `object`. +Grâce à cette notation, vous indiquez à votre analyseur statique que quel que soit le type reçu par votre méthode, il devra forcément être un sous-type de `object`.

Note

-Vous pouvez mettre n'importe quel nom de classe à la place de object, par exemple \Exception peut être pratique pour accepter seulement des objets de types Exception sans savoir à l'avance quelle instance d'Exception exactement sera reçue. +Vous pouvez mettre n'importe quel nom de classe à la place de object, par exemple \Exception peut être pratique pour accepter seulement des objets de types Exception sans savoir exactement à l'avance quelle instance d'Exception sera reçue.
Typer génériquement au niveau des classes peut-être très puissant également, prenons l'exemple classique des `Collection`, et regardez bien les annotations que j'y ai ajouté. @@ -197,7 +197,7 @@ public function foo(Collection $astronauts): void } ``` -Peut-être avez vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. +Peut-être avez-vous déjà vu cette notation avec les chevrons : `Collection`, notamment si vous avez déjà fait du TypeScript. Ici, on indique simplement qu'il faut remplacer le type générique `T` par celui précisé entre les chevrons. Ainsi pour toutes les fois où le type `T` est utilisé dans la classe `Collection` (ici, une fois sur la fonction `add`), c'est en réalité un autre type (ici, `Astronaut`), qui sera utilisé. @@ -208,10 +208,10 @@ Voyons à présent un autre tag très important, le `@extends`. Il permet de tir L'exemple du `@extends` ci-dessous est tiré de mon [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) à propos du concept de ***composition over inheritance***. Je vous le conseille si vous souhaitez en savoir plus sur ce principe, et dans tous les cas, je vous le recommande pour sa dernière partie qui met en application les types génériques que nous sommes en train d'apprendre ici. -Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repository (`find`, `store`, `remove`, etc...). +Prenons une classe `BaseRepository`, qui se veut être une classe abstraite contenant toutes les fonctions de base utilisées dans nos repositories (`find`, `store`, `remove`, etc...).

Note

-Pour rappel, un repository est une classe qui vous permet d'interagir avec votre base de données via les fonctions mises à votre disposition, pour y récupérer des données, voire de les manipuler (insertion, mise à jour, suppression) grâce à l'Entity Manager présent dans le Repository. +Pour rappel, un repository est une classe qui vous permet d'interagir avec votre base de données via les fonctions mises à votre disposition pour y récupérer des données, voire les manipuler (insertion, mise à jour, suppression) grâce à l'Entity Manager présent dans le Repository.
```php @@ -232,12 +232,12 @@ abstract class BaseRepository } ``` -Cette classe est censée être étendue par nos Repository métiers, par exemple un `PostRepository` ou encore un `UserRepository`. +Cette classe est censée être étendue par nos Repositories métiers, par exemple un `PostRepository` ou encore un `UserRepository`. Or, elles étendrons nos fonctions `store` et `find`, qui sont typées `object`, car on ne sait pas à l'avance quel Repository va les utiliser. La solution est de faire un type `T of object`, que l'on a déjà vu plus haut dans cet article. Puis on type les méthodes de la classe. Jusqu'ici, rien de nouveau. -Prenons à présent un de nos réels Repository, le `UserRepository`. +Prenons à présent un de nos réels Repositories, le `UserRepository`. Voilà comment l'écrire : @@ -249,8 +249,8 @@ class UserRepository extends BaseRepository } ``` -Bien que le tag `@extends` est nouveau, la notation avec les chevrons devrait vous rappeler ce que nous avons fait avec les Collections. -Et ainsi comprendre ce qui se passe ici : grâce à cette annotation, on indique qu'en héritant du `BaseRepository`, on souhaite remplacer tous ses types `T` par nos types `User`. +Bien que le tag `@extends` soit nouveau, la notation avec les chevrons devrait vous rappeler ce que nous avons fait avec les Collections. +Du coup on comprend ce qui se passe ici : grâce à cette annotation, on indique qu'en héritant du `BaseRepository`, on souhaite remplacer tous ses types `T` par nos types `User`. Voilà ce qui en résultera en pratique : ```php @@ -270,7 +270,7 @@ Ainsi, vous rajoutez de la sécurité en vous empêchant de faire une action qui Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le plutôt comme un pense-bête sur l'utilisation des génériques en PHP. -Pour une mise en application plus poussée et un accompagnement pas à pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. +Pour une mise en application plus poussée et un accompagnement pas-à-pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. ### Conclusion From af178b58afdc54e0fe5f820fce2b249b0a5490cb Mon Sep 17 00:00:00 2001 From: ElevenTom Date: Wed, 10 Jan 2024 15:10:22 +0100 Subject: [PATCH 18/21] Update 2024-01-10-typage-generique-en-php.md Fixed H2 + last typos --- _articles/fr/2024-01-10-typage-generique-en-php.md | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index 43d5e8a7b..243f31c01 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -9,6 +9,7 @@ categories: - php keywords: - typage générique + - typage PHP - phpstan - symfony - doctrine @@ -16,7 +17,7 @@ authors: - ajacquemin --- -### Introduction au typage générique en PHP +## Introduction au typage générique en PHP Le typage générique, non seulement c'est super, mais en plus, c'est classe. Dans un monde idéal, voilà à quoi ça ressemblerait en PHP : @@ -59,7 +60,7 @@ Alors, que fait-on maintenant ? On se roule en boule dans un coin et on regrette ... Ou alors, on se tourne vers un des super pouvoirs de PHP : son écosystème d'analyseurs statiques. En effet, nous avons la chance en PHP d'avoir pléthore d'*analyseurs statiques*, tous extrêmement bien développés. -Grâce à eux, notre IDE favori (PhpStorm bien entendu) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. +Grâce à eux, [notre IDE favori, PhpStorm bien entendu](https://blog.eleven-labs.com/fr/phpstorm-tips-config-extensions/) est en mesure de nous crier dessus à la moindre erreur décelable avant l'exécution. Problème de typage ? Argument oublié dans une fonction ? Variable inutilisée ? Condition toujours vraie ? Accolade ou point virgule oublié ? Et j'en passe ... Créez même vos propres règles de lint, de bonnes pratiques à suivre dans votre équipe. Ces outils, comme PHPCs ou PHPStan, permettent tout cela. @@ -71,7 +72,7 @@ Comment ? Tenez vous bien, en utilisant... les annotations de la PHPDoc... Bon je sais, certains ne sont pas convaincus, mais dites-vous bien que la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. Vous allez voir, après quelques exemples, vous ne reviendrez plus en arrière. -### Typage générique par l'exemple +## Cas pratique : créer un typage générique en PHP Alors, on trépigne d'impatience à l'idée de créer ses premiers types génériques ? @@ -272,7 +273,7 @@ Cet article est volontairement théorique, et sans exemple exhaustif. Prenez-le Pour une mise en application plus poussée et un accompagnement pas-à-pas de la vérification de ces types avec PHPStan, référez-vous au [Tutoriel](https://blog.eleven-labs.com/fr/composition-over-inheritance-et-typage-generique-avec-symfony-et-doctrine) cité plus haut dans cet article. -### Conclusion +## Conclusion Oui, ce serait génial si dans le futur, PHP trouvait un moyen d'introduire les types génériques nativement dans notre langage préféré, mais en attendant, profiter de la puissance de nos analyseurs statiques est une option plus que satisfaisante pour améliorer notre expérience de développement, grâce à leur propre syntaxe du typage générique. From 6f26c3b6a3b605650eb25200d9d70849ffb8f02c Mon Sep 17 00:00:00 2001 From: ElevenTom Date: Wed, 10 Jan 2024 15:12:54 +0100 Subject: [PATCH 19/21] Update 2024-01-10-typage-generique-en-php.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Majuscule à PHP dans le titre --- _articles/fr/2024-01-10-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index 243f31c01..0c2a1f837 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -3,7 +3,7 @@ contentType: article lang: fr date: 2024-01-10 slug: typage-php -title: Typage générique en php : définition, bonnes pratiques et exemples +title: Typage générique en PHP : définition, bonnes pratiques et exemples excerpt: Découvrez comment réaliser du typage générique en PHP : introduction et définition du concept, conseils et explications pas-à-pas de cas pratique. categories: - php From b5830338539219030fba8767aa651469b7a1e5e8 Mon Sep 17 00:00:00 2001 From: ElevenTom Date: Wed, 10 Jan 2024 15:14:38 +0100 Subject: [PATCH 20/21] Update 2024-01-10-typage-generique-en-php.md fixed slug --- _articles/fr/2024-01-10-typage-generique-en-php.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index 0c2a1f837..f7aa8a5ca 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -2,7 +2,7 @@ contentType: article lang: fr date: 2024-01-10 -slug: typage-php +slug: typage-generique-php title: Typage générique en PHP : définition, bonnes pratiques et exemples excerpt: Découvrez comment réaliser du typage générique en PHP : introduction et définition du concept, conseils et explications pas-à-pas de cas pratique. categories: From a3580ac4845a71fd636fb12484c79ee149a3a191 Mon Sep 17 00:00:00 2001 From: ArthurJCQ Date: Wed, 10 Jan 2024 17:17:13 +0100 Subject: [PATCH 21/21] Fix MD error --- _articles/fr/2024-01-10-typage-generique-en-php.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/_articles/fr/2024-01-10-typage-generique-en-php.md b/_articles/fr/2024-01-10-typage-generique-en-php.md index f7aa8a5ca..34b5c9b0a 100644 --- a/_articles/fr/2024-01-10-typage-generique-en-php.md +++ b/_articles/fr/2024-01-10-typage-generique-en-php.md @@ -3,8 +3,8 @@ contentType: article lang: fr date: 2024-01-10 slug: typage-generique-php -title: Typage générique en PHP : définition, bonnes pratiques et exemples -excerpt: Découvrez comment réaliser du typage générique en PHP : introduction et définition du concept, conseils et explications pas-à-pas de cas pratique. +title: "Typage générique en PHP : définition, conseils et exemples" +excerpt: "Découvrez comment réaliser du typage générique en PHP : introduction et définition du concept, conseils et explications pas-à-pas de cas pratique." categories: - php keywords: @@ -31,11 +31,11 @@ $users = new Collection(); Cela signifie que notre instance de collection `$users` ne peut accepter que des objets de type `User`. Nous aurions alors, notamment grâce à nos IDE intelligents, des informations plus strictes sur le type de données admises par une instance de Collection, sans avoir à simplement le déduire par le nom de la variable. L'analyse statique de notre code serait encore plus performante, ce qui est important en PHP qui ne possède pas d'étape de compilation à proprement parler. -Pour de nombreux langages de programmation utilisés en développement Web, cette étape de compilation permet de soulever des erreurs dans le code, voire de parser ces types génériques. +Pour de nombreux langages de programmation, cette étape de compilation permet de soulever des erreurs dans le code, voire de parser ces types génériques. Alors, pourquoi ces types ne sont-ils pas déjà disponibles dans notre langage préféré ? -### En quoi le typage générique en PHP est impossible dans la pratique ? +## En quoi le typage générique en PHP est impossible dans la pratique ? Comme dit plus haut, PHP n'est pas un langage que l'on compile pour envoyer ensuite un exécutable sur le serveur. PHP est interprété ; lorsque le serveur reçoit une requête, le code PHP est converti en OPCODE, lui-même ensuite exécuté par une machine virtuelle. Si une erreur s'est glissée dans le code, alors le programme plantera à l'exécution. @@ -53,7 +53,7 @@ Pour toutes ces raisons, allant du design même du langage à la complexité d'i Mais, ne jamais dire jamais... -### Le typage générique PHP statique, la solution ? +## Les types statiques, la solution ? Alors, que fait-on maintenant ? On se roule en boule dans un coin et on regrette d'avoir choisi PHP ? @@ -72,7 +72,7 @@ Comment ? Tenez vous bien, en utilisant... les annotations de la PHPDoc... Bon je sais, certains ne sont pas convaincus, mais dites-vous bien que la PHPDoc est une manière très puissante d'enrichir PHP sans avoir à toucher au code. Vous allez voir, après quelques exemples, vous ne reviendrez plus en arrière. -## Cas pratique : créer un typage générique en PHP +## Cas pratique : créer un type générique en PHP Alors, on trépigne d'impatience à l'idée de créer ses premiers types génériques ?