diff --git a/core/controllers/welcome.php b/core/controllers/welcome.php index 672252eb..061a4176 100644 --- a/core/controllers/welcome.php +++ b/core/controllers/welcome.php @@ -20,7 +20,7 @@ class Welcome_Controller extends Template_Controller { public $template = 'welcome.html'; - function Index() { + function index() { $this->template->syscheck = new View('welcome_syscheck.html'); $this->template->syscheck->errors = $this->_get_config_errors(); $this->_create_directories(); @@ -77,7 +77,7 @@ class Welcome_Controller extends Template_Controller { return $errors; } - function _error_handler() { + function _error_handler($x) { } function _create_directories() { diff --git a/core/helpers/core_installer.php b/core/helpers/core_installer.php new file mode 100644 index 00000000..ef4dddd9 --- /dev/null +++ b/core/helpers/core_installer.php @@ -0,0 +1,67 @@ +where('name', 'core')->find()->version; + } catch (Exception $e) { + if ($e->getMessage() == "Table modules does not exist in your database.") { + $base_version = 0; + } else { + throw $e; + } + } + + if ($base_version == 0) { + $db->query("CREATE TABLE `modules` ( + `id` int(9) NOT NULL auto_increment, + `name` char(255) default NULL, + `version` int(9) default NULL, + PRIMARY KEY (`id`), + UNIQUE KEY(`name`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + + $db->query("CREATE TABLE `items` ( + `id` int(9) NOT NULL auto_increment, + `type` char(32) default NULL, + `title` char(255) default NULL, + `path` char(255) default NULL, + `parent_id` int(9) default NULL, + `level` int(9) default NULL, + `left` int(9) default NULL, + `right` int(9) default NULL, + PRIMARY KEY (`id`), + KEY `parent_id` (`parent_id`), + KEY `type` (`type`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + $core = ORM::factory('module')->where('name', 'core')->find(); + $core->name = "core"; + $core->version = 1; + $core->save(); + } + } + + public function uninstall() { + $db = Database::instance(); + $db->query("DROP TABLE IF EXISTS `items`;"); + $db->query("DROP TABLE IF EXISTS `modules`;"); + } +} diff --git a/core/models/item.php b/core/models/item.php new file mode 100644 index 00000000..f402a567 --- /dev/null +++ b/core/models/item.php @@ -0,0 +1,21 @@ +connect(); + } catch (Exception $e) { + print "{$e->getMessage()}\n"; + return; + } + } + // Find all tests, excluding sample tests that come with the unit_test module. $paths = array(APPPATH . "tests"); foreach (glob(MODPATH . "*/tests") as $path) { @@ -32,6 +53,8 @@ class Test_Controller extends Controller { } Kohana::config_set('unit_test.paths', $paths); + core_installer::install(); + print new Unit_Test(); } }