Les commandes essentielles de Git
Git synthétique
Git, logiciel de gestion de versions décentralisé. Git gagne du terrain, depuis longtemps déjà. Les développeurs cherchent des réponses et des idées sur GitHub. Et pourtant, des commandes basiques restent méconnues.
Les plugins Git des IDE ne permettent pas tout. Cet article donne les commandes essentielles de Git, celles qui servent tous les jours ou presque. Pas de théorie, peu d’explications, pas de problèmes complexes. Pour ça, le site officiel est très bien fait : Git-scm
Ce billet, c’est un kit de survie si vous avez installé Git, si vous utilisez des dépôts standards avec quelques branches principales et quelques branches feature, mais si vous vous demandez trop souvent « Mais comment déjà que »
Alors à vos lignes de commandes ! Pour débuter ou pour un usage quotidien, tout est là :
Commandes de base
Télécharger un dépôt distant
git clone https://github.com/spring-projects/spring-framework
Changer de branche courante
git checkout myBranch
Récupérer les modifications faites sur le dépôt distant
git pull
Gérer les problèmes de caractères de fins de ligne (important pour le travail en équipe)
Windows
git config −−global core.autocrlf true
Linux ou Mac
git config −−global core.autocrlf input
Voir les fichiers modifiés
git status
Annuler la modification d’un fichier (les modifications locales sont perdues)
git checkout −− chemin/monFichier
Ajouter un fichier à committer (il fera partie du prochain commit)
git add chemin/monFichier
Annuler l’ajout
git reset −− chemin/monFichier
Ajouter tous les fichiers
git add .
Committer (committe en local tous les fichiers qu’on a ajoutés; ne fait rien à distance)
git commit -m ″message de commit″
Livrer (livre les commits sur le dépôt distant)
git push
Mettre des modifications de côté (restaure les fichiers, mais garde une trace de leur état modifié)
git stash
Annuler ce stash
git stash pop
Récupérer les modifications distantes en évitant tout problème de merge (c’est-à-dire une gestion des merges qui pourrait rendre moins lisible l’historique d’un fichier)
git pull −−rebase
Commandes pour l’usage quotidien
Obtenir les branches et les tags disponibles (dans un usage standard, origin est sans doute le nom du dépôt en local)
git fetch origin
Lister les branches disponibles
git branch −v −a
Récupérer une branche newBranch en local
git checkout -b newBranch origin/newBranch
Reporter un commit d’une branche dans une autre branche (le numéro identifie le commit, tous les commits en ont un)
git cherry-pick 5b6f78ac6a2e648b2332967b515261d297bfa13b
Créer une branche locale myBranch avec le contenu de refBranch
git checkout -b myBranch refBranch
Livrer une branche locale sur le distant
git push origin myBranch
Supprimer une branche locale
git branch -D myBranch
Supprimer une branche sur le dépôt distant
git push origin −−delete myBranch
Annuler un commit
git reset HEAD~1
Supprimer toutes les modifications, revenir à zéro (quand on est perdu après un merge ou autre)
git reset −−hard
git clean -di
Plus de commandes
Restaurer un fichier supprimé en local
git reset −− chemin/monFichier
Puis git checkout −− chemin/monFichier
Annuler un push vers le dépôt distant (le numéro identifie le commit)
git revert 5b6f78ac6a2e648b2332967b515261d297bfa13b
Voir les différences entre 2 branches
git diff origin/master..origin/featureBranch
Merger les commits d’une branche dans une autre (ne fait rien sur le distant, reporte les commits de featureBranch vers la branche courante)
git merge −−no-ff featureBranch
Merger les commits d’une branche sans committer (permet de voir les fichiers qui sont modifiés)
git merge −−no-commit −−no-ff featureBranch
Supprimer les branches locales qui n’existent plus sur le dépôt distant
git remote prune origin
Historique des commits
git log
Trouver les commits dont le message contient ″JIRA-5689″
git log −−grep ″JIRA-5689″
Créer un tag depuis une branche
git tag -a <tag_name> myBranch
Livrer un tag sur le dépôt distant
git push origin <tag_name>
Lister les tags
git tag -l
Récupérer le contenu d’un tag
git checkout tags/<tag_name>
Supprimer un tag en local
git tag −−delete <tag_name>
Supprimer un tag sur le dépôt distant
git push −−delete origin <tag_name>
Et voilà ! Dans la vie de tous les jours, ça suffira. Pour aller plus loin, OXiane propose une formation Git.