Réorganisez vos commits Git
Git est un puissant système de contrôle de version qui aide les développeurs à gérer efficacement les modifications apportées à leurs projets. Parfois, vous devrez peut-être déplacer les validations récentes de la branche principale vers une nouvelle branche. Cela peut être dû à diverses raisons, telles que l'isolement de nouvelles fonctionnalités ou la séparation du travail expérimental du projet principal.
Dans ce guide, nous vous guiderons à travers les étapes pour déplacer vos derniers commits vers une nouvelle branche et réinitialiser votre branche principale à un état précédent. En suivant ces instructions, vous conserverez un historique de validation propre et organisé, garantissant que votre projet reste gérable et compréhensible pour tous les membres de l'équipe.
Commande | Description |
---|---|
git checkout -b newbranch | Crée une nouvelle branche nommée « newbranch » et y bascule immédiatement. |
git reset --hard HEAD~3 | Réinitialise la branche actuelle à l'état dans lequel elle se trouvait il y a trois validations, en annulant toutes les modifications. |
git push origin newbranch | Pousse la branche « newbranch » vers le référentiel distant nommé « origin ». |
git push origin master --force | Met à jour de force la branche « maître » distante pour qu'elle corresponde à la branche « maître » locale, même si elle réécrit l'historique. |
git branch newbranch | Crée une nouvelle branche nommée « newbranch » sans y accéder. |
git cherry-pick C D E | Applique les modifications introduites par les commits spécifiés (C, D et E) à la branche actuelle. |
git log --oneline --graph | Affiche une représentation graphique concise de l’historique des validations. |
Explication détaillée des commandes Git
Les scripts fournis montrent comment déplacer les commits récents vers une nouvelle branche et réinitialiser le branchement vers un état antérieur. Tout d'abord, la commande crée une nouvelle branche nommée et y passe. Ceci est suivi par git reset --hard HEAD~3, qui réinitialise le branchez vers l'état dans lequel il se trouvait il y a trois commits, supprimant ainsi les derniers commits. Cette commande est cruciale pour nettoyer l’historique des validations en supprimant les modifications indésirables.
Ensuite, la commande pousse la branche nouvellement créée vers le référentiel distant, la rendant disponible pour la collaboration. Finaliser, met à jour de force la télécommande branche pour correspondre à l’état local, même si cela implique de réécrire l’histoire. Le deuxième script met en évidence git branch newbranch pour créer une nouvelle branche sans y accéder, et pour appliquer des commits spécifiques d’une branche à une autre. Enfin, fournit une représentation visuelle de l’historique des validations, facilitant la vérification des modifications.
Déplacer les commits récents vers une nouvelle branche dans Git
Utiliser les commandes Git
# Create a new branch and switch to it
git checkout -b newbranch
# Reset the master branch to the previous state
git checkout master
git reset --hard HEAD~3
# Push the new branch to the remote repository
git push origin newbranch
# Force push the reset master branch to the remote repository
git push origin master --force
Création et passage à une nouvelle branche dans Git
Utiliser Git Bash
# Step 1: Check the current branch
git branch
# Step 2: Create a new branch
git branch newbranch
# Step 3: Move commits to the new branch
git checkout newbranch
git cherry-pick C D E
# Step 4: Verify the branches
git log --oneline --graph
Comprendre la gestion des branches et de l'historique Git
Un autre aspect important du travail avec Git est la gestion des historiques de branche pour garder le référentiel propre et maintenable. Lors du déplacement de commits récents vers une nouvelle branche, il est essentiel de comprendre l’impact sur la collaboration. Par exemple, forcer les changements avec peut perturber le travail des membres de l'équipe s'ils ont déjà basé leur travail sur ces commits. Il est donc crucial de communiquer avec votre équipe avant d’effectuer de tels changements.
De plus, vous pouvez utiliser pour maintenir un historique de projet linéaire. Le rebasage vous permet de déplacer ou de combiner des commits, garantissant ainsi que l'historique des commits reste organisé et facile à suivre. Cette pratique est particulièrement utile dans les branches de fonctionnalités de longue durée dans lesquelles vous souhaitez incorporer des mises à jour de la branche principale sans créer de validations de fusion inutiles. La maîtrise de ces techniques améliorera considérablement votre flux de travail et votre collaboration Git.
- Comment créer une nouvelle branche dans Git ?
- Utilisez la commande pour créer une nouvelle branche.
- Quel est le but de ?
- Il réinitialise la branche actuelle à un état spécifique, annulant toutes les modifications apportées après ce point.
- Comment puis-je voir une représentation visuelle de mon historique Git ?
- Utiliser pour afficher un historique de validation graphique et concis.
- Pourquoi devrais-je éviter d'utiliser ?
- La poussée forcée peut écraser l’historique à distance et perturber le travail des collaborateurs. Utilisez-le avec prudence.
- Qu'est-ce que faire?
- Il applique les modifications de commits spécifiques à la branche actuelle.
- Comment puis-je incorporer les mises à jour de la branche principale sans validation de fusion ?
- Utiliser pour réappliquer vos modifications au-dessus de la dernière branche principale.
- Quel est l’avantage de maintenir un historique de projet linéaire ?
- Cela rend l’historique des validations plus facile à comprendre et à suivre, ce qui est utile pour la collaboration.
- Comment changer de branche dans Git ?
- Utiliser pour passer à une branche existante.
- Puis-je récupérer les commits qui ont été réinitialisés avec ?
- Oui, utilisez pour trouver le hachage de validation et y revenir.
Étapes pour déplacer les commits Git récents
Un autre aspect important du travail avec Git est la gestion des historiques de branche pour garder le référentiel propre et maintenable. Lors du déplacement de commits récents vers une nouvelle branche, il est essentiel de comprendre l’impact sur la collaboration. Par exemple, forcer les changements avec peut perturber le travail des membres de l'équipe s'ils ont déjà basé leur travail sur ces commits. Il est donc crucial de communiquer avec votre équipe avant d’effectuer de tels changements.
De plus, vous pouvez utiliser pour maintenir un historique de projet linéaire. Le rebasage vous permet de déplacer ou de combiner des commits, garantissant ainsi que l'historique des commits reste organisé et facile à suivre. Cette pratique est particulièrement utile dans les branches de fonctionnalités de longue durée dans lesquelles vous souhaitez incorporer des mises à jour de la branche principale sans créer de validations de fusion inutiles. La maîtrise de ces techniques améliorera considérablement votre flux de travail et votre collaboration Git.
La maîtrise des commandes Git pour la gestion des succursales est essentielle pour maintenir un historique de projet propre et efficace. En déplaçant les commits récents vers une nouvelle branche et en réinitialisant la branche principale, vous pouvez isoler les modifications et maintenir la stabilité de votre branche principale. Comprendre les commandes comme , , et peut grandement améliorer votre flux de travail et votre collaboration. Communiquez toujours avec votre équipe avant d'apporter des changements importants pour éviter de perturber leur travail.