X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_daemon.erl;h=274a2c2ee0bc86be6ddb391bbda4f383db8a13af;hp=4e5d4eda28557ab8e618d6896abd4c45e6f8a108;hb=accd9081eade01ce5ebf6b54cd6f29f55f3641a7;hpb=bde82d4691e6bb96f841307b8e2771cec5996e5d diff --git a/modules/erl/euphorik_daemon.erl b/modules/erl/euphorik_daemon.erl index 4e5d4ed..274a2c2 100755 --- a/modules/erl/euphorik_daemon.erl +++ b/modules/erl/euphorik_daemon.erl @@ -18,32 +18,62 @@ % % Module tournant en background s'occupant periodiquement de certaines tâches : % - sélection du prochain troll chaque semaine +% - rechargement des modules lors d'une mise en production % Date : 05.11.2007 % @author G.Burri -module(euphorik_daemon). --export([start/1]). +-export([start/1, reload_euphorik/0, loop/0]). -include("../include/euphorik_defines.hrl"). - + % Démarre le démon start(_A) -> + register(euphorik_daemon, self()), loop(). loop() -> - % on attend une minute de plus pour prevenir une dérive nétive - timer:sleep(1000 * trunc(temps_prochaine_election() + 60)), - euphorik_bd:elire_troll(), - loop(). - + % on attend une minute de plus pour prevenir une dérive négative (ce qui pourrait engendrer une double élection) + receive + switch -> % permet de substituer le code du process par un nouveau code, voir reload_euphorik + euphorik_daemon:loop() + after 1000 * (trunc(temps_prochaine_election() + 60)) -> + euphorik_bd:elire_troll(), + euphorik_daemon:loop() + end. + % Renvoie le nombre de seconde qu'il reste jusque au prochain lundi à l'heure donnée (l'heure est sur 24heures) % 86400 est le nombre de seconde dans un jour temps_prochaine_election() -> {Date, {H,M,S}} = calendar:local_time(), Delta = (?JOUR_ELECTION_TROLL - 1) * 86400 + ?HEURE_ELECTION_TROLL * 60 * 60 - -((calendar:day_of_the_week(Date) - 1) * 86400 + H * 60 * 60 + M * 60 + S), - % attention au cas où deux dates (maintenant et la date d'éction) ne se trouvent pas dans la même semaine. + -((calendar:day_of_the_week(Date) - 1) * 86400 + H * 60 * 60 + M * 60 + S), + % attention au cas où deux dates (maintenant et la date d'élection) ne se trouvent pas dans la même semaine. if Delta =< 0 -> Delta + 7 * 86400; true -> Delta end. + + +% Recharge tous les modules euphorik. +% Appelé lors d'une mise en prod. +% TODO : récupérer les noms à partir des .beam dans /modules/ebin +reload_euphorik() -> + lists:foreach( + fun(M) -> + code:purge(M), + code:load_file(M) + end, + [ + euphorik_common, + euphorik_minichat_conversation, + euphorik_protocole, + euphorik_requests, + euphorik_bd, + euphorik_bd_update, + euphorik_daemon + ] + ), + % changement du code du daemon + euphorik_daemon ! switch. + \ No newline at end of file