DEV Community

Cover image for Git par l'exemple - Cherie, ça va cherry-picker !

Git par l'exemple - Cherie, ça va cherry-picker !

Aurélie Vache on October 31, 2023

Je penses que cette situation nous est tous arrivé ... Je suis sur une branche Git, ma branche de travail. Je fais mes modifications, je commi...
Collapse
 
lomalarch profile image
Noé Cendrier

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

glo mauvaise-branche
db6f662 (HEAD -> mauvaise-branche, origin/mauvaise-branche) merge develop-2 sur mauvaise branche
735gd98 un commit sur develop-2 à récupérer sur ma branche
7643233 (origin/ma-branche, ma-branche) premier commit good
17217a7 (origin/main, origin/HEAD, main) Initial commit
Enter fullscreen mode Exit fullscreen mode

et, du coup :

git checkout ma-branche
git cherry-pick -m 1 db6f662
Enter fullscreen mode Exit fullscreen mode

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…)

Collapse
 
aurelievache profile image
Aurélie Vache

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 :)

Collapse
 
bcouetil profile image
Benoit COUETIL 💫

Un bon moyen d'éviter ça, c'est d'afficher la branche systématiquement dans le prompt 😉

Collapse
 
aurelievache profile image
Aurélie Vache

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 :).

Collapse
 
bcouetil profile image
Benoit COUETIL 💫

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 :

git reset origin/mauvaise-branche
git stash
git switch ma-branche
git stash pop
git commit -am"same message"
Enter fullscreen mode Exit fullscreen mode

Plus concis, non ?

Collapse
 
virginiel profile image
VirginieLemaire

Super, c'est vraiment très clair 👍
Merci

Collapse
 
aurelievache profile image
Aurélie Vache

Merci ! :)