summaryrefslogtreecommitdiff
path: root/includes/db_schema
diff options
context:
space:
mode:
authorfisharebest <fisharebest@gmail.com>2010-12-06 12:19:10 +0000
committerfisharebest <fisharebest@gmail.com>2010-12-06 12:19:10 +0000
commit26f92a684d0791d09291821aa4ae743caf954027 (patch)
treeec44d4b98a30244ef87458e873848ea56d95c4e9 /includes/db_schema
parent258f5a918dff227f5ed9fe4ef803952e103480d9 (diff)
downloadwebtrees-26f92a684d0791d09291821aa4ae743caf954027.tar.gz
webtrees-26f92a684d0791d09291821aa4ae743caf954027.tar.bz2
webtrees-26f92a684d0791d09291821aa4ae743caf954027.zip
Add support for sorting gedcoms in user-defined order
Diffstat (limited to 'includes/db_schema')
-rw-r--r--includes/db_schema/db_schema_4_5.php86
1 files changed, 86 insertions, 0 deletions
diff --git a/includes/db_schema/db_schema_4_5.php b/includes/db_schema/db_schema_4_5.php
new file mode 100644
index 0000000000..8993b174cd
--- /dev/null
+++ b/includes/db_schema/db_schema_4_5.php
@@ -0,0 +1,86 @@
+<?php
+/**
+ * Update the database schema from version 4 to version 5
+ * - add support for sorting gedcoms non-alphabetically
+ *
+ * Also clean out some old/unused values and files.
+ *
+ * The script should assume that it can be interrupted at
+ * any point, and be able to continue by re-running the script.
+ * Fatal errors, however, should be allowed to throw exceptions,
+ * which will be caught by the framework.
+ * It shouldn't do anything that might take more than a few
+ * seconds, for systems with low timeout values.
+ *
+ * phpGedView: Genealogy Viewer
+ * Copyright (C) 2010 Greg Roach
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ * @version $Id$
+ */
+
+if (!defined('WT_WEBTREES')) {
+ header('HTTP/1.0 403 Forbidden');
+ exit;
+}
+
+define('WT_DB_SCHEMA_4_5', '');
+
+try {
+ self::exec("ALTER TABLE `##gedcom` ADD COLUMN sort_order INTEGER NOT NULL DEFAULT 0");
+} catch (PDOException $ex) {
+ // If this fails, it has probably already been done.
+}
+
+try {
+ self::exec("ALTER TABLE `##gedcom` ADD INDEX ix1 (sort_order)");
+} catch (PDOException $ex) {
+ // If this fails, it has probably already been done.
+}
+
+// No longer used
+self::exec("DELETE FROM `##gedcom_setting` WHERE setting_name IN ('PAGE_AFTER_LOGIN')");
+
+// Change of defaults - do not add ASSO, etc. to NOTE objects
+self::exec("UPDATE `##gedcom_setting` SET setting_value='SOUR' WHERE setting_value='ASSO,SOUR,NOTE,REPO' AND setting_name='NOTE_FACTS_ADD'");
+
+// Update the version to indicate success
+set_site_setting($schema_name, $next_version);
+
+// We may not have permission to do this. But we can try....
+// Removed in 1.0.2
+@unlink(WT_ROOT.'includes/classes/class_geclippings.php');
+@unlink(WT_ROOT.'includes/classes/class_gedownloadgedcom.php');
+@unlink(WT_ROOT.'includes/classes/class_gewebservice.php');
+@unlink(WT_ROOT.'includes/classes/class_grampsexport.php');
+@unlink(WT_ROOT.'language/en.mo');
+// Removed in 1.0.3
+@unlink(WT_ROOT.'themechange.php');
+// Removed in 1.0.4
+@unlink(WT_ROOT.'themes/fab/images/notes.gif');
+// Removed in 1.0.5
+@unlink(WT_ROOT.'modules/lightbox/functions/lb_indi_doors_0.php');
+@unlink(WT_ROOT.'modules/lightbox/functions/lb_indi_doors_1.php');
+@unlink(WT_ROOT.'modules/lightbox/functions/lb_indi_tabs_0.php');
+@unlink(WT_ROOT.'modules/lightbox/functions/lb_indi_tabs_1.php');
+// Removed in 1.0.6
+@unlink(WT_ROOT.'includes/set_gedcom_defaults.php');
+@unlink(WT_ROOT.'includes/functions/functions.ar.php');
+@unlink(WT_ROOT.'includes/functions/functions.en.php');
+@unlink(WT_ROOT.'includes/functions/functions.fr.php');
+@unlink(WT_ROOT.'includes/functions/functions.pl.php');
+@unlink(WT_ROOT.'includes/functions/functions.tr.php');
+@rmdir (WT_ROOT.'includes/extras');