title: "Tutoriel git" output:
toc: true
git est conçu pour manipuler principalement des fichiers au format texte (code source, code latex, fichier CSV...). Il permet notamment :
Un "projet git" contient l'historique de toutes les modifications de chaque fichier. On appelle "commit" un état sauvegardé de ces modifications (une version du projet en quelque sorte).
Généralement, on modifie le projet à partir de la version précédente et ansi de suite; ce qui correspond à une succession de commits :
Mais on peut également effectuer des modifications en parallèles. On appelle ça des branches :
On peut ensuite rassembler ces modifications en fusionnant les branches :
On appelle dépôt l'ensemble des fichiers de notre "projet git", avec l'historique des commits.
Un dépôt peut être dupliqué sur différentes machines, pour synchroniser les données ou pour travailler en équipe.
Dans l'ancien temps des années 2000, on avait un dépôt principal distant que l'on synchronisait ou modifiait via des copies locales partielles (subversion, CVS...) :
Aujourd'hui, on utilise plutôt un système de dépôts décentralisés (git, mercurial...). Avec ce système, tous les dépôts sont identiques et peuvent se synchroniser entre eux :
Généralement, on garde tout de même un dépôt sur un serveur distant accessible en permanence (serveur gogs, github...).
Pour utiliser git, il vous faut une connexion internet et un client git.
La plupart des systèmes Linux modernes propose le client git dans leur système de paquets. Par exemple, sur les Linux basés Debian, il suffit de lancer la commande console :
sudo apt-get install git
Il existe également des clients graphiques : gitg, giggle, qgit, gitk, git-gui...
Télécharger et installer le client git pour Mac.
Télécharger et installer le client git pour Windows.
Après avoir installé le client git, il faut configurer le nom et l'adresse e-mail de l'utilisateur (à faire une seule). Par exemple, en tapant les commandes consoles :
$ git config --global user.name "John Doe"
$ git config --global user.email johndoe@example.com
On peut également configurer l'éditeur de texte et le proxy que le client git doit utiliser. Par exemple, en tapant les commandes consoles :
$ git config --global core.editor emacs
$ git config --global http.proxy http://user:pass@proxyhost:proxyport
ou alors en ajoutant des variables d'environnement (par exemple, dans le
.bashrc
):
export EDITOR=emacs
export http_proxy=http://user:pass@proxyhost:proxyport
Aide générale sur git :
$ git help
Aide sur une commande git :
$ git help <commande git>
Voir également la section références.
Installez et configurez le client git sur votre machine.
TODO
$ git init
Dépôt Git vide initialisé dans /home/dehos/tmp/mon_PhD/.git/
$ git status
Sur la branche master
Validation initiale
rien à valider (créez/copiez des fichiers et utilisez "git add" pour les suivre)
$ git status
Sur la branche master
Validation initiale
Fichiers non suivis:
(utilisez "git add <fichier>..." pour inclure dans ce qui sera validé)
paper.tex
aucune modification ajoutée à la validation mais des fichiers non suivis sont présents (utilisez "git add" pour les suivre)
log
.gitignore conseil sur les fichiers générés et les fichiers de données
TODO
nouveau projet
projet existant
TODO
Dernière mise à jour : 2016-03-05