==============
``timetables``
==============

``timetables`` met à jour les emplois du temps présents dans la base
de données.

Il est fortement recommandé d’exécuter régulièrement cette commande
:ref:`à l’aide d’une tâche cron <ref-cron>`.

Utilisation
===========
.. code:: shell

    $ ./manage.py timetables [--all] [--force] [--week week] [--year year]

Par défaut, ``timetables`` met à jour seulement la semaine courante ou
à venir le week-end, et ne met pas à jour si la dernière mise à jour
présente dans la base de données est plus récente que celle présente
dans la source. Les différents paramètres permettent de contrôler ce
comportement :

``--all`` permet de mettre à jour toutes les semaines présentes dans
la source.

``--force`` force la mise à jour, même si la dernière mise à jour des
emplois du temps présente dans la base de données est plus récente que
celle présente dans la source.

``--week`` permet de spécifier la semaine à mettre à jour.

``--year`` permet de spécifier l’année à mettre à jour.

Comportement
============
Pour chaque emploi du temps, ``timetables`` récupère la source,
supprime les cours sur la période couverte par cette mise à jour,
parse la source et insère les cours dans la base de données.

Cette mise à jour est effectuée de manière transactionnelle : si la
mise à jour d’une source échoue au milieu du processus, les données
supprimées au début seront entièrement restaurées, les données
rajoutées seront supprimées, et une erreur sera affichée. Cela
n’affecte pas la mise à jour des autres emplois du temps.