X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_daemon.erl;h=51f224e2ec4f69a14ef9c8f5de6b0c4887fe2cb4;hb=df40c17f94b92c8e60331395610428868f0993be;hp=4e5d4eda28557ab8e618d6896abd4c45e6f8a108;hpb=bde82d4691e6bb96f841307b8e2771cec5996e5d;p=euphorik.git diff --git a/modules/erl/euphorik_daemon.erl b/modules/erl/euphorik_daemon.erl index 4e5d4ed..51f224e 100755 --- a/modules/erl/euphorik_daemon.erl +++ b/modules/erl/euphorik_daemon.erl @@ -23,12 +23,14 @@ -module(euphorik_daemon). --export([start/1]). +-export([start/1, reload_euphorik/0]). -include("../include/euphorik_defines.hrl"). % Démarre le démon -start(_A) -> +start(_A) -> + % dossier utilisé lors de gros trie par qlc, voir qlc:keysort() + file:set_cwd("/tmp"), loop(). @@ -36,8 +38,8 @@ 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(). - + euphorik_daemon:loop(). + % 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 @@ -47,3 +49,18 @@ temps_prochaine_election() -> -((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. 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_minichat_conversation, euphorik_protocole, euphorik_requests, euphorik_bd, euphorik_daemon] + ). + +