[add] tutoriels git

This commit is contained in:
kmitresse
2024-09-03 18:34:15 +02:00
parent bbf22daa79
commit 52479bc7be
8 changed files with 154 additions and 0 deletions
+76
View File
@@ -0,0 +1,76 @@
# 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](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](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 ;)
+78
View File
@@ -0,0 +1,78 @@
# Transferer un sous dossier d'un repo git vers un repo github
Ce tuto permet de récuperer un projet sur une branche et de transferer l'integraliter des commits sur le projet
### ___Attention:___ Si vous n'êtes pas sur de vos manipulation, faite un fork du repo initial et effectuez les démarches depuis ce fork afin de ne pas altérer le git. Pensez à supprimer le fork par la suite si vous n'en avez plus besoin
#### Etape 1 : Installer git-filter
```bash
pip install git filter
```
#### Etape 2 : Se placer sur le repo et sur la branche ou se trouve le projet
```bash
# Si besoin cloner le repo git
# Depuis ssh (si vous avez renseigné une clé ssh sur gitlab)
git clone git@git.univ-pau.fr:kmitresse/Master-TI-2.git
# Depuis https
git clone https://git.univ-pau.fr/kmitresse/Master-TI-2.git
# Se placer dans le repo
cd Master-TI-2
# Se placer sur la bonne branche
git checkout nom_de_la_branche_du_projet
```
#### Etape 3 : Isoler les commits concernant le projet dans l'historique des commit
```bash
git filter-repo --path votre/sous_dossier --force
# Vérifier la liste commits isolés si besoin
git log --oneline
```
! Ne pas fermer cette fenêtre
#### Etape 4 : Préparer le repo git depuis gitHub
Sur github, créer un nouveau projet vide et sans readMe (!très important).
Générer ensuite un token :
- Aller dans setting -> Developper settings -> Personnal access Token
- Cliquer sur générer un nouveau Token
- Donner un nom à ce token et une date d'expiration de ce token
- Cliquer sur générer Token
Un token devrait maintenant apparaître. Attention, il n'apparaitra qu'une seule fois, si vous souhaitez le réutiliser, conservez le dans une note protégée car sinon vous devrez en regénerer un.
Pour les besoin du tuto nous appelerons le token: TOKEN
#### Transferer le projet
Revenir sur votre console bash
```bash
# Ajouter le nouveau dépôt gitHub comme dépôt distant
# Avec ssh (si vous avez renseigné une clé ssh sur github)
git remote add origin git@github:nom_utilisateur_github/nom_nouveau_depot.git
# Avec https
git remote add origin https://github.com/nom_utilisateur/nom_nouveau_depot.git
# Pousser les commits
git push -u
```
A ce stade, il est demander de renseigner ses identifiants de connexion gitHub
- Username : Votre nom d'utilisateur gitHub
- Password : TOKEN
#### Conclusion
Normalement vous devriez avoir votre projet sur github sans avoir altéré le repo initial. Il vous suffira ensuite de cloner votre nouveau repo github afin de refacto les dossiers. En effet votre projet sur github devrait suivre l'arborescence originale
Nom_UE/Projet/*
Vous pouvez ainsi refacto pour mettre le contenu de * à la racine du projet
Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 41 KiB