276 Commits

Author SHA1 Message Date
2a39b88df1 Merge branch 'master' of https://forge.cadoles.com/Cadoles/formations 2019-03-25 13:23:10 +01:00
42e475449d Mise à jour des listes de modules disponibles 2019-03-19 16:01:32 +01:00
a699b7551d ajout cours agile cesi 2019-03-15 09:35:55 +01:00
2a06cee004 CESI: Ajout fiche module Hébergement Web + feuille de notation 2019-02-06 14:13:21 +01:00
a3bce17093 Ajout ressources formation CESI: Hébergement Web 2019-02-06 14:10:04 +01:00
b48ccf2bb2 Mise à jour du programme amon/sphynx 2019-02-06 11:36:52 +01:00
18647029a7 ajouter l'option shell-escape à xelatex pour les exercices TC2 2018-12-20 15:24:13 +01:00
a970852f3b CESI - Exo Microbloggr Solution - Création de statuts fonctionnelle 2018-11-28 16:56:54 +01:00
eaa659f3c6 CESI - Exo Microbloggr Solution - Authentification fonctionnelle 2018-11-28 14:47:09 +01:00
68ccdca3a4 Intro Big Data: mise à jour slides + données d'exemple graphe 2018-09-27 07:23:06 +02:00
89ba44063d Architecture N Tiers: ajout QCM 2018-09-27 07:20:36 +02:00
4c92c99472 some cleaning 2018-09-13 10:09:32 +02:00
a58dc496c4 CESI: Intro Big Data - ajout exercice bdd clé/valeur et graphe 2018-09-05 21:54:11 +02:00
8f84189ed5 CESI: Intro Big Data - ajout tuile + exercice BDD orientée graphe 2018-09-05 07:30:09 +02:00
a29c349d75 CESI: Intro Big Data, biblio + environnement démo Hadoop 2018-08-24 17:17:35 +02:00
37fccd7d8c algo et data science 2018-08-24 14:09:25 +02:00
ff92e072df CESI: Intro Big Data, base bibliographie 2018-08-22 11:26:45 +02:00
2db270359c python2 -> python subfolder 2018-08-21 10:26:27 +02:00
ee81eaad1b en and fr python3 courses 2018-08-21 10:25:44 +02:00
8c6997b27d ancien cours python -> python2 2018-08-20 21:02:38 +02:00
8ab75d1eac algorithmique : api et paramètres 2018-08-20 21:01:58 +02:00
9220531442 CESI: DevOps, mise à jour des slides 2018-06-28 06:50:04 +02:00
1ead473830 CESI: Métiers DevOps, base slides 2018-06-27 16:09:39 +02:00
bee347f833 DIIAGE: session 23/03/2018 2018-03-23 11:51:43 +01:00
2aea564151 Logomotion: React+Redux, corrections typo 2018-03-22 18:08:34 +01:00
1baa61d2e8 Logomotion: Qualification 2018-03-20 14:03:21 +01:00
74a2e26f18 Logomotion: React + Redux 2018-03-12 21:20:13 +01:00
7c0f21ae7f CESI: Architectures N Tiers, ajout mini projet 'Alfred' 2018-03-05 19:07:27 +01:00
5f537a3a77 DIIAGE: ajout derniers cours 2018-03-02 12:03:52 +01:00
5255503103 Logomotion: Base des slides pour la formation sur la qualification 2018-02-20 09:03:38 +01:00
e4cad32252 CESI: Sécurité entreprise, maquette + support OK 2018-02-04 18:27:46 +01:00
56066ac24f CESI: Sécurité des entreprises, infrastructure Vagrant avec supervision Prometheus 2018-02-04 15:55:09 +01:00
85d1a97452 CESI: présentation + maquette Vagrant Sécurité entreprise 2018-02-01 17:35:41 +01:00
482bc0e960 Logomotion: maj formation Sécurité Web 2018-01-25 22:10:30 +01:00
0fe8dd7112 Logomotion: Sécurité Web, sécurisation du serveur GNU/Linux 2018-01-23 22:46:57 +01:00
171b1e512c Logomotion: sécurité web, ajout exercice métrologie 2018-01-22 22:33:49 +01:00
16df9d12da CESI: Architecture N Tiers, exemple microservices 2018-01-22 22:14:30 +01:00
7cefd73d13 Logomotion: Sécurité Web 2018-01-22 22:13:04 +01:00
03b9ed5f1e DIIAGE: session 19/01/2018 2018-01-19 11:50:12 +01:00
0eb9d2e1e1 DIIAGE: Prépa session 19/01/2018 2018-01-17 22:58:53 +01:00
608c203acd CESI: architectures n tiers 2018-01-14 21:13:12 +01:00
703ca7d4fb CESI: Architecture N tiers 2018-01-13 18:02:29 +01:00
c8caed6efc CESI: Architecture N tiers, exercice 2018-01-13 16:53:31 +01:00
e041aa9b9f CESI: Architecture N Tiers 2018-01-13 15:28:05 +01:00
ea0439f8ab CESI: mise à jour fiche de préparation Architecture N tiers 2018-01-10 22:42:48 +01:00
f1d44dc9ed Logomotion: mise à jour introduction framework javascript 2018-01-09 22:52:41 +01:00
3a14479bc1 Logomotion: tour d'horizon Javascript, base EmberJS 2018-01-08 23:03:36 +01:00
6eaec99f06 Logomotion: Introduction Javascript 2018-01-08 17:35:19 +01:00
8d4a57ed9b Logomotion: slides Symfony3 seconde journée 2017-12-27 16:12:22 +01:00
63cb07d03e Logomotion: suites des slides Symfony3 2017-12-26 17:38:01 +01:00
cdc80c6a5f CESI: réorganisation de l'arborescence 2017-12-26 10:46:56 +01:00
fc85a3a7f1 DIIAGE: réorganisation des questions 2017-12-26 10:46:06 +01:00
25d1f582a8 DIIAGE: TP sécurité des applicaiton web & métrologie appliquée à la sécurité 2017-12-22 10:16:12 +01:00
4d76474d99 Logomotion: Volet sécurité des applications Web, métrologie / prometheus 2017-12-21 16:55:59 +01:00
03faa7a663 Diiage: préparation QCM évaluation 22/12/2017 2017-12-20 12:00:44 +01:00
a130fab2f8 Remise à niveau Symfony3: slides 2017-12-14 22:14:18 +01:00
ccb80c82e7 Symfony3: slides + revue planning journée 1 2017-12-14 20:05:25 +01:00
cb42e8734b Remise à niveau Symfony3: slides + planning 2017-12-14 17:32:17 +01:00
729f2c318a CESI: Mise à jour slides/planning "Sécurité en entreprise" 2017-12-12 11:35:12 +01:00
3050355eb5 CESI: Mise à jour programme formation "Sécurité en entreprise" 2017-12-11 17:17:43 +01:00
0ed669f1ae Ajout des fichiers de lock LibreOffice à la liste des ignorés 2017-12-11 15:48:06 +01:00
0c3263693a CESII: Mise à jour slides, planning et notes 2017-12-11 15:46:52 +01:00
f357f5ac72 CESII: Slides formation sécurité entreprise 2017-12-11 14:06:38 +01:00
ee8cfea049 DIIAGE: mise à jour sujet TP 2017-12-08 12:03:24 +01:00
8085490457 DIIAGE: Préparation session 20171208 2017-12-08 11:38:41 +01:00
e3e4b6291f Ajout rendus TP 2017-12-08 11:37:44 +01:00
bd7082e887 Préparation cours DIIAGE 08/12/2017 2017-12-06 22:04:40 +01:00
00f9d125d1 Création de fiches d'exemple 2017-11-17 12:07:08 +01:00
f383613cbd Ajout supports formation DIIAGE (DEV & RES 3) 2017-11-16 16:27:53 +01:00
affa70b31c algo avancée 2017-10-24 17:13:41 +02:00
63c4a7e2fc exercices de programmation raisonnée 2017-10-23 18:05:32 +02:00
05e68b4d5e algo avancée 2017-10-17 16:23:38 +02:00
2edd0ea2f1 algo : problèmes NP complets 2017-10-17 14:18:26 +02:00
9ad29e7541 méthodes de tri rapide en python 2017-10-16 17:16:19 +02:00
75bb842bb6 support de cours algo avancée - correction unicode 2017-10-16 16:27:16 +02:00
6a50f7f261 support de cours algo avancée 2017-10-16 15:35:34 +02:00
dd24407b76 contrainte de type par signature 2017-10-12 18:21:33 +02:00
2214b33090 corrections cours poo 2017-10-05 09:18:23 +02:00
b73e7c85ff premiere version stable du cours de poo 2017-10-02 09:11:10 +02:00
86e9646de9 Correction du public pour les méthodes AGile 2017-09-29 16:05:30 +02:00
adde21ff9d Merge branch 'master' of https://forge.cadoles.com/Cadoles/formations 2017-09-29 16:02:54 +02:00
99ff34a750 relecture de qualification 2017-09-29 15:42:15 +02:00
a4f78eb243 relecture des méthodes agiles 2017-09-29 15:38:04 +02:00
2d247ba285 relecture de la messagerie électronique 2017-09-29 15:33:03 +02:00
52f602e8bf relecture 2017-09-29 15:27:14 +02:00
512951e208 relecture 2017-09-29 15:23:47 +02:00
b607c5717a relecture 2017-09-29 15:19:14 +02:00
c92060f849 relecture 2017-09-29 15:12:55 +02:00
b3b2cde6a1 relecture 2017-09-29 15:06:13 +02:00
bfe90bfcac Mise à jour durée 2017-09-29 14:55:42 +02:00
1b6b43878b Coquillesé 2017-09-29 14:27:49 +02:00
d499847408 Programme de formation Logomotion - version LaTeX 2017-09-29 14:12:15 +02:00
5193436497 Retour de inc dans le dépôt 2017-09-29 13:22:52 +02:00
354a2bbb40 Merge branch 'master' of https://forge.cadoles.com/Cadoles/formations 2017-09-29 13:20:11 +02:00
af6e948714 Relecture - Corrections 2017-09-29 13:19:50 +02:00
c88cd4938a Retour du style dans le dépôt 2017-09-29 13:16:31 +02:00
12b0b87911 Mise à jour du tire de la formation 2017-09-29 12:58:36 +02:00
e8bd5fbff7 Mise à jour du tire de la formation 2017-09-29 12:55:13 +02:00
da9fdc71a2 Mise à jour des plans de formation methodes agiles, qualification et smtp-imap 2017-09-29 12:53:34 +02:00
78931654ac Now we can build only one program
./programme.sh my_directory
2017-09-29 12:49:00 +02:00
1eacf73b67 Ajout du programme de qualification 2017-09-29 11:42:47 +02:00
1a75329228 Merge branch 'master' of https://forge.cadoles.com/Cadoles/formations 2017-09-29 11:09:30 +02:00
2a02aec42b Ajout du programme de la formation AGILE 2017-09-29 11:09:12 +02:00
8515e2c8ef Precisions partie symfony 3 2017-09-29 10:29:41 +02:00
789ec739ae Ajout du plan de formation pour Logomotion 2017-09-29 09:40:16 +02:00
cfe5783d6d Ajout du programme pour la formation smtp-imap 2017-09-28 14:02:18 +02:00
1645146d0d modèle objet de python 2017-09-05 09:25:48 +02:00
2ddd3e2c18 méchanismes objets 2017-09-04 17:33:56 +02:00
075a54ecf1 debut du cours de poo 2017-09-04 14:54:33 +02:00
a0040a3b00 tronc commun algo/algo approfondie 2017-08-29 15:42:31 +02:00
898dc77569 tronc commun 2017-08-28 17:52:56 +02:00
3bf7596972 menage 2017-08-28 17:37:01 +02:00
dc02e78fff mise en place des cours algo + poo 2017-08-28 17:36:36 +02:00
2843f25795 mise en place des cours poo et algo approfondie 2017-08-21 10:44:20 +02:00
870a4d7743 alog : rappels de cybernétique 2017-08-21 09:32:10 +02:00
abba666231 notes pour amélioration du cours 2017-06-21 10:53:35 +02:00
2ecd65ce3d corrections du cours après la présentation 2017-06-21 10:52:29 +02:00
78cc7f12eb typo 2017-06-09 10:15:08 +02:00
4c53916b12 exercices de travaux pratiques 2017-06-09 09:59:42 +02:00
45f3836f87 premiers sujets de tp 2017-05-29 14:29:23 +02:00
8afd3606f7 logos 2017-05-23 11:16:12 +02:00
357c2ed0a0 diaporama algorithmique 2017-05-23 09:32:17 +02:00
1689ac7145 présentation beamer 2017-05-22 17:54:40 +02:00
fc6208b99c template de présentation beamer 2017-05-19 11:17:58 +02:00
26cc76dcc1 exercices de manipulation des structures de données 2017-05-14 18:17:14 +02:00
5728bb1834 exercices supplémentaires 2017-05-12 11:55:30 +02:00
2840b2627b ajout du diaporama 2017-05-09 09:37:09 +02:00
31835587a6 suprression des warning au build 2017-05-03 09:26:24 +02:00
fd2b6469bf suppression des derniers fixme 2017-05-03 09:21:28 +02:00
ffcd62cd50 cours : premiere version 2017-04-30 08:59:55 +02:00
670c1fe535 algo programmation structurée 2017-04-30 08:44:43 +02:00
48524d751a langage de modules 2017-04-29 23:14:45 +02:00
81545ae4d3 algorithme module python 2017-04-29 20:24:46 +02:00
63a96dbbc3 exercices (maximum d'une liste) 2017-04-28 11:12:19 +02:00
b0f56186f5 modulatié et programmation raisonnée 2017-04-27 16:40:01 +02:00
b49b0690b9 exercices sur les structures de données de base (2) 2017-04-27 14:46:31 +02:00
c8ab39a19e exercices sur les structures de données de base 2017-04-27 14:15:18 +02:00
24cd7ca9c3 exos d'algo 2017-04-27 12:05:13 +02:00
13ca1532ce exercices sur les structures de controle de base 2017-04-27 11:55:24 +02:00
ae3cdd92b3 exercices sur les variables 2017-04-26 11:48:32 +02:00
1470b93a63 exemples d'algorithmes 2017-04-24 15:53:00 +02:00
b634a10b77 Corrections dans l’exercice ircd 2017-04-21 11:36:32 +02:00
32376db319 exemples d'algorithmes sur des structures de données simples 2017-04-21 10:50:53 +02:00
9cdfc16cc5 structures de données (list + dico) 2017-04-20 14:29:38 +02:00
4e29983800 algorithme vague 2017-04-18 21:53:35 +02:00
cf1b3ac498 portée d'une variable 2017-04-13 17:36:25 +02:00
8d16681688 structures de données 2017-04-13 17:08:27 +02:00
12b1a888c6 organisation des exercices 2017-04-13 16:08:30 +02:00
15fd0fa136 programmation modulaire 2017-04-13 10:50:18 +02:00
eb3daeae4e suppresion des Statex des algo de style impératif 2017-04-12 10:22:44 +02:00
2786706b0f ajout d'aperçu des types d'algorithmes 2017-04-11 16:40:26 +02:00
5c9ca22877 utilisation de l'extension ifconfig pour les exercices et les corrections 2017-04-11 14:24:15 +02:00
b37051c78d Merge branch 'master' of ssh://forge.cadoles.com:4242/cadoles/formations 2017-04-11 11:42:53 +02:00
26c756a914 reorganisation du cours 2017-04-11 11:18:17 +02:00
9fb80c6b48 reorganisation du cours 2017-04-10 17:47:40 +02:00
44c153b95c reorganisation (ordonnancement) du cours 2017-04-10 12:36:16 +02:00
86dec22113 presentation du cours d'algo 2017-04-10 12:25:40 +02:00
95231a4253 définition des actions d'un programme 2017-04-07 17:22:05 +02:00
0685998e20 présentation du cours et avant propos 2017-04-07 15:28:36 +02:00
fe81743c51 mise à jour pour PSI + raid logiciel (non inclu) 2017-04-07 13:01:55 +02:00
936de04ce4 algorithme factorielle 2017-04-06 16:57:22 +02:00
813a09034a diveres définitions de la programmation 2017-04-06 14:55:36 +02:00
6de57bca95 définition d'une fonction 2017-04-06 10:36:31 +02:00
6ccddf4cc5 ajout des principales structures de contrôles 2017-04-05 10:36:41 +02:00
b5a77f5212 instruction de saut conditionnel 2017-04-04 10:50:18 +02:00
97d5f66bd5 ajout d'un exemple de procedure 2017-04-03 16:47:10 +02:00
f92c758800 Ajout de la notion de fonction 2017-04-03 16:34:36 +02:00
7e048b9f61 correction orthographique 2017-03-27 14:26:44 +02:00
777323f940 exo avec roundcube et non thunderbird 2017-03-27 14:09:39 +02:00
a769e6bbd7 ajout script création user 2017-03-27 12:14:16 +02:00
ce101ea602 mise en page 2017-03-27 11:57:27 +02:00
7cc6c19799 modification exercice et contenu 2017-03-27 11:36:59 +02:00
7fd17bd06e amelioration création utilisateur Mysql 2017-03-27 11:22:50 +02:00
debf07b509 modification de l'exercice pour l'ajout d'application web 2017-03-27 10:30:27 +02:00
8bc107fa71 maj log squid/e2guardian 2017-03-23 20:24:35 +01:00
b8a3e05f02 maj formation amon 2017-03-23 17:47:51 +01:00
047eb2728d réflexions sur l'abstraction algorithmique 2017-03-23 11:23:49 +01:00
3baed6b4ff définition d'un algorithme 2017-03-22 09:13:07 +01:00
b380a69cfa package algorithm 2017-03-21 11:56:53 +01:00
44f083eb1d section algorithme 2017-03-21 09:10:34 +01:00
aea8e036a3 ajout des annexses 2017-03-20 10:22:04 +01:00
fb6c63feb4 séparation trouver information serveur/internet + ajout info internet dans les différentes formations 2017-03-20 10:13:43 +01:00
2eb826537c ajout des coordonnées du forum EOLE 2017-03-20 09:20:49 +01:00
e1743c32da présentation du cours 2017-03-18 16:37:36 +01:00
ba6fc1b406 debut de glossaire 2017-03-18 16:00:24 +01:00
0d2b2aca4d debut de glossaire 2017-03-18 15:47:40 +01:00
a723cce565 methodes agiles 2017-03-18 07:00:18 +01:00
e9b0afe3ee méthodologies agiles 2017-03-17 11:58:35 +01:00
de765b7431 Merge branch 'master' of ssh://forge.cadoles.com:4242/cadoles/formations 2017-03-17 11:40:30 +01:00
42223ee6bb modification des besoins pour la prépartion de la formation scribe-horus 2017-03-17 11:39:33 +01:00
a967c1e4c5 définition du cours d'algorithmique 2017-03-17 11:36:03 +01:00
9cbe2e337a début du cours d'algorithmique pour le CESI 2017-03-17 11:33:14 +01:00
d7a4bcc466 coorection orthographique et ajout changement bacula-bareos 2017-03-17 10:45:39 +01:00
4d7a2492a7 modification preparation 2017-03-13 16:36:02 +01:00
421c27e85f mise à jour du contenu 2017-03-13 16:16:58 +01:00
64e1002f9b modification formation pour scribe 2.6 et W10 2017-03-13 11:44:03 +01:00
ec18bf72dc modification contenu 2017-02-03 13:47:51 +01:00
1e0822db1c erreur chemin des dicos locals 2017-01-27 17:04:54 +01:00
fceaf18739 mise à jour des excercices tronc-commun-2 2017-01-26 18:06:37 +01:00
09aa743b31 mise à jour formation tc1 et tc2 2017-01-26 17:36:57 +01:00
c0bb8d8cfe Ajout des nouvelles images 2017-01-23 14:33:30 +01:00
2f93009cb2 Ajout 2.6.0 2017-01-23 14:33:13 +01:00
690581f7d6 mise à jour 2017-01-09 15:45:09 +01:00
21700131a0 ajout restauration complète en 2.6 2016-09-19 10:53:05 +02:00
c4bd4b9183 reformulation et correction orthographique 2016-09-01 15:25:47 +02:00
f642003eaf complement dans l'exemple d'exercice 2016-04-27 11:54:37 +02:00
73a5e3d14f corrections 2016-04-26 15:33:54 +02:00
f149b43557 ajout d'un exemple d'exercice corrigé 2016-04-21 17:00:48 +02:00
7987c5bb21 mise à jour de la formation pour 2.6 2016-04-20 10:44:44 +02:00
0ec050b306 Merge branch 'master' of ssh://forge.cadoles.com:4242/cadoles/formations
* 'master' of ssh://forge.cadoles.com:4242/cadoles/formations:
  modification plan et affichage formation
  ajout formation personnalidée sallanches
2015-11-02 16:32:13 +01:00
ee24393082 Fix title 2015-11-02 16:31:06 +01:00
8749c13f6d modification plan et affichage formation 2015-08-04 11:15:47 +02:00
ab17ccefb4 ajout formation personnalidée sallanches 2015-07-28 11:15:56 +02:00
00bda3b860 Adding new background 2015-06-17 15:16:13 +02:00
647a8cb2f2 Update de la formation amon sphynx 2015-06-17 15:01:19 +02:00
d3fedded5e ajout de doc sur les méta classes 2015-06-04 10:10:58 +02:00
5391804ac5 ajout de doc sur les classes et les objets 2015-06-04 09:58:51 +02:00
1e21dbe0f9 corrections coquilles 2015-05-13 15:37:00 +02:00
7ad34d4962 paragraphe generique 2015-05-11 09:16:33 +02:00
47c572334d sphinx et docutils 2015-05-07 09:33:59 +02:00
239097238e ajout des imports et de sys.modules 2015-05-05 15:00:47 +02:00
f52d023781 ajout des design patterns 2015-05-04 17:38:00 +02:00
9d1597fc15 ajout des design patterns 2015-05-04 16:29:15 +02:00
03da3c99a0 ajout de la doc sur les exceptions 2015-05-04 15:38:51 +02:00
03d5f17f6a config pour la version pdf 2015-05-01 10:32:46 +02:00
da6a42f8bb editeurs python : syntaxe 2015-04-30 16:23:39 +02:00
a3552c18c0 editeurs python 2015-04-30 14:57:46 +02:00
30f646581b Exo ngResource 2015-04-10 01:46:41 +02:00
1d015b15d5 Ajout exo protractor 2015-04-10 01:01:21 +02:00
22eb8175fe Ajout exo Karma 2015-04-10 00:30:02 +02:00
24ebf33c75 Ajout exo routage 2015-04-09 23:11:56 +02:00
e0ad7f004d Corrections slides 2015-04-09 20:36:17 +02:00
ccfe7374cc Formation Angular: exos supplémentaires 2015-04-09 01:03:35 +02:00
11b5d82ce4 (not) vanilla todos 2015-04-09 00:19:37 +02:00
16a28eb88b Angular, première partie 2015-04-08 23:22:53 +02:00
de745ba6df Ajout exo services 2015-04-07 22:38:36 +02:00
4df20d8adf Base formation angular+amélioration layout formations JS 2015-04-06 17:50:08 +02:00
e4811d8040 Suppression node_modules exercices 2015-04-03 10:42:28 +02:00
bbcccf4586 Nettoyage exemple tests-unitaires 2015-04-03 10:34:09 +02:00
f4e96ea040 Nettoyage exercices 2015-04-03 10:31:05 +02:00
c645af4112 Correction exo heritge js 2015-04-02 08:43:33 +02:00
b00c6dd3f4 Ajout exercices supplémentaires formation JS 2015-04-01 22:05:05 +02:00
9a2452b334 Corrections typo + exo VanillaTodos complet 2015-04-01 15:11:13 +02:00
16cf72bb59 Ajout exo VanillaTodos 2015-04-01 11:17:02 +02:00
5cf0c82685 Ajout slides supplémentaires formation JS 2015-03-31 23:29:23 +02:00
006c3f5a42 More Javascript 2015-03-30 14:18:55 +02:00
67f3024587 Inversion des paramètres pour bacula 2015-03-27 15:28:59 +01:00
7997272ef5 Ajustement du plan 2015-03-27 10:06:46 +01:00
4ba2e5768b Mise à jour du plan de formation 2015-03-27 10:06:46 +01:00
33d3f5386a Formation JS, ajout slides suppl. 2015-03-26 17:36:34 +01:00
6b0206f399 Essai de markdown pour documenter la génération des plans de formations 2015-03-26 15:27:11 +01:00
dda69187df Ajout de la durée 2015-03-26 15:19:38 +01:00
0672a0bd80 Ajout doc dépendances Latex 2015-03-25 17:27:44 +01:00
a2650f1ebd Ajout base formation Javascript 2015-03-25 17:27:03 +01:00
72ba644959 Relecture 2015-03-23 18:07:42 +01:00
4779875c04 Relecture 2015-03-23 18:06:36 +01:00
3c15ec7fe1 Relecture 2015-03-23 17:03:36 +01:00
d286f5cc66 Couleur différente pour le sous-titre de diapo 2015-03-23 16:55:26 +01:00
42199f9c6e Arrangement des diapos trop longues 2015-03-23 16:49:34 +01:00
b3cd20642a Relecture scribe-horus 2015-03-23 11:02:22 +01:00
5506609770 Relecture scribe-horus 2015-03-23 10:43:35 +01:00
cf58bc6aea Relecture scribe-horus 2015-03-23 09:48:02 +01:00
838027ac1d Relecture scribe/horus 2015-03-23 09:40:51 +01:00
eaad0c234b ajout EOP 2015-03-16 22:05:17 +01:00
5c44c012af plus de <fichier>.eol pour instance 2015-03-16 22:03:51 +01:00
acd25e74a1 mise à jour schedule 2015-03-12 15:09:27 +01:00
2140d0d47d Adaptation pour EOLE 2.4.1 2015-03-11 19:50:42 +01:00
c952079bdf Adaptation des dictionnaire et template pour la 2.4.x 2015-03-11 19:27:10 +01:00
00372ac099 Corrections mineures 2015-03-09 13:46:45 +01:00
b54c863956 Corrections mineures (ou pas) 2015-03-09 12:24:18 +01:00
870477c0b1 Corrections mineures 2015-03-09 12:20:02 +01:00
4e3bcf9231 Adaptations à la 2.4 2015-03-09 12:04:27 +01:00
448455c1ec Échappement des caractères spéciaux 2015-03-09 11:28:00 +01:00
c59da436d5 Relecture de la formation tronc commun 1 2015-03-09 11:20:53 +01:00
0ef2f19837 Relecture et correction 2015-03-09 09:56:36 +01:00
89a2a3604a modif exercices 2015-03-09 09:35:21 +01:00
609 changed files with 91 additions and 18409 deletions

4
.gitignore vendored
View File

@ -11,10 +11,6 @@
*.bcf
*.idx
*.run.xml
*.pygtex
*.vrb
build-messages-*.txt
plans_de_formation.tar.gz
_minted-*/
.~lock*
_minted-*/

25
README
View File

@ -1,25 +0,0 @@
Pour la formation sur Git, il faut compiler avec XeLaTeX.
XeLaTeX
=======
Langage de description de document avec prise en charge native de l'UTF-8
XeLaTeX est une variante de LaTeX, la structure générale du document reste identique et l'immense majorité des commandes et packages continuent de fonctionner comme d'habitude.
http://doc.ubuntu-fr.org/xelatex
http://fr.wikipedia.org/wiki/XeTeX
Installation
============
Sous Ubuntu 12.04 :
# apt-get install texlive-xetex
Utilisation
===========
Pour la formation sur Git, il faut compiler avec XeLaTeX.
Usage :
$ xelatex --shell-escape skell.tex

BIN
cesi/agilite/AtelierAgile.odp Executable file

Binary file not shown.

BIN
cesi/agilite/CoursAgile.odp Executable file

Binary file not shown.

View File

@ -1,5 +0,0 @@
\begin{frame}
\begin{exampleblock}{}
Des questions ?
\end{exampleblock}
\end{frame}

View File

@ -1,11 +0,0 @@
\section{Licence}
Cette œuvre est mise à disposition sous licence \href{http://creativecommons.org/licenses/by-nc-sa/2.0/fr/}{\textsc{cc-by-sa-2.0}}
\begin{itemize}
\item Attribution
\item Partage dans les Mêmes Conditions 2.0
\item France
\end{itemize}
Pour voir une copie de cette licence, visitez
\href{http://creativecommons.org/licenses/by-sa/2.0/fr/}{http://creativecommons.org/licenses/by-sa/2.0/fr/}
ou écrivez à Creative Commons, 444 Castro Street, Suite 900,
Mountain View, California, 94041, USA.

View File

@ -1,18 +0,0 @@
\skbheading{Lannuaire de module Scribe}
Lannuaire du module Scribe est opéré à laide du logiciel OpenLDAP.
Les schémas mis en place sont définis selon les règles métiers de lÉducation nationale.
Les schémas mis en place sont les suivants :
\begin{itemize}
\item core.schema
\item cosine.schema
\item inetorgperson.schema
\item nis.schema
\item samba.schema
\item eole.schema
\item eoleshare.schema
\item radius.schema
\item ent.schema
\end{itemize}
Les schémas \emph{core.schema}, \emph{cosine.schema} et \emph{nis.schema} sont des schémas classiques pour les annuaires décrivant des personnes.
Les autres schémas, placés dans le sous-répertoire \emph{eole}, décrivent les objets nécessaires pour Samba (\emph{samba.schema}), les objets précisant les types de personnes (\emph{eole.schema}) et les partages (\emph{eoleshare.schema}), les attributs pour lutilisation de Radius (\emph{radius.schema}) et, enfin, les objets et attributs pour limplémentation du schéma directeur des espaces numériques de travail (\emph{ent.schema}).

View File

@ -1,33 +0,0 @@
\skbheading{Les classes dobjets métiers de lannuaire du module Scribe}
Les classe dobjets métiers de lannuaire du module Scribe sont celles décrites dans les schémas de plus haut niveau.
Ces classes dobjets décrivent des utilisateurs, des groupes dutilisateurs et des ressources comme les partages.
Plusieurs classes dobjets peuvent être utilisées conjointement pour préciser le type de la ressource décrite : les classes dobjects sont complémentaires et ne sont pas organisées de manière hiérarchique.
Les classes dont le nom débute par \emph{ENT} sont issues du schéma directeur des espaces numériques de travail.
Les classes dobjets susceptibles dêtre utilisées pour les personnes sont les suivantes :
\begin{itemize}
\item Eleves
\item administrateur
\item responsable
\item administratif
\item ENTPerson
\item ENTEleve
\item ENTAuxPersRelEleve
\item ENTAuxEnseignant
\item ENTAuxNonEnsServAc
\item ENTAuxNonEnsCollLoc
\item ENTAuxNonEnsEtab
\item ENTAuxPersExt
\item ENTAuxTuteurStage
\item ENTAuxRespEntrp
\item eolemail
\item autre
\end{itemize}
Les classes dobjets susceptibles dêtre utilisées pour les groupes sont les suivantes :
\begin{itemize}
\item eolegroupe
\item classe
\item ENTGroupe
\item ENTClasse
\end{itemize}

View File

@ -1,79 +0,0 @@
\skbheading{La fiche du personnel administratif dans lannuaire du module Scribe}
Le personnel administratif, dans lannuaire du module Scribe, est la conjonction de plusieurs classes dobjets :
\begin{itemize}
\item top
\item person
\item organizationalPerson
\item posixAccount
\item shadowAccount
\item inetOrgPerson
\item sambaSamAccount
\item administratif
\item ENTPerson
\item ENTAuxNonEnsEtab
\item radiusprofile
\end{itemize}
La partie métier est portée par les classes \emph{administratif}, \emph{ENTPerson} et \emph{ENTAuxNonEnsEtab}.
Les attributs susceptibles dêtre associés à un personnel administratif sont les suivants :
\begin{itemize}
\item les attributs issus de la classe administratif :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item typeadmin
\item codecivilite
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item dateNaissance
\item mailDir
\item mailHost
\item intid
\item FederationKey
\item Divcod
\item ManagedGroup
\item LastUpdate
\item mailAlternateAddress
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTPerson :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item ENTPersonLogin
\item ENTPersonJointure
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTPersonAutresPrenoms
\item ENTPersonNomPatro
\item ENTPersonSexe
\item ENTPersonCentresInteret
\item ENTPersonAdresse
\item ENTPersonCodePostal
\item ENTPersonVille
\item ENTPersonPays
\item ENTPersonAlias
\item ENTPersonStructRattach
\item ENTPersonFonctions
\item ENTPersonProfils
\item ENTPersonDateNaissance
\item personalTitle
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTAuxNonEnsEtab :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item aucun attribut obligatoire
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTAuxNonEnsEtabService
\end{itemize}
\end{itemize}
\end{itemize}

View File

@ -1,97 +0,0 @@
\skbheading{La fiche de lélève dans lannuaire du module Scribe}
Lélève, dans lannuaire du module Scribe, est la conjonction de plusieurs classes dobjets :
\begin{itemize}
\item top
\item person
\item organizationalPerson
\item posixAccount
\item shadowAccount
\item inetOrgPerson
\item sambaSamAccount
\item Eleves
\item ENTPerson
\item ENTEleve
\item radiusprofile
\end{itemize}
La partie métier est portée par les classes \emph{Eleves} et \emph{ENTEleve}.
Les attributs susceptibles dêtre associés à un élève sont les suivants :
\begin{itemize}
\item les attributs issus de la classe Eleves :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item givenName
\item codecivilite
\item mail
\item mailHost
\item userPassword
\item employeeNumber
\item dateNaissance
\item Meflcf
\item Divcod
\item uid
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item mailDir
\item telephoneNumber
\item mailForwardingAddress
\item mailAlternateAddress
\item textelibre
\item photo
\item diffusion
\item dermaj
\item Meflcm
\item Divcodmso
\item mailparent
\item FederationKey
\item Ine
\item postalAddress
\item rne
\item LastUpdate
\item intid
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTEleve :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item ENTEleveStatutEleve
\item ENTEleveMEF
\item ENTEleveLibelleMEF
\item ENTEleveNivFormation
\item ENTEleveFiliere
\item ENTEleveEnseignements
\item ENTEleveClasses
\item ENTEleveMajeur
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTEleveVilleNaissance
\item ENTEleveDeptNaissance
\item ENTElevePaysNaissance
\item ENTEleveParents
\item ENTEleveAutoriteParentale
\item ENTElevePersRelEleve1
\item ENTEleveQualitePersRelEleve1
\item ENTElevePersRelEleve2
\item ENTEleveQualitePersRelEleve2
\item ENTEleveBoursier
\item ENTEleveRegime
\item ENTEleveTransport
\item ENTEleveMEFRattach
\item ENTEleveNivFormationDiplome
\item ENTEleveSpecialite
\item ENTEleveGroupes
\item ENTEleveEnsRespStage
\item ENTEleveEnsTutStage
\item ENTEleveEntrTutStage
\item ENTEleveEntrAutres
\item ENTEleveDelegClasse
\item ENTEleveDelegAutres
\item ENTEleveMajeurAnticipe
\item ENTEleveStructRattachId
\end{itemize}
\end{itemize}
\end{itemize}

View File

@ -1,89 +0,0 @@
\skbheading{La fiche de lenseignant dans lannuaire du module Scribe}
Lenseignant, dans lannuaire du module Scribe, est la conjonction de plusieurs classes dobjets :
\begin{itemize}
\item top
\item person
\item organizationalPerson
\item posixAccount
\item shadowAccount
\item inetOrgPerson
\item sambaSamAccount
\item administrateur
\item ENTPerson
\item ENTAuxEnseignant
\item radiusprofile
\end{itemize}
La partie métier est portée par les classes \emph{administrateur}, \emph{ENTPerson} et \emph{ENTAuxEnseignant}.
Les attributs susceptibles dêtre associés à un enseignant sont les suivants :
\begin{itemize}
\item les attributs issus de la classe administrateur :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item typeadmin
\item codecivilite
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item dateNaissance
\item mailDir
\item mailHost
\item mailForwardingAddress
\item mailAlternateAddress
\item Meflcf
\item Divcod
\item FederationKey
\item ManagedGroup
\item LastUpdate
\item intid
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTPerson :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item ENTPersonLogin
\item ENTPersonJointure
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTPersonAutresPrenoms
\item ENTPersonNomPatro
\item ENTPersonSexe
\item ENTPersonCentresInteret
\item ENTPersonAdresse
\item ENTPersonCodePostal
\item ENTPersonVille
\item ENTPersonPays
\item ENTPersonAlias
\item ENTPersonStructRattach
\item ENTPersonFonctions
\item ENTPersonProfils
\item ENTPersonDateNaissance
\item personalTitle
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTAuxEnseignant :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item aucun attribut obligatoire
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTAuxsEnsMEF
\item ENTAuxEnsCategoDiscipline
\item ENTAuxEnsMatiereEnseignEtab
\item ENTAuxEnsClasses
\item ENTAuxEnsGroupes
\item ENTAuxEnsClassePrincipal
\item ENTAuxEnsRespStage
\item ENTAuxEnsTutStage
\end{itemize}
\end{itemize}
\end{itemize}

View File

@ -1,73 +0,0 @@
\skbheading{La fiche du responsable délève dans lannuaire du module Scribe}
Le responsable délève, dans lannuaire du module Scribe, est la conjonction de plusieurs classes dobjets :
\begin{itemize}
\item inetOrgPerson
\item responsable
\item ENTPerson
\item ENTAuxPersRelEleve
\end{itemize}
La partie métier est portée par les classes \emph{responsable}, \emph{ENTPerson} et \emph{ENTAuxPersRelEleve}.
Les attributs susceptibles dêtre associés à un responsable délève sont les suivants :
\begin{itemize}
\item les attributs issus de la classe responsable  :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item aucun attribut obligatoire
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item mailDir
\item mailHost
\item sambaLMPassword
\item sambaNTPassword
\item codecivilite
\item LastUpdate
\item gecos
\item eleve
\item intid
\item dateNaissance
\item mailPerso
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTPerson :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item ENTPersonLogin
\item ENTPersonJointure
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTPersonAutresPrenoms
\item ENTPersonNomPatro
\item ENTPersonSexe
\item ENTPersonCentresInteret
\item ENTPersonAdresse
\item ENTPersonCodePostal
\item ENTPersonVille
\item ENTPersonPays
\item ENTPersonAlias
\item ENTPersonStructRattach
\item ENTPersonFonctions
\item ENTPersonProfils
\item ENTPersonDateNaissance
\item personalTitle
\end{itemize}
\end{itemize}
\item les attributs issus de la classe ENTAuxPersRelEleve :
\begin{itemize}
\item dont les attributs obligatoires :
\begin{itemize}
\item ENTAuxPersRelEleveEleve
\end{itemize}
\item et les attributs optionnels :
\begin{itemize}
\item ENTAuxPersRelEleveRepresentant
\end{itemize}
\end{itemize}
\end{itemize}

View File

@ -1,2 +0,0 @@
\skbheading{schemas.tex}
fichier content/modules\_eole\_envole/scribe/annuaire/schemas.tex à éditer

View File

@ -1,29 +0,0 @@
\skbheading{Les outils du backend Scribe}
Le module Scribe amène des scripts pour la gestion des utilisateurs et des fonctions liées.
Ces fonctions utilisent les mêmes bibliothèques que lEAD2 pour la gestion des utilisateurs et groupes et sont donc une façon équivalente de manipuler lannuaire.
La liste des scripts disponibles est la suivante :
\begin{itemize}
\item ajout\_partage.py
\item change-classe.py
\item config-controle-vnc.py
\item creation-administratif.py
\item creation-eleve.py
\item creation-groupe.py
\item creation-prof.py
\item desinscription.py
\item droits\_partage.sh
\item droits\_user.py
\item inscription.py
\item mailsync.py
\item maj\_regle\_esu.sh
\item manage\_special\_shares.py
\item migre-domaine-messagerie.sh
\item modifie\_profil.py
\item regenalias.sh
\item regen\_maillist.py
\item suppression\_groupe.py
\item suppression\_utilisateur.py
\item zenity\_console.py
\end{itemize}

View File

@ -1,2 +0,0 @@
\skbheading{creation-administratif.tex}
fichier content/modules\_eole\_envole/scribe/backend/creation-administratif.tex à éditer

View File

@ -1,28 +0,0 @@
\skbheading{creation-eleve.py}
Le script \emph{creation-eleve.py} est utilisé pour créer un nouvel utilisateur du type élève dans lannuaire du module Scribe.
La fiche dun élève dans lannuaire du scribe contient obligatoirement :
\begin{itemize}
\item un identifiant de connexion ;
\item la classe de rattachement ;
\item un mot de passe ;
\item le prénom de lélève ;
\item le nom de famille de lélève ;
\item la date de naissance de lélève ;
\item le numéro de lélève ;
\item la civilité de lélève.
\end{itemize}
En complément, il est possible de renseigner les éléments suivants :
\begin{itemize}
\item le niveau de lélève ;
\item le type de domaine pour le courriel de lélève ;
\item un quota disque à assigner à lélève ;
\item le type de profil pour lutilisation dun poste client Windows ;
\item lactivation du shell pour permettre la connexion sur un poste client GNU/Linux.
\end{itemize}
\begin{description}
\item[emplacement] /usr/share/eole/backend
\item[aide] creation-eleve.py
\end{description}

View File

@ -1,2 +0,0 @@
\skbheading{creation-groupe.tex}
fichier content/modules\_eole\_envole/scribe/backend/creation-groupe.tex à éditer

View File

@ -1,2 +0,0 @@
\skbheading{creation-prof.tex}
fichier content/modules\_eole\_envole/scribe/backend/creation-prof.tex à éditer

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Source Code Management}
\begin{description}
\item[SCM] Système de gestion du code source
\end{description}
\begin{exampleblock}{}
Outil permettant le développement de code informatique en conservant les étapes de création.
\end{exampleblock}
\end{frame}

View File

@ -1,11 +0,0 @@
\begin{frame}
\frametitle{Fonctionnalités d'un SCM}
\framesubtitle{Que peut faire un SCM pour vous ?}
Avec un SCM :
\begin{itemize}
\item produisez des bugs en toute quiétude
\item déterminez qui est responsable du bug bloquant
\item corrigez facilement ce bug
\item identifiez cet état du code comme stable
\end{itemize}
\end{frame}

View File

@ -1,47 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{Récapitulatif}
\tiny{
\begin{columns}
\begin{column}{.3\textwidth}
Faire le point :
\begin{itemize}
\item status
\item ls-files
\item diff
\item log
\item grep
\item cherry
\item show
\item bisect
\item blame
\end{itemize}
\end{column}
\begin{column}{.3\textwidth}
Modifier le contenu :
\begin{itemize}
\item checkout
\item pull
\item fetch
\item merge
\item rebase
\item add
\item reset
\item clean
\item commit
\item cherry-pick
\item revert
\item push
\item filter-branch
\end{itemize}
\end{column}
\begin{column}{.3\textwidth}
Organiser le développement :
\begin{itemize}
\item branch
\item tag
\end{itemize}
\end{column}
\end{columns}
}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{add}
\begin{description}
\item[\commande{git add}] Ajouter le contenu d'un fichier à l'index.
\end{description}
\skbinput[from=fig]{apps/git_commande_add}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-u}] ajout des modifications des fichiers déjà connus de git
\item[\commande{-i}] ajout interactif
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{bisect}
\begin{description}
\item[\commande{git bisect start}] Démarrer une session de recherche du commit problématique par division binaire
\end{description}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{blame}
\begin{description}
\item[\commande{git blame}] Afficher l'auteur et la référence de la dernière modification pour chaque ligne d'un fichier
\end{description}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{branch}
\begin{description}
\item[git branch] Gérer les branches
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--list}] Lister les branches (\commande{-a} les branches locales et distantes, \commande{-r} les branches distantes uniquement)
\item[\commande{-d}] Supprimer une branche
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{checkout}
\begin{description}
\item[\commande{git checkout}] Synchroniser le répertoire de travail avec une version
\end{description}
\skbinput[from=fig]{apps/git_commande_checkout}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-b}] Créer une nouvelle branche et déplacer HEAD dessus
\item[\commande{--ours --theirs}] Conserver des modifications explicitement
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,12 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{cherry-pick}
\begin{description}
\item[\commande{git cherry-pick}] Appliquer les changements introduits dans un commit donné
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--abort}] Interrompre le processus
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{cherry}
\begin{description}
\item[\commande{git cherry}] Trouver les commit qui ne sont pas encore appliqués dans le dépôt distant
\end{description}
\end{frame}

