MOD cleanage euphorik.js (attention un début du code pour la gestion des pages traine)
[euphorik.git] / modules / erl / euphorik_bd.erl
index 1cd534e..f2acb7a 100755 (executable)
@@ -179,7 +179,7 @@ update_pseudo_user(UserId, Pseudo) ->
 user_by_cookie(Cookie) ->\r
    resultat_transaction(mnesia:transaction(\r
       fun() ->\r
-         case e(q([E || E <- mnesia:table(user), E#user.cookie =:= Cookie]), [{tmpdir, ?KEY_SORT_TEMP_DIR}]) of\r
+         case mnesia:index_read(user, Cookie, #user.cookie) of\r
             [User] -> {ok, User};\r
             _ -> erreur\r
          end\r
@@ -455,33 +455,45 @@ enfants(M_id) ->
    )).\r
    \r
    \r
-% Renvoie les parents d'un message M (les messages auquels répond M)\r
+% Renvoie les id des parents d'un message M (les messages auquels répond M)\r
 % ordrés du plus petit au plus grand..\r
+% On évite d'utiliser qlc pour des raisons de performance\r
 % @spec parents_id(integer()) -> [integer()]\r
-parents_id(M) ->\r
+parents_id(M_id) ->\r
    resultat_transaction(mnesia:transaction(fun() ->\r
-      e(\r
-         qlc:sort(\r
-            q([E#reponse_minichat.cible || E <- mnesia:table(reponse_minichat), E#reponse_minichat.repondant =:= M]),\r
-            [{order, ascending}]\r
-         ),\r
-         [{tmpdir, ?KEY_SORT_TEMP_DIR}]\r
-      )\r
+      case mnesia:read({reponse_minichat, M_id}) of\r
+         Parents when is_list(Parents) ->\r
+            lists:sort(lists:map(\r
+               fun(#reponse_minichat{cible = Cible}) -> Cible end,\r
+               Parents\r
+            ));\r
+         _ -> []            \r
+      end\r
    end)).\r
    \r
    \r
 % Renvoie les id des enfants d'un message M (les messages qui répondent à M)\r
 % ordrés du plus petit au plus grand.\r
 % @spec enfants_id(integer()) -> [integer()]\r
-enfants_id(M) ->\r
+enfants_id(M_id) ->\r
+%   resultat_transaction(mnesia:transaction(fun() ->\r
+%      e(\r
+%         qlc:sort(\r
+%            q([E#reponse_minichat.repondant || E <- mnesia:table(reponse_minichat), E#reponse_minichat.cible =:= M]),\r
+%            [{order, ascending}]\r
+%         ),\r
+%         [{tmpdir, ?KEY_SORT_TEMP_DIR}]\r
+%      )\r
+%   end)).\r
    resultat_transaction(mnesia:transaction(fun() ->\r
-      e(\r
-         qlc:sort(\r
-            q([E#reponse_minichat.repondant || E <- mnesia:table(reponse_minichat), E#reponse_minichat.cible =:= M]),\r
-            [{order, ascending}]\r
-         ),\r
-         [{tmpdir, ?KEY_SORT_TEMP_DIR}]\r
-      )\r
+      case mnesia:index_read(reponse_minichat, M_id, #reponse_minichat.cible) of\r
+         Enfants when is_list(Enfants) ->\r
+            lists:sort(lists:map(\r
+               fun(#reponse_minichat{repondant = Repondant}) -> Repondant end,\r
+               Enfants\r
+            ));\r
+         _ -> []            \r
+      end\r
    end)).\r
      \r
 \r
@@ -512,7 +524,7 @@ est_une_reponse_a_user(Id_user, Id_mess) ->
 a_repondu_a_message(Id_user, Id_mess) ->\r
    resultat_transaction(mnesia:transaction(\r
       fun() ->\r
-         case mnesia:match_object({reponse_minichat, '_', Id_mess}) of\r
+         case mnesia:index_read(reponse_minichat, Id_mess, #reponse_minichat.cible) of\r
             [] -> false;\r
             Reponses ->\r
                lists:any(\r