plex_fr_discord_repo/TUTO_Git_SourceTree.md

10 KiB

Tutoriel pour Git avec SourceTree

Le but de ce tuto est d'expliquer comment faire des commits proprement sur le Gitea de Zoz.

Table des matières

1. Introduction & Installation

Ce petit tuto va utiliser l'application SourceTree : https://www.sourcetreeapp.com/.
J'ai essayé plusieurs clients Git pour windows et macOS, et SourceTree est le seul (parmis ceux essayés) qui offre une interface graphique assez similaire sur ces deux plateformes, et est assez facile d'utilisation. Ce tuto sera donc en partie rédigé pour utiliser cette application.

Ce tuto va donc servir de guide pour contribuer au dépôt avec le moins possible de ligne de commande, voir aucune.

1.1. Prérequis :

  • Vous devrez aussi avoir installé Git pour windows (ou macos) : https://git-scm.com/downloads. Ça pourra être nécessaire si on passe par la ligne de commande.
  • Installez SourceTree.
    Une fois Git installé, et SourceTree installé, allez dans les options de SourceTree pour vérifier que le Git utilisé est bien celui que vous venez d'installer (en externe du point de vue de SourceTree) :

    Tous les autres paramètres étant ceux par défaut.

1.2. Cloner le dépôt avec SourceTree :


Une fois le dépôt cloné, on peut commencer à commiter comme un pro :D. Vous devriez avoir ce genre d'affichage :

1.3. Explications rapides des fonctions de SourceTree utilisées dans ce tuto

Dans ce tuto, nous n'allons pas utiliser beaucoup de fonctionnalités de SourceTree, mais voilà les principales :

  • Bouton Valider : permet d'afficher l'écran de validation du commit que l'on s'apprête à finaliser. On peut, et on doit, laisser un bref message indiquant sommairement ce que contient ce commit (en termes d'ajout, modification, etc...).
    En ligne de commande, ce serait : git commit -m "ma super modif".
  • Bouton Récupérer : C'est le git pull, ça permet de récupérer dans la branche en cours le conteneur d'une branche distante :
  • Bouton Envoyer : C'est le git push, ça permet d'envoyer les modifications locales sur le dépôt distant. En général, je préfère utiliser la case à cocher "Envoyer les modifications vers origin/ma-brancheblabla" à l'étape de validation du commit (voir plus bas).
  • Bouton Rapatrier : Je l'utilise lorsque je suis sur la branche master pour récupérer les données et enlever de SourceTree les branches distantes qui ont été supprimées.
  • Bouton Changer de branche : C'est avec ce bouton que je crée une nouvelle branche depuis la de départ master.

2. Créer une branche de travail mon_pseudo-travail depuis la branche master

2.1. Méthode n°1 : depuis SourceTree

  • Il faut tout d'abord se placer sur la branche master en double cliquant dessus.
  • Ensuite, toujours choisir "Parent de la copie de travail" avant de créer la branche :

On est maintenant prêt à faire nos commit :

2.2. Méthode n°2 : depuis l'interface web de Gitea







Si vous créez votre branche depuis Gitea, il faudra l'importer dans SourceTree.

  • Pour ce faire :

    • soit vous double-cliquez sur la branche distance à rapatrier,
    • soit vous faites un clic droit dessus :
  • Ensuite vous cochez bien la case indiquée, et laissez le nom qui s'affiche pour la branche locale, puis validez par OK :



Une fois la branche créée, vérifiez bien que cette dernière est bien sélectionnée !

3. Envoi du premier commit, et des suivants...

Vous pouvez maintenant créer vos dossiers/fichiers, faire les modifications sur les fichiers/dossiers existants.

Une fois que vous arrivez à une étape clé, ou bien pour être sûr que votre travail soit "sauvegardé" sur le serveur, vous pouvez faire votre 1er commit.

  • Cliquez sur le bouton + :
  • Puis choisissez les élements à indexer :
  • Puis pensez bien à écrire un commentaire et à cocher la case en bas pour que le commit soit envoyé sur le dépôt distant.
    Cette case est l'équivalent d'un git push.

Pour la rédaction de ce tuto, j'ai fait pas mal de commits ^^. Voilà çe que ça donne avec une vue :

On voit même une branche (MilesTEG) que j'ai supprimé en cours de route... (ça rendait trop complexe la gestion des branches).

4. Demande de fusion de notre branche mon_pseudo-travail avec master

Une fois qu'on a fini de travailler sur notre branche, dernier commit fait, ou bien pour soumettre le travail fait à la relecture par les autres membres, on peut faire une demande de fusion.

Je vais illustrer cela maintenant, même si au moment où je fais la capture, le tuto n'est pas entièrement terminé.

  • Pour faire cette demande de fusion, le plus simple est d'aller là aller sur la page web des branches puis de cliquer sur le bouton "Nouvelle demande de fusion" de notre branche (il se peut que ce bouton s'intitule juste "Demande de fusion"):

    (On voit que j'ai 12 commits dans cette branche, je ne sais pas à quoi correspond le 0...)

  • Ensuite, on vérifie bien qu'on a la bonne branche de destination master (à gauche) et notre branche source mon_pseudo-travail :

  • Étape suivante : (lisez le texte dans la capture)


Si vous faites encore des commits avant de fusionner, vous les verrez apparaître à la suite des précédents et des modifications apportées à la demande de fusion (message, ajout d'étiquette, etc...):

  • Dernière étape : Sélectionnez quelques relecteurs dans la liste

  • Si jamais vous avez cliquez sur WIP, quand vous aurez terminé vos modifications, il faudra cliquer sur le bouton "Enlever le préfixe WIP" pour fusionner votre branche avec master.

Il ne vous reste plus qu'à attendre la validation par un relecteur, et qu'il fusionne votre branche avec la branche master.

À l'issue de cette fusion, votre branche sera supprimée. Si vous vouliez continuer à travailler dessus, mettez-là en statut WIP, en postant un message indiquant votre intention.

✏️ Note : Si jamais vous envoyiez un nouveau commit (ou plusieurs) après que la fusion ait été faite, mais avant que la branche soit supprimée, il faudra refaire une demande de fusion.


Ça y est, c'est la fin du tutoriel :D

Merci d'avoir tout lu et tout suivi ;)

Votre avis, conseils et idées d'amélioration sont les bienvenues. Vous pouvez faire ue branche et commiter dessus ^^ ou bien me demander directement sur Discord.