2016-03-07 12:11:48 +00:00
*Contribuer c'est la vie*
2016-03-07 12:31:38 +00:00
=========================
Hey ! Tu veux devenir un mec bien et en plus devenir bon en python si tu l'es pas déjà ?
Il se trouve que le sith AE prévu pour l'été 2016 a besoin de toi !
2016-03-07 12:34:22 +00:00
2018-10-05 20:30:54 +00:00
Pour faire le sith, on utilise le framework Web [Django ](https://docs.djangoproject.com/fr/1.11/intro/ )
2016-03-07 12:31:38 +00:00
N'hésite pas à lire les tutos et à nous demander (ae.info@utbm.fr).
2016-11-06 11:32:29 +00:00
Bon, passons aux choses sérieuses, pour bidouiller le sith sans le casser :
2016-03-07 12:31:38 +00:00
Ben en fait, tu peux pas le casser, tu vas juste t'amuser comme un petit fou sur un clone du sith.
2016-03-07 12:34:22 +00:00
C'est pas compliqué, il suffit d'avoir [Git ](http://www.git-scm.com/book/fr/v2 ), python et pip (pour faciliter la gestion des paquets python).
2016-11-06 11:32:29 +00:00
Tout d'abord, tu vas avoir besoin d'un compte Gitlab pour pouvoir te connecter.
2016-03-07 12:31:38 +00:00
Ensuite, tu fais :
`git clone https://ae-dev.utbm.fr/ae/Sith.git`
Avec cette commande, tu clones le sith AE dans le dossier courant.
2018-10-05 21:18:35 +00:00
```bash
2018-12-05 21:15:20 +00:00
cd Sith
2018-12-18 22:16:00 +00:00
virtualenv --system-site-packages --python=python3 env
2018-12-05 21:15:20 +00:00
source env_sith/bin/activate
pip install -r requirements.txt
2018-10-05 21:18:35 +00:00
```
2016-11-03 14:32:56 +00:00
2018-12-05 21:15:20 +00:00
Attention aux dépendances système, à voir dans le README.md
2016-11-03 14:32:56 +00:00
Maintenant, faut passer le sith en mode debug dans le fichier de settings personnalisé.
2018-10-05 21:18:35 +00:00
```bash
2018-12-05 21:15:20 +00:00
echo "DEBUG=True" > sith/settings_custom.py
echo 'EXTERNAL_RES = "False"' >> sith/settings_custom.py
echo 'SITH_URL = "localhost:8000"' >> sith/settings_custom.py
2018-10-05 21:18:35 +00:00
```
2016-11-03 14:32:56 +00:00
2016-11-03 23:03:36 +00:00
Enfin, il s'agit de créer la base de donnée de test lors de la première utilisation
2016-11-03 14:32:56 +00:00
2018-10-05 21:18:35 +00:00
```bash
2018-12-05 21:15:20 +00:00
./manage.py setup
2018-10-05 21:18:35 +00:00
```
2016-03-07 12:31:38 +00:00
2016-03-07 12:34:22 +00:00
Et pour lancer le sith, tu fais `python3 manage.py runserver`
2016-03-07 12:31:38 +00:00
2016-11-03 14:32:56 +00:00
Voilà, c'est le sith AE. Il y a des issues dans le gitlab qui sont à régler. Si tu as un domaine qui t'intéresse, une appli que tu voudrais développer, n'hésites pas et contacte-nous.
2016-11-03 18:57:41 +00:00
Va, et que l'AE soit avec toi.
2018-10-05 21:18:35 +00:00
# Black
Pour uniformiser le formattage du code nous utilisons [Black ](https://github.com/ambv/black ). Cela permet d'avoir le même codestyle et donc le codereview prend moins de temps. Tout étant dans le même format, il est plus facile pour chacun de comprendre le code de chacun ! Cela permet aussi d'éviter des erreurs (y parait 🤷♀️).
2018-10-05 21:03:45 +00:00
Installation de black:
2018-10-05 21:18:35 +00:00
```bash
2018-12-05 21:15:20 +00:00
pip install black
2018-10-05 21:18:35 +00:00
```
## Sous VsCode:
Attention, pour VsCode, Black doit être installé dans votre virtualenv !
2018-10-05 21:03:45 +00:00
Ajouter ces deux lignes dans les settings de VsCode
2018-10-05 21:18:35 +00:00
```json
{
2018-10-05 21:03:45 +00:00
"python.formatting.provider": "black",
2018-10-05 21:18:35 +00:00
"editor.formatOnSave": true
}
```
## Sous Sublime Text
Il faut installer le plugin [sublack ](https://packagecontrol.io/packages/sublack ) depuis Package Control.
Il suffit ensuite d'ajouter dans les settings du projet (ou en global)
```json
{
"sublack.black_on_save": true
}
```
Si vous utilisez le plugin [anaconda ](http://damnwidget.github.io/anaconda/ ), pensez à modifier les paramètres du linter pep8 pour éviter de recevoir des warnings dans le formatage de black
```json
{
"pep8_ignore": [
"E203",
"E266",
"E501",
"W503"
]
}
```
2018-10-05 21:03:45 +00:00
2016-11-03 18:58:58 +00:00
Sites et doc cools
------------------
2016-11-03 18:57:41 +00:00
2018-10-05 20:30:54 +00:00
[Classy Class-Based Views ](http://ccbv.co.uk/projects/Django/1.11/ )
2017-04-24 15:35:39 +00:00
Helpers:
`./manage.py makemessages --ignore "env/*" -e py,jinja`
2017-04-24 15:51:12 +00:00
`for f in $(find . -name "*.py" ! -path "*migration*" ! -path "./env/*" ! -path "./doc/*"); do cat ./doc/header "$f" > /tmp/temp && mv /tmp/temp "$f"; done`
2017-04-24 15:35:39 +00:00