Je penses que cette situation nous est tous arrivé ...
Je suis sur une branche Git, ma branche de travail. Je fais mes modifications, je commit, je push sur ma branche, impec.
A un moment, en montrant quelque chose a un collegue, je change de branche.
Plus tard, je reviens sur mon travail, je fais mes modifications de fichier, je commit et là ... je m'apperçois que je ne suis plus sur MA branche, mais sur la branche master/main qui est protégée en ecriture par exemple.
Que faire dans ce cas là ?
C'est là que le pouvoir du Git cherry-pick entre en jeu !
Git Cherry Pick
Le Git Cherry Pick permet de copier un commit d'une branche à une autre et c'est ce qui va nous aider, voir nous sauver, dans cette situation ! :-)
Les logs
En premier, nous allons regarder les logs dans la mauvaise branche, afin de récupérer l'ID du commit que nous voulons copier.
$ git log --oneline --decorate
db6f662 (HEAD -> mauvaise-branche, origin/mauvaise-branche) commit sur mauvaise branche
7643233 (origin/ma-branche, ma-branche) premier commit good
17217a7 (origin/main, origin/HEAD, main) Initial commit
...
On voit bien notre commit, il s'agit du db6f662
.
Astuce :
Vous pouvez ajouter en alias cette ligne de commande à rallonge :
alias glo='git log --oneline --decorate'
Placez-vous dans votre branche de travail (la bonne !)
A présent, on se place dans la bonne branche de travail :
$ git switch ma-branche
Switched to branch 'ma-branche'
Comme vous pouvez voir, votre commit n'apparait pas encore :
$ glo
7643233 (HEAD -> ma-branche, origin/ma-branche) premier commit good
17217a7 (origin/main, origin/HEAD, main) Initial commit
(END)
Cherry-pick du commit
Maintenant, nous allons utiliser la commande git cherry-pick
pour copier le commit dans notre branche :
$ git cherry-pick db6f662
[ma-branche 46f048d] commit sur mauvaise branche
Date: Mon Oct 30 18:13:05 2023 +0100
1 file changed, 1 insertion(+)
Regardons l'historique Git/les logs de votre branche Git afin de vérifier que le commit a été ajouté :
$ glo
46f048d (HEAD -> ma-branche) commit sur mauvaise branche
7643233 (origin/ma-branche) premier commit good
17217a7 (origin/main, origin/HEAD, main) Initial commit
(END)
Super, le commit apparait bien maintenant dans la bonne branche !
Parfait :-)
A noter que l'on peut "cherry-picker" plusieurs commits à la fois :
$ git cherry-pick <COMMIT_ID1> <COMMIT_ID2> <COMMIT_ID3>
Conclusion
Git est un gestionnaire de version (SCM) utilisé en masse, mais comme de nombreux outils que l'on utilise au quotidien, il regorge de nombreuses fonctionnalités super pratique mais pas super simple à comprendre.
J'espère que cet exemple vous sera utile.
Top comments (7)
Bonjour,
Si je peux me permettre d’ajouter mon grain de sel, il y a le cas où in peut avoir besoin de récupérer un commit de merge, auquel cas on va utilise l’option -m
et, du coup :
permettra de récupérer tous les commits du merge (y compris celui de fusion) dans ma-branche !
(oui, mes collègues aussi trouvent que j’ai l’esprit tordu…)
Yes je connaissais l'option -m et oui effectivement cela eput aider dans certains cas.
Je pense qu'on a tous des histoires, tordues ou pas, avec Git :-D
merci :)
Un bon moyen d'éviter ça, c'est d'afficher la branche systématiquement dans le prompt 😉
Cette astuce je l'ai, mais à force de l'avoir tout le temps on peut ne plus la lire à un certain moment. Ou bien en devant switcher sur 3-4 branches dans la meme matinée il se peut qu'a un moment on se trompe :).
J'avoue que ça m'est déjà arrivé aussi, mais pas sur 2 commits successifs, car par automatisme je jette un oeil à la branche présentée par le prompt !
Et dans ce cas d'erreur tu n'as pas seulement à cherry-pick, tu as également à nettoyer la branche initiale, c'est donc plus coûteux que ce que tu indiques en opérations.
Du coup je préfère :
Plus concis, non ?
Super, c'est vraiment très clair 👍
Merci
Merci ! :)
Some comments may only be visible to logged-in visitors. Sign in to view all comments.