User Tools

Site Tools


2018_2019:s2:td:git

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
Next revision Both sides next revision
2018_2019:s2:td:git [2019/03/16 18:30]
blay [Introduction à GIT]
2018_2019:s2:td:git [2019/03/16 21:03]
blay [Définition de l'environnement]
Line 1: Line 1:
 ====== Introduction à GIT ====== ====== Introduction à GIT ======
 +
 +===== Définition de l'​environnement =====
  
   - Adresse de gitlab :  https://​git-iutinfo.unice.fr/​   - Adresse de gitlab :  https://​git-iutinfo.unice.fr/​
   - Vous désactivez la vérification SSL <​code>​ git config --global http.sslVerify false </​code>​   - Vous désactivez la vérification SSL <​code>​ git config --global http.sslVerify false </​code>​
-  - Si vous n'avez pas encore créé de dépôt, suivez ​les instructions du dépôt+  - Suivez ​les instructions du dépôt ​(si vous ne les voyez plus : [[2018_2019:​s2:​td:​git:​depot|2018_2019:​s2:​td:​git:​depot]]
-  - [[2018_2019:​s2:​td:​git:​depot|2018_2019:​s2:​td:​git:​depot]] +
-  - Pour savoir qui commite : <​code>​ +
-git config --global user.name "​myusername"​ +
-git config --global user.email "​monadresse@unice.fr"​ +
-</​code>​+
  
 Pour les étudiants qui utilisent leur ordi perso, il est possible que vous ayez besoin de, ouvrir un Git CMD en administrateur,​ puis taper la commande suivante:  ​ Pour les étudiants qui utilisent leur ordi perso, il est possible que vous ayez besoin de, ouvrir un Git CMD en administrateur,​ puis taper la commande suivante:  ​
 <​code>​ git config --system --unset credential.helper</​code>​ <​code>​ git config --system --unset credential.helper</​code>​
  
 +===== Git comme un historique des modifications =====
 +Chaque étudiant du groupe a une tâche particulière,​ chacun choisit sa couleur : Blanc, Bleu, Vert, Jaune, Rouge
  
 +   - Créer un fichier contenant une classe vice en fonction de votre couleur (public class X {})
 +       * Blanc : Game (Partie)
 +       * Bleu : Player (Joueur)
 +       * Vert : Move (Coup)
 +       * Jaune : IA 
 +       * Rouge : GameManager
 +       * Evidemment dans ce qui suit X est le nom de class créée par chacun.
 +  - Comment interprétez-vous le résultat de la commande suivante <​code>​ git status </​code> ​
 +  - Ajoutez votre fichier ''​X.java''​ comme git vous l'a dit : <​code>​ git add X.java</​code> ​
 +  - Réinterprétez le résultat de la commande ''​git status''​.
 +  - Le fichier ''​X.txt''​ est maintenant prêt à être versionné. <​code>​ git commit -m "​construction de la class X" </​code>​ **ou** <​code>​ git commit </​code>​ ((Un éditeur s'​ouvre qui dépend de votre configuration. Si c'est VIM pour sortir ":​q"​. Si l'​éditeur ne vous convient pas, vous pouvez le configurer par exemple <​code>​ git config --global core.editor emacs </​code>​)) Quel message avez-vous en retour?
 +  - Que donne la commande ''​git status''​ ? ​
 +  - Apportez quelques modifications au fichier ''​X.java''​. ​
 +       * Blanc : ajouter l'​attribut ''​Date date''​ avec aussi ''​import java.util.Date;''​ (Game) ​
 +       * Bleu : ajouter l'​attribut String pseudo ​ (Player) ​
 +       * Vert : ajouter l'​attribut LocalTime time; (Move) ((<​code>​import java.time.LocalTime;​
 +public class Move {
 +  private LocalTime time;
 +}</​code>​))
 +       * Jaune : ajouter l'​attribut int level  (IA)
 +       * Rouge : ajouter la methode export (GameManager) ((<​code>​import java.util.Date;​
 +public class Game {
 + private Date date;
 +}</​code>​))
 +  - Essayez de commiter ces modifications. Que se passe-t-il ?​ En vous aidant de la documentation accessible en tapant ''​git help commit'',​ versionnez ces modifications (avec un message décrivant le changement) (( Au lieu d'un git add suivi d'un git commit vous pouvez préférer <​code>​ git commit -a -m "ajout de l'​attribut Y ..."</​code>​ ))
 +  - Affichez l’historique des modifications du dépôt. <​code>​ git log </​code> ​
 +  - Et pour voir les modifications apportées par le dernier commit <​code>​ git log -p  -1 </​code>​ et savoir qui fait quoi <​code>​ git log --stat </​code>​ ou <​code>​ git log --pretty=format:"​%h - %an, %ar : %s"</​code>​ **etc.**
 +  - En utilisant ''​git diff''​ ,​ visualisez les modifications effectuées entre le premier commit et le second commit. Par exemple <​code>​ git diff 71cfcd6 0c24491 </​code>​ Attention l'​ordre des commits modifie le résultat (un- devient un +).
 +  - Modifiez plusieurs fois votre fichier par exemple en ajoutant des commentaires afin d’en avoir plusieurs versions. ​
 +  - Le dernier commentaire ajouté ne vous plait finalement pas. Il existe deux manières de revenir à une version antérieure :​ de manière temporaire ou définitive.
 +  - Exécuter ''​git log''​ et récupérez le hash (HASH) du commit où vous souhaitez revenir en arrière.
 +         - Pour revenir en arrière de manière temporaire, exécutez <​code>​ git checkout HASH</​code>​
 +              -  Vérifiez que votre fichier Menu.txt est dans son état antérieur. ​
 +               - Revenez au dernier commit (HEAD) en exécutant <​code>​ git checkout master</​code>​
 +         - Pour revenir en arrière de manière définitive,​ et donc supprimer tout ce que vous avez fait depuis ce moment : <​code>​ git reset --hard HASH </​code>​
 +               - Dans ''​git log'',​ vérifiez que tout ce que vous aviez effectué depuis ce commit a été effacé. ​
  
-Git global setup +
-git config --global user.name "BLAY Mireille"​ +
-git config --global user.email "​mireille.blay@unice.fr"​ +
- +
-Create a new repository +
-git clone https://​git-iutinfo.unice.fr/​blay/​ajeter.git +
-cd ajeter +
-touch README.md +
-git add README.md +
-git commit -m "add README"​ +
-git push -u origin master +
- +
-Existing folder +
-cd existing_folder +
-git init +
-git remote add origin https://​git-iutinfo.unice.fr/​blay/​ajeter.git +
-git add . +
-git commit -m "​Initial commit"​ +
-git push -u origin master +
- +
-Existing Git repository +
-cd existing_repo +
-git remote rename origin old-origin +
-git remote add origin https://​git-iutinfo.unice.fr/​blay/​ajeter.git +
-git push -u origin --all +
-git push -u origin --tags +
  
  
2018_2019/s2/td/git.txt · Last modified: 2019/03/26 16:18 by blay