Update to the new library 'json2'
[euphorik.git] / modules / erl / euphorik_daemon.erl
index 274a2c2..190458e 100755 (executable)
 %\r
 % You should have received a copy of the GNU General Public License\r
 % along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
-% \r
-% Module tournant en background s'occupant periodiquement de certaines tâches :
-%  - sélection du prochain troll chaque semaine\r
+%\r
+% Module tournant en background s'occupant periodiquement de certaines tâches :\r
 %  - rechargement des modules lors d'une mise en production\r
-% Date : 05.11.2007
-% @author G.Burri\r
 \r
 \r
--module(euphorik_daemon).
--export([start/1, reload_euphorik/0, loop/0]).
--include("../include/euphorik_defines.hrl").
+-module(euphorik_daemon).\r
+-author("Greg Burri <greg.burri@gmail.com>").\r
+-export([start/1, reload_euphorik/0, loop/0]).\r
+-include("../include/euphorik_defines.hrl").\r
+\r
 \r
-
-% Démarre le démon
+% Démarre le démon\r
 start(_A) ->\r
    register(euphorik_daemon, self()),\r
-   loop().
-   \r
-   
-loop() ->
-   % on attend une minute de plus pour prevenir une dérive négative (ce qui pourrait engendrer une double élection)\r
+   loop().\r
+\r
+\r
+loop() ->\r
    receive\r
-      switch -> % permet de substituer le code du process par un nouveau code, voir reload_euphorik\r
-         euphorik_daemon:loop()    \r
-      after 1000 * (trunc(temps_prochaine_election() + 60)) ->\r
-         euphorik_bd:elire_troll(),\r
+      switch -> % To reload a new code, see 'reload_euphorik/0'.\r
          euphorik_daemon:loop()\r
-   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'é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
-      ]
+   end.\r
+\r
+% Recharge tous les modules euphorik.\r
+% Appelé lors d'une mise en prod.\r
+% TODO : récupérer les noms à partir des .beam dans /modules/ebin\r
+reload_euphorik() ->\r
+   lists:foreach(\r
+      fun(M) ->\r
+         c:l(M) % (purge & load)\r
+      end,\r
+      [\r
+         euphorik_common,\r
+         euphorik_minichat_conversation,\r
+         euphorik_protocole,\r
+         euphorik_requests,\r
+         euphorik_bd,\r
+         euphorik_bd_admin,\r
+         euphorik_daemon\r
+      ]\r
    ),\r
    % changement du code du daemon\r
-   euphorik_daemon ! switch.
-   
\ No newline at end of file
+   euphorik_daemon ! switch,\r
+   ok.\r