# Documentation pour les développeurs ScoDoc Informations pour les développeurs souhaitant étendre ou modifier ScoDoc. ## Informations générales * S'abonner aux [listes de diffusion](ListesDeDiffusion.md). Il y a aussi un serveur Discord ouvert sur invitation aux développeur actifs. Contacter Emmanuel. * [Générer de nouveaux formats de bulletins PDF](ApiGenerationBulletinsPdf.md) * [Créer de nouveaux types de "parcours"](ApiCreationParcours.md) * [API](ScoDoc9API.md) : API JSON ou XML pour interfaçage avec d'autres applications * Notes diverses * [Discussions pour la future gestion des absences](IdeesGestionAbsences.md) * [Anciennes discussions sur la gestion des plannings](IdeesGestionPlannings.md) ## Développer sur ScoDoc Quelques conseils, indications et mémos pour les développeurs sur ScoDoc version 9. ### Installation d'un serveur de développement [Quelques conseils mouvants pour configurer votre serveur de développement](ConseilServeurDev.md) ### Style et formatage du code L'ancienneté de la base de code a rendu le style un peu incohérent, mais cela s'est amélioré avec ScoDoc 9 (respect PEP 8). Le code doit être formatté avec [`black`](https://black.readthedocs.io/) avant tout commit (configurez votre éditeur pour appeler `black` à l'enregistrement). #### Documentation On adoptera le style "Google": Exemple: """Description résumée de la fonction blah blah sur la fonction Args: table_handle: An open smalltable.Table instance. keys: A sequence of strings representing the key of each table row to fetch. String keys will be UTF-8 encoded. require_all_keys: Optional; If require_all_keys is True only rows with values set for all keys will be returned. Returns: A dict mapping keys to the corresponding table row data fetched. Each row is represented as a tuple of strings. For example: {b'Serak': ('Rigel VII', 'Preparer'), b'Zim': ('Irk', 'Invader'), b'Lrrr': ('Omicron Persei 8', 'Emperor')} """ ### Git Le dépôt est La branche `master` est celle de ScoDoc 9. La branche `Scodoc7` est l'ancienne (jusqu'à septembre 2021) version en production. Ci-dessous quelques pense-bête qui peuvent servir. #### Hot fixes (internes) Pour les développeurs internes (écriture sur le dépôt master), un exemple basique: # Créer une branche # si besoin (travail en cours), utiliser git stash avant git checkout master git branch hotfix git checkout hotfix ... dev, test ... git add ... git commit -m "fixed ..." git checkout master git merge hotfix git branch -d hotfix # publication # éventuellement: git stash pop #### Mettre à jour votre branche Vous travaillez dans votre branche `ma_branche`. Pour lui appliquer les mises à jour de `master` (remote): git pull origin master #### Commandes utiles, en vrac * `git log -L:fonction_python:fichier.py` * Commits locaux: `git log @{u}..` #### Refactoring Lint tous les fichiers modifiés: git status | grep modified | grep .py | awk '{print $2}' | xargs pylint -E Restore les modes au besoin (SAMBA les changent parfois): git diff -p -R --no-color | grep -E "^(diff|(old|new) mode)" --color=never | git apply Affiche les variables non définies dans un fichier: pylint --disable=all -e E sco_parcours_dut.py | grep undefined-variable | awk '{print $4;}' | sort | uniq | tr -d \' Prépare un sed pour renommer les variables non définies: for f in *.py do pylint --disable=all -e E "$f" | grep undefined-variable | awk '{print "sed -i .bak s/"$4"/scu."$4"/ '$f'";}' | sort | uniq | tr -d \' done Note pour travailler sur VirtualBox: addgroup scodoc vboxsf #### Préparation d'un PR ##### Principes généraux L'essentiel des remarques/procédures de cette section vise à obtenir une relecture facile des modifications: * Éviter les modifications de forme sans substance sémantique. L'utilisation de [`black`](https://black.readthedocs.io/) permet de normaliser la présentation du code. * Avoir un nombre d'étapes de validation faible (idéalement un seul commit pour les PR courantes (peu volumineuses) * La PR doit toujours être énoncé par rapport au dernier commit de la branche master officielle ##### Manipulations Les manipulations sont décrites selon 4 phases du développement: l'installation, la mise en place, le suivi, la livraison. ###### l'installation Il est pratique d'avoir en ligne les deux dépôt git distant que vous pouvez utiliser: votre dépôt personnel (`https://scodoc.org/git//.git`) et le dépôt officiel (`https://scodoc.org/git/ScoDoc/ScoDoc.git`) pour ajouter une référence (et lui donner un nom) vers un dépôt distant, envoyez la commande: ```git remote add nom_remote https://scodoc.org/git/ScoDoc/.git``` Par la suite vous aurez donc une référence vers votre dépôt personnel (`perso`) et une référence vers le dépôt officiel (`officiel`). L'un des deux si vous avez initialement cloné l'un des deux dépôts, la référence vers celui-ci existe et a pour nom `origin`. La commande vous exposant tous les dépôts connus est : `git remote -v` ##### Mise en place L'objectif de ce paragraphe est de créer une branche locale basée sur le master du dépôt officiel et bien sur de lui donner un nom. pour cela (attention cela va écraser les éventuels fichiers modifiés) ``` git reset --hard officiel/master git checkout -b ma_modif ``` À partir de la vous pouvez modifier, tester, développer, commit. ##### Suivi Si votre développement prend plusieurs jours, il est probable que la branche principale évolue pendant ce temps. Pour garder la cohérence, il est nécessaire de réintégrer en local les modifications de la branche principale. Ceci peut se faire de deux façons. - Une fusion (`merge`) applique toutes les modifications en une seul commit). C'est la méthode couramment utilisée - Un `rebase` rejoue tous les commits de la nouvelle branche par dessus l'état le plus à jour de la branche principal (il en résulte un historique plus linéaire) Les commandes git correspondantes: ``` git fetch officiel git merge officiel/master ``` ou ``` git fetch officiel git rebase officiel/merge ``` ##### La livraison Ça y est. vous avez terminé le développement. IL n'y a plus qu'à demander l'intégration. Ceci se fait en plusieurs étapes (vous êtes bien sûr toujours sur la branche locale `ma_modif`). ###### Étape 1 : faire l'inventaire des fichiers impliqués ``` git fetch officiel/master git diff --name-only officiel/master ``` ###### Étape 2 : passer black sur les fichiers modifiés Cette étape est automatique avec les bons réglages sous VSCode (pas trouvé l'équivalent sous *pyCharm*) À défaut les lignes suivantes réalisent le même travail: ``` for fn in $(git diff --name-only officiel/master) do python3 -m black $fn done ``` faire une première lecture rapide pour vérifier qu'il n'y ait pas de fichiers modifiés accidentellement. pour obtenir la modification sur un fichier spécifique (`app/fichier.py` par exemple) ``` git diff officiel/master app/fichier.py ``` Utilisateurs Windows: Vérifiez bien que les réglages de fin de ligne suivant bien les règles Linux (pas de CR ou `\r` en fin de ligne juste les LF `\n`). Le cas échéant réglez votre IDE pour cela À ce niveau là vous n'avez dans votre branche locales que les différences nécessaires à votre correctif. ###### Étape 3: résumez tous les commits depuis le point de divergence en un seul commit Repérez le point de divergence de votre branche locale avec officiel/master (normalement `git merge-base ma_branche officiel/master`) Demander un `rebase` interactif depuis ce point: ``` git rebase -i $(git merge-base HEAD officiel/master) ``` Vous devez obtenir dans un éditeur de texte la liste des commits opéré depuis le début du développement sous cette forme (c'est un exemple le nombre de lignes peut varier) ``` pick eb8cbec modif 1 pick 83eb79e modif 2 # Rebase 5ffd074..83eb79e onto 5ffd074 (2 commands) # # Commands: # p, pick = use commit # r, reword = use commit, but edit the commit message # e, edit = use commit, but stop for amending # s, squash = use commit, but meld into previous commit # f, fixup [-C | -c] = like "squash" but keep only the previous # commit's log message, unless -C is used, in which case # keep only this commit's message; -c is same as -C but # opens the editor # x, exec = run command (the rest of the line) using shell # b, break = stop here (continue rebase later with 'git rebase --continue') # d, drop = remove commit # l, label