Файл: install/inc/ver_tables.php
Строк: 30
<?php
// данный скрипт добавяет отсутствующие таблицы в базу данных
// также он используется для установки движка
$tab= $db->query('SHOW TABLES');
while ($tables= $tab->fetch_row()) {
$_ver_table[$tables[0]]=1;
}
$k_sql=0;
$ok_sql=0;
$opdirtables = opendir(H . 'install/db');
while ($filetables = readdir($opdirtables)) {
if (preg_match('#.sql$#i', $filetables)) {
$table_name = preg_replace('#.sql$#i', null, $filetables);
if (!isset($_ver_table[$table_name])) {
include_once H . 'sys/inc/sql_parser.php';
$sql=SQLParser::getQueriesFromFile(H.'install/db/'.$filetables);
for ($i = 0; $i < count($sql); $i++) {
$k_sql++; // счетчик запросов (для установщика)
if ($db->query($sql[$i])) {
$ok_sql++; // счетчик успешно выполненных запросов (для установщика)
}
}
}
}
}
closedir($opdirtables);
if (!isset($install)) {
// выполнение одноразовых запросов
$opdirtables=opendir(H.'install/update/');
while ($rd=readdir($opdirtables)) {
if (preg_match('#^.#', $rd)) {
continue;
}
if (isset($set['update'][$rd])) {
continue;
}
if (preg_match('#.sql$#i', $rd)) {
include_once H . 'sys/inc/sql_parser.php';
$sql = SQLParser::getQueriesFromFile(H.'install/update/'.$rd);
for ($i = 0; $i < count($sql); $i++) {
$db->query($sql[$i]);
}
$set['update'][$rd]=true;
$save_settings=true;
} elseif (preg_match('#.php$#i', $rd)) {
include_once H.'install/update/'.$rd;
$set['update'][$rd]=true;
$save_settings=true;
}
}
closedir($opdirtables);
if (isset($save_settings)) {
save_settings($set);
}
}