Files
Master-TI-2/Tutoriels/Git/Base_git.md
T
2024-09-06 07:22:37 +02:00

76 lines
1.9 KiB
Markdown

# Les bases du git
## Créer un repo git depuis gitLab
Depuis gitLab, créez un nouveau dépôt git puis clonez le sur votre machine
```bash
# Récupérer le projet en local
git clone https://git.univ-pau.fr/username/nom_depot
# Créer la branche principale
git branch main
# Ajouter les accès distants
git remote add origin mais
```
## Créer une branche
```bash
git branch nom_de_la_nouvelle_branche
```
## Se positionner sur une branche ou un commit
Supposons l'arborescence git suivante:
![arbo git initial](images/git_initial.png)
### Positionner la tête sur la branche souhaitée
```bash
git checkout nom_branche
```
![checkout branch](images/checkout_branch.png)
### Positionner la tête sur le commit précédent
```bash
git checkout HEAD-1
```
![HEAD-1](images/head-1.png)
### Positionner la tête sur un commit précis
```bash
git checkout c1
```
![checkout commit](images/checkout_c2.png)
## Remonter une sous branche sur la tête de la branche parente
```bash
# Se positionner sur la branche à relever (ex: branche_secondaire)
git checkout branche_secondaire
# Effectuer un rebasesur la branche souhaité (ex: branche principale)
git rebase branche_principale
```
![rebase](images/rebase.png)
___Remarque___ : Rebase une branche peut apporter son lot de problèmes. En effet, si vous avez modifier les mêmes sections de code sur les mêmes fichiers sur les deux branches il va falloir réparer toutes les conflits entre temps.
___Astuce___ : N'hesitez pas à demander de l'aide ;)
## Merge une branche
```bash
# Se positionner sur la branche à merge
git checkout branche_secondaire
# Effectuer un merge
git merge branche_principale --rebase
```
![merge](images/merge.png)
___Remarque___ : Par sécurité, il vaut mieux toujours faire une "merge request" directement sur gitLab (ou gitHub) au lieu de merge directement. Cela permet d'ajouter des "reviewer" qui permettront la merge. Vaut mieux avoir plusieurs fautifs qu'un seul ;)