forked from mkucej/i-librarian
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmigrate2.php
53 lines (48 loc) · 1.96 KB
/
migrate2.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<?php
//THIS SCRIPT UPGRADES I, LIBRARIAN DATABASES FROM 2.1 to 2.4 FORMAT
//ADD BIBTEX COLUMN TO TABLE LIBRARY AND SOME INDECES, UPGRADE AUTHORS
ignore_user_abort(true);
echo <<<EOT
<script type="text/javascript">
var div = parent.document.getElementById('first-loader').childNodes[1];
div.innerHTML = div.innerHTML + '<p style="font-size: 26px;">Please wait, upgrading…</p>';
</script>
EOT;
include_once 'data.php';
include_once 'functions.php';
function migrate_authors ($string) {
$result = '';
$array = array ();
$new_authors = array ();
$string = str_ireplace(' and ', ' , ', $string);
$array = explode(',', $string);
$array = array_filter($array);
if (!empty($array)) {
foreach ($array as $author) {
$author = trim($author);
$author = str_replace('"', '', $author);
$space = strpos($author, ' ');
if ($space === false) {
$last = trim($author);
$first = '';
} else {
$last = trim(substr($author, 0, $space));
$first = trim(substr($author, $space+1));
}
if (!empty($last)) $new_authors[] = 'L:"'.$last.'",F:"'.$first.'"';
}
if(count($new_authors) > 0) $result = join(';', $new_authors);
}
return $result;
}
database_connect(IL_DATABASE_PATH, 'library');
$dbHandle->sqliteCreateFunction('migrateauthors', 'migrate_authors', 1);
$dbHandle->beginTransaction();
$dbHandle->exec("ALTER TABLE library ADD COLUMN bibtex TEXT NOT NULL DEFAULT ''");
$dbHandle->exec("UPDATE library SET authors=migrateauthors(authors), authors_ascii=migrateauthors(authors_ascii) WHERE authors NOT LIKE '%L:\"%'");
$dbHandle->exec("CREATE INDEX journal_ind ON library (journal)");
$dbHandle->exec("CREATE INDEX secondary_title_ind ON library (secondary_title)");
$dbHandle->exec("CREATE INDEX addition_date_ind ON library (addition_date)");
$dbHandle->commit();
$dbHandle = null;
?>