Skip to content

Instantly share code, notes, and snippets.

@UnderXirox
Forked from aquelito/git-command.md
Created January 19, 2017 19:37
Show Gist options
  • Save UnderXirox/e738e8ed69f1aa51600ff70e4d9cc0a8 to your computer and use it in GitHub Desktop.
Save UnderXirox/e738e8ed69f1aa51600ff70e4d9cc0a8 to your computer and use it in GitHub Desktop.
GIT - Ligne de commande principale

Github

Configuration

Identity Name

$ git config --global user.name "aquelito"

Identity Email

$ git config --global user.email "[email protected]"

Editor Tool

$ git config --global core.editor subl

Diff Tool

$ git config --global merge.tool filemerge

Liste des globals

$ git config --list

Principales commandes

Status des fichiers

$ git status

Lister les branchs

$ git branch

*sur la branche courante.

Créer une branch

$ git branch nom_de_ma_branch

Changer de branch

$ git checkout nom_de_ma_branch

Premier commit

$ git add .
$ git commit - m "initial commit"

Commit suivant

$ git add chemin_vers_mon_fichier
$ git commit -m "message du commit"

Annuler le dernier commit et modifs

$ git reset --hard md5_commit
$ git push --force

Mettre à jour le dépôt local

$ git pull

Envoyer ses commits vers le dépôt distant

$ git push

Supprimer un fichier du répertoire de travail et de l'index

$ git rm nom_du_fichier

Supprimer un fichier de l'index

$ git rmg --cached nom_du_fichier

Diff

Affiche la différence entre le contenu du dernier commit et celui du répertoire de travail. Cela correspond à ce qui serait commité par git commit -a.

$ git diff HEAD

Affiche la différence entre le contenu pointé par A et celui pointé par B.

$ git diff A B

Diff entre un dossier présent sur deux branches

$ git diff master..MA_BRANCH chemin/vers/mon_dossier

Log

$ git log
# Affiche X derniers commits
$ git log -n X
# Affiche un ensemble de commits par date
$ git log --since=date --until=date

Représentation de l’historique à partir de HEAD (commit / branch)

$ git log --oneline --graph --decorate

Représentation de l’historique à partir d'un fichier (commit / branch)

$ git log --oneline --graph --decorate nom_du_fichier

Annuler commits (soft)

Seul le commit est retiré de Git ; vos fichiers, eux, restent modifiés. Vous pouvez alors à nouveau changer vos fichiers si besoin est et refaire un commit.

Annuler le dernier commit

$ git reset HEAD^

Pour indiquer à quel commit on souhaite revenir, il existe plusieurs notations :

  • HEAD : dernier commit ;
  • HEAD^ : avant-dernier commit ;
  • HEAD^^ : avant-avant-dernier commit ;
  • HEAD~2 : avant-avant-dernier commit (notation équivalente) ;
  • d6d98923868578a7f38dea79833b56d0326fcba1 : indique un numéro de commit précis ;

Annuler commits (hard)

Si vous voulez annuler votre dernier commit et les changements effectués dans les fichiers, il faut faire un reset hard. Cela annulera sans confirmation tout votre travail !

Annuler les commits et perdre tous les changements

$ git reset --hard HEAD^

Annuler les modifications d’un fichier avant un commit

Si vous avez modifié plusieurs fichiers mais que vous n’avez pas encore envoyé le commit et que vous voulez restaurer un fichier tel qu’il était au dernier commit :

$ git checkout nom_du_fichier

Annuler/Supprimer un fichier avant un commit

Supposer que vous venez d’ajouter un fichier à Git avec git add et que vous vous apprêtez à le « commiter ». Cependant, vous vous rendez compte que ce fichier est une mauvaise idée et vous voulez annuler votre git add.

Il est possible de retirer un fichier qui avait été ajouté pour être « commité » en procédant comme suit :

$ git reset HEAD -- nom_du_fichier_a_supprimer
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment