depot_local.md 8.7 KB


title: "Tutoriel git


introduction | installation | dépôt local | dépôt distant | branches | forks
" output:

toc: true


Dépôt local

L'élément de base d'un projet git est le dépôt. Il s'agit simplement d'un dossier classique que l'on demande à git de versionner (journaliser).

Un dépôt git contient l'ensemble des commits (versions sauvegardées du projet). Ces commits peuvent être marqués par des étiquettes. Il existe deux étiquettes prédéfinies et gérées par git : master (dernier commit) et HEAD (commit/état courant des fichiers).

Initialiser un dépôt

Allez dans le dossier à versionner puis lancez la commande git init.

Git crée alors un dossier .git pour y stocker ses metadonnées. Si vous ne voulez plus versionner votre dossier, il suffit de supprimer ce dossier. Le reste du temps, ne touchez pas à ce dossier si vous n'êtes pas absolument sûr(e) de ce que vous faites.

Afficher l'état d'un dépôt

La commande git status affiche l'état courant du dépôt : nouveaux fichiers, fichiers modifiés, fichiers supprimés. Cette commande est très sûre; elle ne peut rien casser. N'hésitez donc pas à la lancer pour voir où vous en êtes.

Ajouter des fichiers dans le dépôt

Il faut indiquer explicitement les fichiers que git doit journaliser.

Par exemple, imaginons qu'on ouvre un nouveau fichier LaTeX rapport_01.tex dans notre projet.

Et on affiche l'état du dépôt.

Git nous indique que le fichier rapport_01.tex existe bien dans le dossier (ainsi qu'un fichier de sauvegarde), mais qu'il ne fait pas partie du dépôt.

Pour ajouter un fichier au dépôt, il faut utiliser la commande git add.

Ceci indique que git doit prendre en compte le fichier lors des prochains commits (journalisation), ce qu'on peut vérifier avec un git status.

Valider les modifications (commit)

Après avoir ajouté, modifié ou supprimé des fichiers, on peut valider les modifications, c'est-à-dire sauvegarder un état du projet (commit). Encore une fois, seuls les fichiers qui ont été ajoutés au projet (avec git add) sont pris en compte.

La commande à lancer pour valider toutes les modifications est git commit -a.

Git lance alors l'éditeur de texte pour le message de commit. Le message est pré-rempli avec des informations concernant le commit. Ces informations vous permettent de vérifier que le commit correspond bien à ce que vous voulez mais ne feront pas partie du message final.

Écrivez un message expliquant rapidement les modifications que vous êtes en train de valider puis enregistrez et quittez.

Git crée alors le nouveau commit, qui valide ici le fichier rapport_01.tex.

Vous pouvez le vérifier avec un git status.

Ainsi, un git commit crée un commit à partir de l'état pointé par HEAD et fait pointer master (et HEAD) sur ce nouveau commit.

Fichiers autogénérés et .gitignore

Git est très utile pour gérer des fichiers textes que l'on modifie régulièrement. En revanche, il n'est pas adapté pour gérer des fichiers dans un format non-textuel (images, données compressées, documents word...). Si on ajoute un tel fichier dans le dépôt alors à chaque modification, git stockera une nouvelle copie complète (au lieu de stocker uniquement les lignes qui ont changé), ce qui est inefficace.

D'autre part, il est inutile de versionner les fichiers autogénérés (créés automatiquement). Par exemple, si on compile le code LaTeX de notre projet...

... des fichiers intermédiaires sont créés et apparaissent lors des git status :

Pour les ignorer, il suffit d'ajouter un fichier .gitignore et d'y indiquer les fichiers à ignorer.

Ainsi, il n'apparaissent plus lors des git status.

Il est de pratique courante d'ajouter le .gitignore au dépôt, ainsi qu'un fichier README.md qui servira de page d'accueil (au format markdown).

Renommer et supprimer des fichiers

La commande git mv permet de renommer un fichier versionné. Il ne faut pas utiliser la commande système (mv) car dans ce cas git ne saura pas qu'il faut renommer le fichier (il pensera que le fichier manque et essaiera de le recréer).

De même, la commande git rm permet de supprimer un fichier versionné.

Afficher l'historique des commits

Faisons d'abord une modification "commitée" puis une autre non commitée.

La commande git log permet d'afficher l'historique des commits.

On peut également le voir avec un client graphique comme gitg.

Le "unstaged" correspond aux modifications courantes non commitées.

Supprimer les modifications courantes

La commande git checkout -- . supprime les modifications courantes. Le dépôt revient alors dans l'état du dernier commit (master).

Revenir à un commit précédent (sans suppression)

La commande git checkout 7b3... permet de revenir au commit "7b3...". On passe ainsi dans un mode "détaché" (HEAD ne pointe plus sur un commit terminal).

Au lieu d'utiliser le numéro de commit, on peut également utiliser les étiquettes : par exemple git checkout master pour aller au dernier commit principal ou git checkout HEAD~1 pour aller au commit précédent le commit courant.

Marquer un commit

La commande git tag permet de nommer des commits pour, par exemple, indiquer une version ou pour pouvoir revenir plus facilement à un commit particulier.

Supprimer des commits précédents

La commande git reset 073... revient au commit "073..." et annule tous les commits suivant (jusqu'à l'ancien master). Les modifications correspondant à ces commits sont regroupées dans l'état courant, non commité.

Autre possibilité : la commande git reset --hard 073... revient au commit "073..." et annule tous les commits suivant en supprimant les modifications correspondantes.

Résumé et méthode de travail

Résumé des commandes git précédentes :

---|---| git init | initialise le dossier courant (nouveau dépôt git) | git status | affiche l'état courant des fichiers | git add <fichiers> | demande à git de versionner des fichiers | git commit -a | valide toutes les modifications courantes | git mv <nom1> <nom2> | renomme des fichiers versionnés | git rm <fichiers> | supprime des fichiers versionnés | git log | affiche la liste des commits | git checkout -- . | supprime les modifications courantes (revient au commit)| git checkout <commit/etiquette> | revient à un commit sans rien supprimer | git tag | affiche la liste des étiquettes | git tag <etiquette> | crée une nouvelle étiquette | git reset <commit> | supprime des commits et regroupe les modifications correspondantes dans l'état courant| git reset --hard <commit> | supprime des commits ainsi que les modifications correspondantes|

Quelques conseils de méthode de travail :

  • privilégiez les petits dépôts, correspondant à différents travaux, plutôt qu'un gros dépôt regroupant tous vos travaux de l'année
  • faites des commits réguliers et correspondant aux petites tâches successives
  • évitez de commiter un projet cassé (par exemple, du code qui ne compile pas)
  • ne versionnez pas les fichiers auto-générés

Exercice

  • créez un nouveau dépôt local, ajoutez des fichiers et faites quelques commits; affichez l'état du dépôt à chaque étape
  • renommez et supprimez quelques fichiers
  • affichez l'historique des commits et revenez dans un état précédent du dépot
  • ajoutez une étiquette à un ancien commit et vérifiez que vous la voyez dans l'historique des commits ou avec un client git graphique
  • testez les suppressions de commits

Retour au début de la page

Retour à la page d'accueil

Dernière mise à jour : 2016-03-05