FIX #88
[euphorik.git] / modules / erl / euphorik_bd_admin.erl
index 66427d3..dca6c2d 100644 (file)
@@ -85,7 +85,6 @@ create_tables() ->
       {disc_copies, [node()]}
    ]),
    mnesia:create_table(minichat, [
-      {type, ordered_set},
       {attributes, record_info(fields, minichat)},
       {disc_copies, [node()]}
    ]),
@@ -269,13 +268,7 @@ patch(1) ->
       {atomic, _} -> ok
    end;\r
 % 2 -> 3\r
-patch(2) ->
-   % première étape : changer le type de la table minichat de set à ordered_set
-   % TODO : trouver un meilleur moyen que de passer par un backup
-   backup("tmp"),
-   create(),
-   restore("tmp"),
-   file:delete(dossier_backups() ++ "tmp"),\r
+patch(2) ->\r
    mnesia:transform_table(\r
       troll,\r
       fun({troll, Id_troll, Id_user, Date_create, Date_post, Content}) ->\r
@@ -292,10 +285,25 @@ patch(2) ->
    mnesia:transform_table(\r
       minichat,\r
       fun({minichat, Id, Auteur_id, Date, Pseudo, Contenu, _Troll_id, Racine_id}) ->\r
-         {minichat, Id, Auteur_id, Date, Pseudo, Contenu, Racine_id}\r
+         {minichat, Id, Auteur_id, Date, Pseudo, Contenu, Racine_id, normal}\r
       end,\r
       record_info(fields, minichat)\r
-   ),\r
+   ),
+   mnesia:transaction(fun() ->
+      % comble les trous entre les id non-contigues
+      lists:foreach(fun(Id) ->
+            case mnesia:read({minichat, Id}) of
+               [] -> 
+                  {ok, #user{profile = Profile}} = euphorik_bd:user_by_id(0),
+                  mnesia:write(#minichat{id = Id, auteur_id = 0, date = undefined, pseudo = Profile#profile.pseudo, contenu = "Comblement...", racine_id = Id, status = deleted});
+               _ -> rien
+            end
+         end,
+         lists:seq(1, mnesia:table_info(minichat, size))
+      ),
+      % la table troll utilise maintenant son index et pas celui de la table minichat (correction d'un vieux bug)
+      mnesia:write(#counter{key = troll, value = mnesia:table_info(minichat, size)})
+   end),\r
    creer_indexes(). % uniquement pour l'indice sur id_minichat de la table troll\r