View File

@ -1,13 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{clean}
\begin{description}
\item[\commande{git clean}] Supprime les fichiers non suivis du répertoire de travail
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-xdf}] Combinaison pour supprimer du répertoire de travail les dossiers et fichiers non suivis
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{clone}
\begin{description}
\item[\commande{git clone <url du dépôt>}] Récupérer un dépôt git depuis une source distante
\end{description}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,15 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{commit}
\begin{description}
\item[\commande{git commit}] Créer un commit à partir du contenu de l'index
\end{description}
\skbinput[from=fig]{apps/git_commande_commit}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-a}] Court-circuiter l'index en intégrant au commit les modifications des fichiers suivis dans le répertoire de travail
\item[\commande{--amend}] Modifier le dernier commit
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{diff}
\begin{description}
\item[\commande{git diff}] Afficher la différence entre deux états (entre le répertoire de travail ou l'index et la branche par exemple)
\end{description}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,13 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{checkout}
\begin{description}
\item[git fetch] Mettre à jour la copie locale d'un dépôt distant
\end{description}
\skbinput[from=fig]{apps/git_commande_fetch}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[-all] Mettre à jour les copies locales de tous les dépôts distants configurés
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,13 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{filter-branch}
\begin{description}
\item[\commande{git filter-branch}] Exécuter une commande sur un ensemble de commit
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--tree-filter}] Modifier le contenu de l'arborescence pour chaque version du projet
\item[\commande{--env-filter}] Modifier la teneur des variables d'environnement pour chaque commit
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{grep}
\begin{description}
\item[\commande{git grep}] Rechercher dans chaque fichier d'un arbre quelconque
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--break}] Sépare les résultats pour une meilleure lisibilité
\item[\commande{--heading}] Donne le contexte du résultat
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{init}
\begin{description}
\item[\commande{git init}] Convertir le dossier courant en dépôt git
\end{description}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,15 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{log}
\begin{description}
\item[\commande{git log}] Afficher une liste de commit
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-L}] Retracer l'historique d'un morceau de code
\item[\commande{<c1>..<c2>}] Lister les commit accessibles depuis c2 mais pas c1
\item[\commande{<c1>...<2>}] Lister les commit accessibles depuis l'un ou l'autre mais pas des deux à la fois
\item[\commande{--not Ref}] Lister les commit qui ne sont pas accessibles depuis Ref
\end{description}
\end{exampleblock}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{ls-files}
\begin{description}
\item[\commande{git ls-files}] Afficher les informations sur les fichiers de l'index et du répertoire de travail.
\end{description}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{merge}
\begin{description}
\item[\commande{git merge}] Intégrer les commit d'une branche à une autre
\end{description}
%\skbinput[from=fig]{apps/git_commande_merge}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--abort}] Pour faire machine arrière lors d'un merge manuel
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{pull}
\begin{description}
\item[\commande{git pull}] Synchroniser une branche locale avec la branche distante
\end{description}
\skbinput[from=fig]{apps/git_commande_pull}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--rebase}] Choisir la stratégie rebase pour incorporer les changements (équivalent à la succession des commandes \commande{fetch} et \commande{rebase})
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,15 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{push}
\begin{description}
\item[\commande{git push}] Synchroniser une branche distante avec une branche locale
\end{description}
\skbinput[from=fig]{apps/git_commande_push}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--tags}] Pousser les tags locaux sur le dépôt distant
\item[\commande{--all}] Pousser toutes les branches
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{rebase}
\begin{description}
\item[\commande{git rebase}] Rejouer les modifications après mise à jour de la branche
\end{description}
%\skbinput[from=fig]{apps/git_commande_rebase}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-i}] Réordonner les modifications manuellement
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{reset}
\begin{description}
\item[\commande{git reset}] Revenir à une version antérieure
\end{description}
%\skbinput[from=fig]{apps/git_commande_reset}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--hard}] Écraser le contenu du répertoire de travail et de l'index
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{revert}
\begin{description}
\item[\commande{git revert}] Créer le commit annulant un autre commit
\end{description}
%\skbinput[from=fig]{apps/git_commande_revert}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{--abort}] Interrompre le traitement
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{show}
\begin{description}
\item[\commande{git show}] Afficher la description d'un commit
\end{description}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{status}
\begin{description}
\item[\commande{git status}] Afficher le statut du répertoire de travail, et de l'index relativement à la branche
\end{description}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,15 +0,0 @@
\begin{frame}
\frametitle{Commandes git}
\framesubtitle{tag}
\begin{description}
\item[\commande{git tag}] Gérer les étiquettes attachées à un commit
\end{description}
\begin{exampleblock}{Options à retenir}
\begin{description}
\item[\commande{-l}] Lister les étiquettes (éventuellement correpondant à un motif)
\item[\commande{-a}] Annoter l'étiquette
\item[\commande{-s}] Signer l'étiquette
\end{description}
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,33 +0,0 @@
\begin{frame}
\frametitle{Ergonomie}
\framesubtitle{alias}
Les alias sont des raccourcis gérés pas git.
\commande{git config alias.<nom de l'alias> "<commande>"}
\begin{exampleblock}{Nature des commandes}
Les commandes peuvent aussi bien être des options et sous-commandes de git que des commandes externes accessibles au shell.
\end{exampleblock}
\end{frame}
\begin{frame}[fragile]
\frametitle {Ergonomie}
\framesubtitle{Exemples d'alias}
\begin{minted}[fontsize=\tiny]{ini}
[alias]
co = checkout
st = status
fe = fetch
lo = log --oneline
re = reset --hard HEAD~1
br = branch
mnf = merge --no-ff
sw = checkout @{-1}
lu = log ..@{upstream}
luo = log --oneline ..@{upstream}
ul=log @{upstream}..HEAD
ulo=log --oneline @{upstream}..HEAD
cslt = !git describe --long --first-parent | awk -F'/' '{print $NF}' | awk -F'-' '{print $(NF-1)}'
clf = !git lo --no-merges $(git lo -1 --pretty=format:"%h" debian/changelog)..
\end{minted}
\end{frame}

View File

@ -1,10 +0,0 @@
\begin{frame}
\frametitle{Ergonomie}
\framesubtitle{Interface}
\begin{itemize}
\item \commande{git config --global core.editor "vim"}
\item \commande{git config --global core.pager "less"}
\item \commande{git config --global color.ui auto}
\end{itemize}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,47 +0,0 @@
\begin{frame}
\frametitle{Ergonomie}
\framesubtitle{Hooks}
Les hooks sont des actions déclenchées par des évènements concernant le dépôt git.
\begin{exampleblock}{}
Les hooks sont des scripts exécutables (pas de langage imposé) posés dans le dossier .git/hooks.
\end{exampleblock}
\end{frame}
\begin{frame}
\frametitle{Ergonomie}
\framesubtitle{Hooks pour le client}
\begin{columns}
\begin{column}{0.5\textwidth}
\begin{itemize}
\item pre-commit
\item prepare-commit-msg
\item commit-msg
\item post-commit
\item applypatch-msg
\item preapply-patch
\item postapply-patch
\end{itemize}
\end{column}
\begin{column}{0.5\textwidth}
\begin{itemize}
\item pre-rebase
\item post-rewrite
\item post-checkout
\item post-merge
\item pre-push
\end{itemize}
\end{column}
\end{columns}
\end{frame}
\begin{frame}
\frametitle{Ergonomie}
\framesubtitle{Hooks pour le serveur}
\begin{itemize}
\item pre-receive
\item update
\item post-receive
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Configurer git}
\framesubtitle{Une configuration souple}
\begin{itemize}
\item configuration globale
\item configuration par dépôt
\end{itemize}
\end{frame}

View File

@ -1,16 +0,0 @@
\begin{frame}[fragile]
\frametitle{Ergonomie}
\framesubtitle{bash}
\begin{minted}{bash}
source ~/.git-prompt.sh
GIT_PS1_SHOWDIRTYSTATE=1
GIT_PS1_SHOWSTASHSTATE=1
GIT_PS1_SHOWUNTRACKEDFILES=1
GIT_PS1_SHOWUPSTREAM="auto"
PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '
\end{minted}
\begin{exampleblock}{git-prompt}
git-prompt.sh est un script définissant la fonction \_\_git\_ps1 permettant d'afficher des informations pertinentes sur l'état du dépôt git dans l'invite de commande.
\end{exampleblock}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Configurer git}
\framesubtitle{Identifier l'utilisateur}
git associe à chaque commit des informations sur la personne ayant commité et sur la personne ayant mergé le commit.
\begin{itemize}
\item \commande{git config --global user.name "<nom d'utilisateur>"}
\item \commande{git config --global user.email "<courriel>"}
\end{itemize}
\end{frame}

View File

@ -1,6 +0,0 @@
\begin{frame}
\frametitle{Décentralisé}
\begin{description}
\item[DVCS] Système de gestion de version décentralisé
\end{description}
\end{frame}

View File

@ -1,12 +0,0 @@
\begin{frame}
\frametitle{Les trois états des fichiers}
\begin{itemize}
\item non-suivi (avec la variante ignoré)
\item suivi :
\begin{itemize}
\item non modifié (par rapport au dernier état archivé)
\item modifié (par rapport au dernier état archivé)
\item sélectionné pour être archivé
\end{itemize}
\end{itemize}
\end{frame}

View File

@ -1,10 +0,0 @@
\begin{frame}
\frametitle{Exercices}
\framesubtitle{Configuration globale de git}
Les paramètres de l'application git peuvent être globaux ou propres à un dépôt.
L'ergonomie, l'identité, les alias sont souvent les mêmes pour tous les dépôts.
La première étape consiste généralement à renseigner ces paramètres.
Le premier exercice consiste donc à renseigner un minimum de ces variables globales.
\end{frame}

View File

@ -1,38 +0,0 @@
\begin{frame}
\frametitle{Mise en place}
\framesubtitle{Identité de l'utilisateur}
\begin{itemize}
\item \commande{git config --global user.name "<nom de l'utilisateur>"}
\item \commande{git config --global user.email "<courriel de l'utilisateur>"}
\end{itemize}
\begin{exampleblock}{En cas d'oubli}
\commande{git} émet un avertissement lors du premier commit si ces variables ne sont pas renseignées.
Il est possible de corriger cet oubli facilement si les commit n'ont pas encore été partagés.
\end{exampleblock}
\end{frame}
\begin{frame}
\frametitle{Mise en place}
\framesubtitle{Ergonomie}
\begin{itemize}
\item \commande{git config --global color.ui auto}
\item \commande{git config --global core.editor "<éditeur de texte à utiliser>"}
\item \commande{git config --global core.pager "<pager>"}
\end{itemize}
\end{frame}
\begin{frame}[fragile]
\frametitle{Mise en place}
\framesubtitle{Ergonomie (GNU/Linux)}
\begin{minted}{bash}
source ~/.git-prompt.sh
GIT_PS1_SHOWDIRTYSTATE=1
GIT_PS1_SHOWSTASHSTATE=1
GIT_PS1_SHOWUNTRACKEDFILES=1
GIT_PS1_SHOWUPSTREAM="auto"
PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '
\end{minted}
\begin{exampleblock}{git-prompt}
git-prompt.sh est un script définissant la fonction \_\_git\_ps1 permettant d'afficher des informations pertinentes sur l'état du dépôt git dans l'invite de commande.
\end{exampleblock}
\end{frame}

View File

@ -1,14 +0,0 @@
\begin{frame}
\frametitle{Exercices}
\framesubtitle{Initialiser un dépôt}
Un dépôt git peut être amorcé de différentes façons selon le contexte.
\begin{itemize}
\item le dépôt existe déjà en \emph{distant} :
\begin{itemize}
\item le dépôt distant est déjà au format git ;
\item le dépôt distant est géré par un autre scm ;
\end{itemize}
\item un répertoire local doit être converti en dépôt git ;
\end{itemize}
L'exercice propose la création d'un dépôt suivant ces différents contextes.
\end{frame}

View File

@ -1,21 +0,0 @@
\begin{frame}
\frametitle{Initialiser le dépôt}
\framesubtitle{Récupérer le dépôt git distant en ssh}
Le serveur de dépôt de test propose un dépôt par groupe.
\commande{git clone ssh://gogs@<adresse\_serveur>/formation/<groupe>}
\end{frame}
\begin{frame}
\frametitle{Initialiser le dépôt}
\framesubtitle{Récupérer le dépôt git distant en https}
L'accès au serveur est aussi permis en http(s)
\commande{git clone http://<adresse\_serveur>:3000/formation/<groupe>}
\end{frame}
\begin{frame}
\frametitle{Initialiser le dépôt}
\framesubtitle{Convertir le dossier local en dépôt git}
N'importe quelle répertoire peut être converti en dépôt git.
\commande{git init}
\end{frame}

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Avoir des dépôts distants en référence}
Les dépôts distants sont un aspect important du fonctionnement d'un SCM décentralisé.
git permet d'associer plusieurs dépôts distants à un dépôt local et de renseigner à quelle branche de quel dépôt distant une branche locale doit se référer.
Le présent exercice aborde la mise en place de tels liens entre branches locales et branches distantes.
\end{frame}

View File

@ -1,31 +0,0 @@
\begin{frame}
\frametitle{Associer les dépôts distants}
\framesubtitle{Ajouter un dépôt distant}
\commande{git remote add <nom> <protocole>://[<utilisateur>@]<adresse>[:port]/<chemin>}
Exemples :
\begin{itemize}
\item \commande{git remote add formation ssh://gogs@localhost:3000/formation/exercices.git}
\item \commande{git remote add formation http://gogs@localhost:3000/formation/exercices.git}
\end{itemize}
\begin{exampleblock}{Vérification}
Les dépôts distants configurés peuvent être listés avec :
\begin{itemize}
\item \commande{git remote} pour la version sobre ou
\item \commande{git remote -v} pour plus de détails.
\end{itemize}
\end{exampleblock}
\end{frame}
\begin{frame}
\frametitle{Associer les dépôts distants}
\framesubtitle{Observer une branche distante}
Pour une branche distante existante :
\begin{itemize}
\item \commande{git branch --set-upstream-to=<nom\_dépôt\_distant>/<branche\_distante>}
\end{itemize}
Pour une branche distante inexistante :
\begin{itemize}
\item \commande{git push --set-upstream <nom\_dépôt\_distant> <branche\_locale>}
\end{itemize}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Premier commit}
Le premier commit est toujours le plus facile. Pas de conflit à attendre, pas de stress…
Cet exercice permet de revoir le fonctionnement des \emph{arbres} de git avec l'ajout d'un simple fichier dans un dossier.
\end{frame}

View File

@ -1,138 +0,0 @@
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Dépôt vide}
Au démarrage, est un dépôt vide :
\begin{minted}[fontsize=\tiny]{bash}
Sur la branche master
Validation initiale
rien à valider (créez/copiez des fichiers et utilisez "git add" pour les suivre)
\end{minted}
\end{frame}
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Et pourtant…}
\begin{columns}
\begin{column}{0.5\textwidth}
L'initialisation consiste en la création du dossier .git :
\end{column}
\begin{column}{0.5\textwidth}
\begin{minted}[fontsize=\tiny]{bash}
.
└── .git
├── branches
├── config
├── description
├── HEAD
├── hooks
│   ├── applypatch-msg.sample
│   ├── commit-msg.sample
│   ├── post-update.sample
│   ├── pre-applypatch.sample
│   ├── pre-commit.sample
│   ├── prepare-commit-msg.sample
│   ├── pre-push.sample
│   ├── pre-rebase.sample
│   └── update.sample
├── info
│   └── exclude
├── objects
│   ├── info
│   └── pack
└── refs
├── heads
└── tags
\end{minted}
\end{column}
\end{columns}
\end{frame}
\begin{frame}
\frametitle{Premier pas}
\framesubtitle{Création d'un dossier}
\commande{mkdir doc}
\end{frame}
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Création d'un dossier}
\commande{git status}
\begin{minted}[fontsize=\tiny]{bash}
Sur la branche master
Validation initiale
rien à valider (créez/copiez des fichiers et utilisez "git add" pour les suivre)
\end{minted}
\begin{exampleblock}{}
git ne prend en considération que le contenu des fichiers.
\end{exampleblock}
\end{frame}
\begin{frame}
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{touch doc/README}
\end{frame}
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{git status}
\begin{minted}[fontsize=\tiny]{bash}
Sur la branche master
Validation initiale
Fichiers non suivis:
(utilisez "git add <fichier>..." pour inclure dans ce qui sera validé)
doc/
aucune modification ajoutée à la validation mais des fichiers non suivis sont présents
(utilisez "git add" pour les suivre)
\end{minted}
\end{frame}
\begin{frame}
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{git add .}
\skbinput[from=fig]{apps/git_commande_add}
\end{frame}
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{git status}
\begin{minted}[fontsize=\tiny]{bash}
Sur la branche master
Validation initiale
Modifications qui seront validées :
(utilisez "git rm --cached <fichier>..." pour désindexer)
nouveau fichier : doc/README
\end{minted}
\end{frame}
\begin{frame}
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{git commit -m "Ajout du premier fichier."}
\skbinput[from=fig]{apps/git_commande_commit}
\end{frame}
\begin{frame}[fragile]
\frametitle{Premier pas}
\framesubtitle{Création d'un fichier}
\commande{git status}
\begin{minted}[fontsize=\tiny]{bash}
Sur la branche master
rien à valider, la copie de travail est propre
\end{minted}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Gérer son répertoire de travail}
Le répertoire de travail est la vue du dépôt la plus facile à prendre en main dans un dépôt git.
Cet exercice a pour but de bien maîtriser les quatre états des fichiers dans un dépôt git : non-suivi, suivi et identique au contenu de l'index, suivi et différent et enfin, suivi, différent et selectionné pour archivage.
La difficulté majeure, à ce stade, est de toujours contrôler les passages d'état pour ne pas archiver un fichier indésirable par exemple.
\end{frame}

View File

@ -1,115 +0,0 @@
\begin{frame}
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Créer un fichier}
\commande{echo "userA userApwd" > password}
\end{frame}
\begin{frame}
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Modifier un fichier}
Ajouter du texte au fichier doc/README
\end{frame}
\begin{frame}[fragile]
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Admirer la complexité de la situation}
\commande{git status}
\begin{minted}[fontsize=\tiny]{console}
Sur la branche master
Modifications qui seront validées :
(utilisez "git reset HEAD <fichier>..." pour désindexer)
modifié : doc/README
Fichiers non suivis:
(utilisez "git add <fichier>..." pour inclure dans ce qui sera validé)
password
\end{minted}
\end{frame}
\begin{frame}[fragile]
\frametitle{Gérer son répertoire de travail}
\framesubtitle{À la croisée des chemins}
Associer les commandes suivantes :
\begin{columns}
\begin{column}{.3\textwidth}
\tiny{\commande{git add .}}
\tiny{\commande{git commit -m "Tout de go"}}
\end{column}
\begin{column}{.3\textwidth}
\tiny{\commande{git commit -am "Implicite"}}
\end{column}
\begin{column}{.3\textwidth}
\tiny{\commande{git add doc/README}}
\tiny{\commande{git commit -m "Explicite"}}
\end{column}
\end{columns}
aux résultats suivants :
\begin{columns}
\begin{column}{.3\textwidth}
\begin{minted}[fontsize=\tiny,breaklines,frame=single]{console}
Sur la branche master
Fichiers non suivis:
(utilisez "git add <fichier>..." pour inclure dans ce qui sera validé)
password
aucune modification ajoutée à la validation mais des fichiers non suivis sont présents (utilisez "git add" pour les suivre)
\end{minted}
\end{column}
\begin{column}{.3\textwidth}
\begin{minted}[fontsize=\tiny,breaklines,frame=single]{console}
Sur la branche master
rien à valider, la copie de travail est propre
\end{minted}
\end{column}
\begin{column}{.3\textwidth}
\begin{minted}[fontsize=\tiny,breaklines,frame=single]{console}
Sur la branche master
Fichiers non suivis:
(utilisez "git add <fichier>..." pour inclure dans ce qui sera validé)
password
aucune modification ajoutée à la validation mais des fichiers non suivis sont présents (utilisez "git add" pour les suivre)
\end{minted}
\end{column}
\end{columns}
\end{frame}
\begin{frame}
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Parer les erreurs prévisibles}
\commande{echo "password" > .gitignore}
\commande{git add .gitignore}
\commande{git commit -m "Filtre de fichier à ne pas suivre"}
\end{frame}
\begin{frame}[fragile]
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Laisser sur le côté de la route}
\commande{git status}
\begin{minted}[fontsize=\tiny]{console}
Sur la branche master
rien à valider, la copie de travail est propre
\end{minted}
\end{frame}
\begin{frame}
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Et s'il est trop tard ?}
\commande{git reset HEAD\~{}1}
\end{frame}
\begin{frame}
\frametitle{Gérer son répertoire de travail}
\framesubtitle{Recueil de .gitignore}
Des .gitignore adaptés à différents contextes sont faciles à obtenir sur l'Internet.
\url{https://github.com/github/gitignore}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Utiliser les branches}
Les branches sont faciles à créer et détruire dans un dépôt git.
Cela en fait un outil de choix pour l'organisation du développement.
L'exercice suivant aborde les manipulations de base avec les branches.
\end{frame}

View File

@ -1,219 +0,0 @@
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Créer une branche}
On créé une branche qui contiendra le fichier password.
\commande{git checkout -b branche\_indiscrete}
équivalent de la succession de commandes :
\begin{enumerate}
\item \commande{git branch branche\_indiscrete}
\item \commande{git checkout branche\_indiscrete}
\end{enumerate}
\begin{tikzpicture}
\gitDAG[grow right sep = 1em]{
A -- B};
\gitbranch{master}{above=of B}{B}
\gitHEAD{above=of master}{master}
\end{tikzpicture}
\begin{tikzpicture}
\gitDAG[grow right sep = 1em]{
A -- B};
\gitbranch{master}{above=of B}{B}
\gitHEAD{above=of master}{master}
\gitbranch[brindis]{brancheindiscrete}{below=of B}{B}
\end{tikzpicture}
\begin{tikzpicture}
\gitDAG[grow right sep = 1em]{
A -- B};
\gitbranch{master}{above=of B}{B}
\gitbranch[brindis]{brancheindiscrete}{below=of B}{B}
\gitHEAD{below=of brindis}{brindis}
\end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\frametitle{Aparté}
\commande{git add password}
\commande{git commit -m "le fichier indésirable"}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\frametitle{Aparté}
\commande{git log master..branche\_indiscrete}
\commande{git log master..}
\commande{git reflog}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Merge}
\commande{git checkout master}
\commande{git branch merge/automatique}
\commande{git branch merge/conflit}
\commande{git branch merge/rebase}
% \begin{tikzpicture}
% \gitDAG[grow down sep = 1em]{
% A -- B};
% \gitbranch{master}{left=of B}{B}
% \gitHEAD{left=of master}{master}
% \gitbranch[auto]{merge/automatique}{right=of master}{B}
% \gitbranch[conflit]{merge/conflit}{right=of auto}{B}
% \gitbranch[rebase]{merge/rebase}{right=of conflit}{B}
% \end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Merge}
\commande{git checkout merge/automatique}
\commande{cp doc/README\{,.md\}}
\commande{git add doc/}
\commande{git commit -m "Copie du fichier"}
% \begin{tikzpicture}
% \gitDAG[grow down sep = 1em]{
% A -- B --{C}};
% \gitbranch{master}{right=of B}{B}
% \gitHEAD{left=of auto}{auto}
% \gitbranch[auto]{merge/automatique}{left=of C}{C}
% \gitbranch[conflit]{merge/conflit}{right=of master}{B}
% \gitbranch[rebase]{merge/rebase}{right=of conflit}{B}
% \end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Merge}
\commande{git checkout merge/conflit}
Édition du fichier doc/README
\commande{git commit -am "Des ennuis en perspective"}
% \begin{tikzpicture}
% \gitDAG[grow down sep = 1em]{
% A -- B --{C, D}};
% \gitbranch{master}{right=of B}{B}
% \gitHEAD{left=of conflit}{conflit}
% \gitbranch[auto]{merge/automatique}{right=of C}{C}
% \gitbranch[conflit]{merge/conflit}{left=of D}{D}
% \gitbranch[rebase]{merge/rebase}{right=of master}{B}
% \end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Merge}
\commande{git checkout merge/rebase}
Édition du fichier doc/README
\commande{git commit -am "Des ennuis en perspective"}
% \begin{tikzpicture}
% \gitDAG[grow right sep = 1em]{
% A -- B --{C, D, E}};
% \gitbranch{master}{above=of B}{B}
% \gitHEAD{above=of rebase}{rebase}
% \gitbranch[auto]{merge/automatique}{above=of C}{C}
% \gitbranch[conflit]{merge/conflit}{above=of D}{D}
% \gitbranch[rebase]{merge/rebase}{above=of E}{E}
% \end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Merge}
\commande{git checkout master}
Édition du fichier doc/README pour ajouter des alias
\commande{git commit -am "Des ennuis en perspective"}
Pour chaque branche merge/*, tenter la commande :
\commande{git merge merge/<nom>}
\end{frame}
\begin{frame}
\frametitle{Utiliser les branches}
\framesubtitle{Rebase}
\commande{git checkout merge/rebase}
\commande{git rebase master}
% \begin{tikzpicture}
% \gitDAG[grow down sep = 1em]{
% A -- B --{C, D, E'}};
% \gitbranch{master}{right=of B}{B}
% \gitHEAD{left=of rebase}{rebase}
% \gitbranch[auto]{merge/automatique}{right=of C}{C}
% \gitbranch[conflit]{merge/conflit}{right=of D}{D}
% \gitbranch[rebase]{merge/rebase}{left=of E'}{E'}
% \end{tikzpicture}
\end{frame}
% \begin{tikzpicture}
% % Commit DAG
% \gitDAG[grow right sep = 2em]{
% A -- B -- {
% C,
% D -- E,
% }
% };
% % Tag reference
% \gittag
% [v0p1] % node name
% {v0.1} % node text
% {above=of A} % node placement
% {A} % target
% % Remote branch
% \gitremotebranch
% [origmaster] % node name
% {origin/master} % node text
% {above=of C} % node placement
% {C} % target
% % Branch
% \gitbranch
% {master} % node name and text
% {above=of E} % node placement
% {E} % target
% % HEAD reference
% \gitHEAD
% {above=of master} % node placement
% {master} % target
% \end{tikzpicture}
% \begin{tikzpicture}
% \gitDAG[grow right sep = 2em]{
% A -- B -- {
% C -- D' -- E',
% {[nodes=unreachable] D -- E },
% }
% };
% % Tag reference
% \gittag
% [v0p1] % node name
% {v0.1} % node text
% {above=of A} % node placement
% {A} % target
% % Remote branch
% \gitremotebranch
% [origmaster] % node name
% {origin/master} % node text
% {above=of C} % node placement
% {C} % target
% % Branch
% \gitbranch
% {master} % node name and text
% {above=of E'} % node placement
% {E'} % target
% % HEAD reference
% \gitHEAD
% {above=of master} % node placement
% {master} % target
% \SAandWT
% \end{tikzpicture}

View File

@ -1,11 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Inspection générale}
Un historique de code n'a d'intérêt que si le besoin de connaître les actions
qui ont mené à un état se fait sentir.
git met à disposition divers outils pour inspecter l'historique.
Cet exercice se propose de présenter certains de ces outils.
Cet exercice s'appuie sur le contenu du dépôt git \emph{exercices} fourni.
\end{frame}

View File

@ -1,132 +0,0 @@
\begin{frame}
\frametitle{Inspection}
\framesubtitle{log}
Comparer les branches du dépôt \emph{exercices} en explorant les différentes options de git log (--graph, --all, --decorate, .., ...)
\commande{git log}
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{log}
\begin{tikzpicture}
\begin{pgflowlevelscope}{\pgftransformscale{0.5}}
\gitDAG[grow right sep=1em]{
fcacc8a -- a3a980c -- {6d7f839 -- {d221665 -- 841f693 -- f5965df -- a12f94b -- 5464ee7, fe0c2b7 -- 6212e29 -- 0f13577 -- a60f3ed, f81ca5c, 7e54de0},
30a5821, b13bcf2, 902ae87}
};
\gitbranch
{master}
{above=of 6d7f839}
{6d7f839}
\gitbranch
{brancheindiscrete}
{right=of 902ae87}
{902ae87}
\gitbranch
{merge/conflit}
{right=of 30a5821}
{30a5821}
\gitbranch
{merge/automatique}
{right=of b13bcf2}
{b13bcf2}
\gitbranch
{merge/rebase}
{right=of 7e54de0}
{7e54de0}
\gitbranch
{branche/perdue}
{right=of f81ca5c}
{f81ca5c}
\gitbranch
{branche/minee}
{above=of 5464ee7}
{5464ee7}
\gitbranch
{histoire/confuse}
{right=of a60f3ed}
{a60f3ed}
\end{pgflowlevelscope}
\end{tikzpicture}
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{bisect}
\begin{minipage}{\textwidth}
\begin{tikzpicture}
%\begin{pgflowlevelscope}{\pgftransformscale{0.5}}
\begin{pgflowlevel}{\pgftransformscale{0.6}}
\gitDAG[grow right sep=1em]{
fcacc8a -- a3a980c -- {6d7f839 -- {d221665 -- 841f693 -- f5965df -- a12f94b -- 5464ee7}}
};
\gitbranch
{master}
{above=of 6d7f839}
{6d7f839}
\gitbranch
{branche/minee}
{above=of 5464ee7}
{5464ee7}
%\end{pgflowlevelscope}
\end{pgflowlevel}
\end{tikzpicture}
\end{minipage}
La branche minee schématise une situation dans laquelle un dysfonctionnement a été introduit mais pas détecté
aussitôt.
Un script \emph{test.sh} a été ajouté pour simuler le test du code.
Il retourne \emph{0} lorsque le code est bon, \emph{1} lorsque le code est mauvais.
L'exercice consiste donc à utiliser la commande \commande{git bisect} pour repérer le commit ayant introduit l'erreur, c'est-à-dire à partir duquel le script retourne \emph{1}.
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{bisect}
Conditions de départ :
\begin{itemize}
\item dernier \emph{commit} de la branche \emph{branche/minee}
\item dernier état du code fonctionnel : dernier \emph{commit} de la branche \emph{master}.
\end{itemize}
\begin{enumerate}[<+->]
\item \commande{git checkout branche/minee}
\item \commande{git bisect start} \# démarrage de la session de recherche
\item \commande{git bisect bad} \# déclaration de l'état du dernier \emph{commit}
\item \commande{git bisect good \$(git log --oneline -1 --format=\%h master)} \# déclaration du dernier état fonctionnel connu
\end{enumerate}
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{bisect}
À chaque déplacement contrôlé par \commande{git bisect}, exécuter \emph{test.sh} et indiquer si l'état est fonctionnel :
\commande{./test.sh; [[ \$? -eq 0 ]] \&\& git bisect good || git bisect bad}
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{bisect}
\commande{a12f94b62f617417f4b1f8c5317bc2f033c92f5a is the first bad commit}
Terminer la session de recherche :
\commande{git bisect reset}
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{blame}
La conclusion précédente, vu la simplicité du code en cause, aurait pu être tirée grâce à \commande{git blame} et \commande{git log}.
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Inspection}
\framesubtitle{blame}
\begin{itemize}
\item \commande{git blame test.sh}
\item \commande{git log -S"exit 1" test.sh}
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Travail collaboratif}
En fait de travail collaboratif, chacun peut facilement personnifier l'enfer pour ses collègues.
L'exercice suivant propose de nettoyer son dépôt personnel avant de le rendre public.
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,156 +0,0 @@
\begin{frame}
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
\begin{minipage}{\textwidth}
\begin{tikzpicture}
%\begin{pgflowlevelscope}{\pgftransformscale{0.5}}
\begin{pgflowlevel}{\pgftransformscale{0.6}}
\gitDAG[grow right sep=1em]{
fcacc8a -- a3a980c -- {6d7f839 -- {fe0c2b7 -- 6212e29 -- 0f13577 -- a60f3ed}}
};
\gitbranch
{master}
{above=of 6d7f839}
{6d7f839}
\gitbranch
{histoire/confuse}
{above=of a60f3ed}
{a60f3ed}
%\end{pgflowlevelscope}
\end{pgflowlevel}
\end{tikzpicture}
\end{minipage}
Le scénario proposé pour le nettoyage s'appuie sur la branche \emph{histoire/confuse}.
Les \emph{commit} n'y sont pas cohérents : mélange de corrections syntaxiques, orthographiques et grammaticales.
Le but est de redonner de la lisibilité à l'historique du dépôt en le réécrivant à l'aide de \commande{git rebase -i} et \commande{git add -i}.
\end{frame}
\begin{frame}
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
\begin{enumerate}[<+->]
\item \commande{git checkout histoire/confuse}
\item \commande{git show master..} \# aperçu des modifications à réorganiser
\item \commande{git rebase -i \$(git merge-base --fork-point master)} \# rebase de tous les commits depuis la divergence avec la branche \emph{master}
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
À l'origine :
\begin{minted}[fontsize=\tiny]{console}
pick fe0c2b7 Commit un peu rapide.
pick 6212e29 Premier commit de correction
pick 0f13577 Deuxième commit de correction
pick a60f3ed Troisième et dernier (on espère) commit de correction
\end{minted}
Ce qu'on veut faire :
\begin{itemize}
\item un \emph{commit} pour les espaces superflues (0f13577 et 6212e29)
\item un \emph{commit} pour l'orthographe et la grammaire (0f13577, a60f3ed et 6212e29)
\item un \emph{commit} pour le contresens
\end{itemize}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
\begin{enumerate}[<+->]
\item s'arrêter sur le \emph{commit} 6212e29 et répartir les modifications sur trois \emph{commit}
\item s'arrèter sur le \emph{commit} 0f13577 et répartir les modifications sur deux \emph{commit}
\item reformuler le message du \emph{commit} a60f3ed
\end{enumerate}
\begin{minted}[fontsize=\tiny]{console}
pick fe0c2b7 Commit un peu rapide.
e 6212e29 Premier commit de correction
e 0f13577 Deuxième commit de correction
r a60f3ed Troisième et dernier (on espère) commit de correction
\end{minted}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
Pour chaque \emph{commit} édité :
\begin{enumerate}[<+->]
\item \commande{git reset HEAD\~{}1}
\item \commande{git add -i}
\item \commande{patch} et sélection du fichier à éditer
\item validation, refus ou édition du fragment de patch
\item sortie du mode patch
\item \commande{git add doc/README} suivi de \commande{git commit}
\item si il n'y a plus de modifications, \commande{git rebase --continue}, sinon, retour à l'étape 2
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
\begin{minted}[fontsize=\tiny]{console}
f500056 Corrections orthographiques et grammaticales
a11256a Suppression des espaces superflues
1a03003 Corrections orthographiques et grammaticales
f48a802 Corrections orthographiques et grammaticales
9ed1adb Suppression des espaces superflues
7236369 Correction du contresens
fe0c2b7 Commit un peu rapide.
\end{minted}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
Prêt pour la seconde passe.
\begin{minted}[fontsize=\tiny]{console}
pick fe0c2b7 Commit un peu rapide.
pick 7236369 Correction du contresens
pick 9ed1adb Suppression des espaces superflues
s a11256a Suppression des espaces superflues
pick f48a802 Corrections orthographiques et grammaticales
s 1a03003 Corrections orthographiques et grammaticales
s f500056 Corrections orthographiques et grammaticales
\end{minted}
\end{frame}
\begin{frame}[fragile]
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
Prêt pour la seconde passe.
\begin{minted}[fontsize=\tiny]{console}
f7caf4b Corrections orthographiques et grammaticales
cdcf39e Suppression des espaces superflues
7236369 Correction du contresens
fe0c2b7 Commit un peu rapide.
\end{minted}
\end{frame}
\begin{frame}
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
Évidemment, dans la situation décrite, peu de modifications mais imbriquées, un résultat équivalent mais plus rapidement obtenu avec :
\begin{enumerate}[<+->]
\item \commande{git reset \$(git merge-base --fork-point master)}
\item \commande{git add -i}
\end{enumerate}
\end{frame}
\begin{frame}
\frametitle{Travail collaboratif}
\framesubtitle{Nettoyage}
\begin{minipage}{\textwidth}
\begin{tikzpicture}
%\begin{pgflowlevelscope}{\pgftransformscale{0.5}}
\begin{pgflowlevel}{\pgftransformscale{0.6}}
\gitDAG[grow right sep=1em]{
fcacc8a -- a3a980c -- {902ae87}
};
\gitbranch
{brancheindiscrete}
{above=of 902ae87}
{902ae87}
%\end{pgflowlevelscope}
\end{pgflowlevel}
\end{tikzpicture}
\end{minipage}
Il ne reste plus qu'à purger les \emph{commit} de tous les fichiers embarrassants, ajoutés par inadvertance.
\begin{enumerate}[<+->]
\item \commande{git checkout branche\_indiscrete}
\item \commande{git filter-branch --tree-filter "git rm password" master..}
\end{enumerate}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Travail collaboratif}
\framesubtitle{Partager}
Reprendre les exercices en incluant les commandes push, pull et fetch.
Côté serveur, tester les hooks.
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,4 +0,0 @@
\begin{frame}
\frametitle{}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Exercice}
\framesubtitle{Intégration dans les processus}
git est intégré dans divers processus, notamment les processus de packaging.
Cet exercice donne un aperçu d'une telle intégration dans le cas du packaging debian.
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,35 +0,0 @@
\begin{frame}
\frametitle{Packaging debian}
\framesubtitle{buildpackage}
buildpackage regroupe les outils simplifiant le packaging debian basé sur des sources maintenues en dépôts git.
\commande{apt-get install git-buildpackage}
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Packaging debian}
\framesubtitle{patchs}
gbp-pq est la commande permettant de faire correspondre les commit d'une branche aux patchs d'un paquet.
Depuis la branche de packaging :
\commande{gbp-pq import}
Après modification du code et organisation en commit :
\commande{gbp-pq export}
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Packaging debian}
\framesubtitle{changelog}
git dch permet d'automatiser l'écriture du changelog en se basant sur les commit.
\commande{git dch}
% contenu (pas trop long) de la diapositive
\end{frame}
\begin{frame}
\frametitle{Packaging debian}
\framesubtitle{description du paquet}
Finalement, git buildpackage produit les fichiers nécessaires à la construction du paquet : .dsc, archive des sources, etc.
\commande{apt-get install git-buildpackage}
% contenu (pas trop long) de la diapositive
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Installer git}
\framesubtitle{sur les systèmes d'exploitation GNU/Linux}
\begin{itemize}
\item apt-get, dnf, emerge, pacman, zypper, \ldots{}
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Installer git}
\framesubtitle{sur les systèmes d'exploitation Apple}
\begin{itemize}
\item \url{http://git-scm.com/download/mac}
\item \url{https://mac.github.com/}
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Installer git}
\framesubtitle{sur les systèmes d'exploitation Microsoft©}
\begin{itemize}
\item \url{http://git-scm.com/download/win}
\item \url{https://windows.github.com/}
\end{itemize}
\end{frame}

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Git en un mot}
\begin{itemize}
\item projet créé en 2005
\item sous licence GPLv2
\item gère le code source du noyau linux
\item est multiplateforme
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Références}
\begin{itemize}
\item \url{http://www.git-scm.com/docs}
\item Pro-git, S. Chacon et B. Straub, Apress, 2014
\item les pages de man : gitcore-tutorial, gitworkflows, gitcvs-migration
\end{itemize}
\end{frame}

View File

@ -1,11 +0,0 @@
\begin{frame}
\frametitle{Ce que cache le dépôt git}
\begin{description}[répertoire de travail]
\item[.git]<1-> Les objets et la configuration locale du dépôt git
\item[répertoire de travail]<2-> Une arborescence de fichiers accessible à l'édition, le bac à sable
\item[index]<3-> Les changements candidats à l'archivage
\item[HEAD]<4-> Le dernier état archivé
\item[stash]<5-> Une zone tampon pour les modifications à mettre momentanément de côté
\end{description}
\skbinput[from=fig]{apps/git_trees}
\end{frame}

View File

@ -1,7 +0,0 @@
\begin{frame}
\frametitle{Serveur de dépôts git}
\framesubtitle{Serveur basique ssh}
Ajout des clés des utilisateurs au fichier ~/.ssh/authorized\_keys de l'utilisateur administrant les dépôts.
Préciser l'utilisation d'un shell restreint, git-shell, pour limiter les droits (\commande{chsh git /usr/bin/git-shell}).
\end{frame}

View File

@ -1,10 +0,0 @@
\begin{frame}
\frametitle{Serveur de dépôts git}
\framesubtitle{GitLab}
Application combinant un serveur de dépôts git avec une interface web conviviale.
\begin{itemize}
\item Gestion des utilisateurs
\item Navigation dans les dépôts
\item Gestion des évènements git et web
\end{itemize}
\end{frame}

View File

@ -1,11 +0,0 @@
\begin{frame}
\frametitle{Serveur de dépôts git}
\framesubtitle{gitolite}
Application de gestion de dépôts git sans interface graphique
\begin{itemize}
\item Gestion des utilisateurs
\item Accès par ssh
\item Gestion fine des droits
\item Gestion sous la forme d'un dépôt git
\end{itemize}
\end{frame}

View File

@ -1,10 +0,0 @@
\begin{frame}
\frametitle{Serveur de dépôts git}
\framesubtitle{Gogs}
Application combinant un serveur de dépôts git avec une interface web conviviale.
\begin{itemize}
\item Gestion des utilisateurs
\item Navigation dans les dépôts
\item Gestion des évènements git et web
\end{itemize}
\end{frame}

View File

@ -1,8 +0,0 @@
\begin{frame}
\frametitle{Des branches pour étayer le tronc}
\begin{itemize}
\item maintenir l'histoire du code lisible
\item faciliter les divergences
\item éphémères ou pérennes
\end{itemize}
\end{frame}

View File

@ -1,9 +0,0 @@
\begin{frame}
\frametitle{Un processus bien documenté}
\begin{description}
\item[git-flow] une démarche de développement tirant parti des capacités de git.
\end{description}
\begin{exampleblock}{}
\small{\url{http://nvie.com/posts/a-successful-git-branching-model/}}
\end{exampleblock}
\end{frame}

View File

@ -1,15 +0,0 @@
\begin{frame}
\frametitle{Processus de Vincent Driessen}
\begin{columns}
\begin{column}{0.5\textwidth}
\begin{itemize}
\item Des branches \emph{master} et \emph{develop} pour le code fonctionnel
\item Des branches pour les développements en cours
\item Un circuit entre les branches bien fléché
\end{itemize}
\end{column}
\begin{column}{0.5\textwidth}
\skbfigure[center, figure, caption=Vincent Driessen CC-by-sa, height=0.5\textheight]{scm/git-model@2x.png}
\end{column}
\end{columns}
\end{frame}

View File

@ -1,12 +0,0 @@
\skbheading{Équipements personnels utilisés}
Utilisez-vous des équipements personnels (smartphone, ordinateur) ?
\ChoiceMenu[radio,radiosymbol=\ding{52},name=utilisation_equipement_personnel]{}{oui}
\ChoiceMenu[radio,radiosymbol=\ding{52},name=utilisation_equipement_personnel]{}{non}
Si vous avez répondu oui à la question précédente, pourquoi utilisez-vous un équipement personnel ?
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par commodité}
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par obligation}
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par nécessité}

View File

@ -1,2 +0,0 @@
\skbheading{equipement\_personnel\_utilises\_oui\_non.tex}
fichier content/questions/equipement/equipement\_personnel\_utilises\_oui\_non.tex à éditer

View File

@ -1,12 +0,0 @@
\skbheading{Équipements utilisés}
Utilisez-vous plusieurs équipements (smartphone, ordinateur) ?
\ChoiceMenu[radio,radiosymbol=\ding{52},name=utilisation_equipement_personnel]{}{oui}
\ChoiceMenu[radio,radiosymbol=\ding{52},name=utilisation_equipement_personnel]{}{non}
Si vous avez répondu oui à la question précédente, pourquoi utilisez-vous plusieurs équipements ?
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par commodité}
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par obligation}
\ChoiceMenu[bordercolor=CadolesBlue,radio,radiosymbol=\ding{52},name=pourquoi_equipement_personnel]{}{par nécessité}

View File

@ -1,9 +0,0 @@
\skbheading{Type daccès aux services numériques}
Depuis quel endroit avez-vous accès aux services numériques ?
\begin{center}
\ChoiceMenu[radio,radiosymbol=\ding{52},name=ou_service]{}{depuis mon établissement}
\ChoiceMenu[radio,radiosymbol=\ding{52},name=ou_service]{}{depuis mon domicile}
\ChoiceMenu[radio,radiosymbol=\ding{52},name=ou_service]{}{depuis les deux}
\end{center}

View File

@ -1,2 +0,0 @@
\skbheading{attentes\_ameliorations.tex}
fichier content/questions/services/attentes\_ameliorations.tex à éditer

Some files were not shown because too many files have changed in this diff Show More