source: spip-zone/_core_/branches/spip-3.0/plugins/mots/mots_administrations.php @ 71848

Last change on this file since 71848 was 71848, checked in by marcimat@…, 7 years ago

Sur les traces de http://core.spip.org/projects/spip/repository/revisions/20410 , ajouter un index nécessite ADD INDEX, pas seulement ADD.

File size: 3.3 KB
Line 
1<?php
2
3/***************************************************************************\
4 *  SPIP, Systeme de publication pour l'internet                           *
5 *                                                                         *
6 *  Copyright (c) 2001-2013                                                *
7 *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
8 *                                                                         *
9 *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
10 *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
11\***************************************************************************/
12
13if (!defined('_ECRIRE_INC_VERSION')) return;
14
15/**
16 * Installation/maj des tables mots et groupes de mots...
17 *
18 * @param string $nom_meta_base_version
19 * @param string $version_cible
20 */
21function mots_upgrade($nom_meta_base_version,$version_cible){
22
23        // cas particulier :
24        // si plugin pas installe mais que la table existe
25        // considerer que c'est un upgrade depuis v 1.0.0
26        // pour gerer l'historique des installations SPIP <=2.1
27        if (!isset($GLOBALS['meta'][$nom_meta_base_version])){
28                $trouver_table = charger_fonction('trouver_table','base');
29                if ($desc = $trouver_table('spip_mots')
30                  AND isset($desc['exist'])
31                  AND $desc = $trouver_table('spip_mots_articles')
32                        AND isset($desc['exist'])){
33                        ecrire_meta($nom_meta_base_version,'1.0.0');
34                }
35                // si pas de table en base, on fera une simple creation de base
36        }
37
38        $maj = array();
39        $maj['create'] = array(
40                array('maj_tables',array('spip_groupes_mots','spip_mots','spip_mots_liens')),
41        );
42        $maj['1.0.0'] = array(
43                array('maj_tables',array('spip_groupes_mots','spip_mots','spip_mots_liens')),
44        );
45        include_spip('maj/svn10000');
46        $maj['2.0.0'] = array(
47                array('maj_liens','mot'), // creer la table liens
48                array('maj_liens','mot','breve'),
49                array('sql_drop_table',"spip_mots_breves"),
50                array('maj_liens','mot','rubrique'),
51                array('sql_drop_table',"spip_mots_rubriques"),
52                array('maj_liens','mot','syndic'),
53                array('sql_drop_table',"spip_mots_syndic"),
54                array('maj_liens','mot','forum'),
55                array('sql_drop_table',"spip_mots_forum"),
56                array('maj_liens','mot','auteur'),
57                array('sql_drop_table',"spip_mots_auteurs"),
58                array('maj_liens','mot','document'),
59                array('sql_drop_table',"spip_mots_documents"),
60                array('maj_liens','mot','article'),
61                array('sql_drop_table',"spip_mots_articles"),
62        );
63        $maj['2.0.1'] = array(
64                array('sql_updateq',"spip_mots_liens",array('objet'=>'site'),"objet='syndic'"),
65        );
66        $maj['2.1.0'] = array(
67                array('sql_alter',"TABLE spip_mots_liens ADD INDEX id_objet (id_objet)"),
68                array('sql_alter',"TABLE spip_mots_liens ADD INDEX objet (objet)"),
69        );
70        $maj['2.1.1'] = array(
71                array('sql_alter',"TABLE spip_mots ADD INDEX id_groupe (id_groupe)")
72        );
73
74        include_spip('base/upgrade');
75        maj_plugin($nom_meta_base_version, $version_cible, $maj);
76}
77
78
79/**
80 * Desinstallation/suppression des tables mots et groupes de mots
81 *
82 * @param string $nom_meta_base_version
83 */
84function mots_vider_tables($nom_meta_base_version) {
85        sql_drop_table("spip_mots");
86        sql_drop_table("spip_groupes_mots");
87        sql_drop_table("spip_mots_liens");
88       
89        effacer_meta('articles_mots');
90        effacer_meta('config_precise_groupes');
91       
92        effacer_meta($nom_meta_base_version);
93}
94
95?>
Note: See TracBrowser for help on using the repository browser.