Aller au contenu principal
Comment patcher une dépendance Composer sans la forker ?

Comment patcher une dépendance Composer sans la forker ?

Lorsque vous travaillez sur un projet PHP utilisant Composer pour la gestion des dépendances, il peut arriver que l’une de vos bibliothèques présente un bug ou nécessite une modification spécifique pour répondre à vos besoins. La solution immédiate qui vient souvent à l'esprit est de forker le dépôt, y apporter les modifications nécessaires, puis de l'utiliser comme source dans votre projet.

Cependant, cette approche n’est pas toujours idéale. Forker une dépendance signifie prendre en charge sa maintenance, suivre ses mises à jour et gérer les éventuelles incompatibilités futures. Cela peut rapidement devenir un fardeau, surtout si vous devez maintenir plusieurs forks.

Heureusement, il existe une alternative élégante : appliquer un patch directement sur la dépendance, sans avoir besoin de forker. Cette méthode vous permet de corriger ou modifier le comportement de la bibliothèque tout en continuant à bénéficier des mises à jour officielles.

Dans cet article, nous explorerons comment utiliser Composer et les outils associés pour appliquer des patchs à vos dépendances de manière efficace, maintenable et sans complexifier votre workflow. Que vous soyez développeur débutant ou expérimenté, cette technique pourra vous faire gagner du temps et simplifier la gestion de vos projets.

4 étapes pour réaliser votre patch

1 - Installation des packages nécessaires au patch

composer require cweagans/composer-patches symplify/vendor-patches --dev

2 - Préparer le fichier de patch

Dans le dossier de vos vendors, une fois le bon fichier identifié, créez une copie de ce dernier en le suffixant par ".old"

cp vendor/package/toto/src/toto.php vendor/package/toto/src/toto.php.old

Il suffit maintenant de modifier le fichier ".php" et d'appliquer vos modifications.

Seuls les fichiers *.php sont chargés, et non les fichiers *.php.old. De cette manière, vous pouvez vous assurer que le nouveau code fonctionne correctement avant de générer les patchs.

3 - Création du patch

Exécuter la ligne suivante :

vendor/bin/vendor-patches generate

Cette ligne va générer un fichier dans le dossier patches, voici un exemple :

/patches/package-toto-src-toto.php.patch

Le chemin du patch est créé à partir du chemin du fichier original, ce qui garantit que le nom du patch est toujours unique.

De plus, la configuration pour cweagans/composer-patches est ajoutée à votre fichier composer.json :

{
    "extra": {
        "patches": {
            "package/toto": [
                "patches/package-toto-src-toto.php.patch"
            ]
        }
    }
}

4 - Réinstallation des package et vérification du patch

Il suffit de vérifier que tout fonctionne en remettant au propre le code.

Le plus simple est de supprimer le dossier vendor et de relancer l'installation des packages:

rm -Rf vendor
composer install

Et voilà, vous êtes maintenant un maître dans l'art de patcher vos dépendances sans tout casser (ou presque) ! Avec cette méthode, vous pourrez corriger des bugs plus vite que votre collègue ne corrige ses fautes de frappe dans Slack. Alors, à vos claviers, et que vos projets soient aussi stables qu'un serveur un vendredi soir à 18h ! ?

Étiquettes

Ajouter un commentaire

HTML restreint

  • Vous pouvez aligner les images (data-align="center"), mais également les vidéos, citations, etc.
  • Vous pouvez légender les images (data-align="center"), mais également les vidéos, citations, etc.
Experts en innovation, services, produits sur mesure, et intégration IA.

Contact

Derniers articles