{disc_copies, [node()]}
]),
mnesia:create_table(minichat, [
- {type, ordered_set},
{attributes, record_info(fields, minichat)},
{disc_copies, [node()]}
]),
{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
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