* Please remember that this include file is being loaded *before* the class
* loader is loading classes from "exceptions", "interfaces" and "main"!
*
- * @author Roland Haeder <webmaster@ship-simu.org>
- * @version 0.0.0
- * @copyright Copyright (c) 2007, 2008 Roland Haeder, 2009 Ship-Simu Developer Team
+ * @author Roland Haeder <webmaster@shipsimu.org>
+ * @version 0.0
+ * @copyright Copyright (c) 2007 - 2008 Roland Haeder, 2009 - 2012 Ship-Simu Developer Team
* @license GNU GPL 3.0 or any newer version
- * @link http://www.ship-simu.org
*
* 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
* 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, see <http://www.gnu.org/licenses/>.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-class ApplicationHelper extends BaseApplication implements ManageableApplication, Registerable {
+class ApplicationHelper extends BaseFrameworkSystem implements ManageableApplication, Registerable {
/**
* The version number of this application
*/
- private $appVersion = "";
+ private $appVersion = '';
/**
* The human-readable name for this application
*/
- private $appName = "";
+ private $appName = '';
/**
* The short uni*-like name for this application
*/
- private $shortName = "";
-
- /**
- * An instance of a controller
- */
- private $controllerInstance = null;
+ private $shortName = '';
/**
* An instance of this class
*/
- private static $selfInstance = null;
+ private static $selfInstance = NULL;
/**
- * Protected constructor
+ * Private constructor
*
* @return void
*/
*
* @return $selfInstance An instance of this class
*/
- public final static function getInstance () {
+ public static final function getSelfInstance () {
// Is the instance there?
if (is_null(self::$selfInstance)) {
self::$selfInstance = new ApplicationHelper();
/**
* Getter for the version number
*
- * @return $appVersion The application's version number
+ * @return $appVersion The application's version number
*/
public final function getAppVersion () {
return $this->appVersion;
}
-
/**
* Setter for the version number
*
- * @param $appVersion The application's version number
+ * @param $appVersion The application's version number
* @return void
*/
public final function setAppVersion ($appVersion) {
// Cast and set it
- $appVersion = (string) $appVersion;
- $this->appVersion = $appVersion;
+ $this->appVersion = (string) $appVersion;
}
/**
*/
public final function setAppName ($appName) {
// Cast and set it
- $appName = (string) $appName;
- $this->appName = $appName;
+ $this->appName = (string) $appName;;
}
/**
*/
public final function setAppShortName ($shortName) {
// Cast and set it
- $shortName = (string) $shortName;
- $this->shortName = $shortName;
+ $this->shortName = (string) $shortName;
}
/**
- * Builds the master template's name
- *
- * @return $masterTemplateName Name of the master template
- */
- public function buildMasterTemplateName () {
- // Get short name and add suffix
- $masterTemplateName = str_replace('-', '', $this->getAppShortName()) . '_main';
-
- // Return it
- return $masterTemplateName;
- }
-
- /**
- * Launches the admin area
+ * Launches the application
*
* @return void
*/
// Set this application in registry
Registry::getRegistry()->addInstance('app', $this);
+ // Default response is console
+ $response = self::getResponseTypeFromSystem();
+ $responseType = self::getResponseTypeFromSystem();
+
// Create a new request object
- $requestInstance = ObjectFactory::createObjectByName('HttpRequest');
+ $requestInstance = ObjectFactory::createObjectByName(self::convertToClassName($response) . 'Request');
- // Default response is HTTP (HTML page) and type is 'Web'
- $response = 'http';
- $responseType = 'web';
+ // Remember request instance here
+ $this->setRequestInstance($requestInstance);
// Do we have another response?
if ($requestInstance->isRequestElementSet('request')) {
} // END - if
// ... and a new response object
- $responseClass = sprintf("%sResponse", $this->convertToClassName($response));
+ $responseClass = sprintf('%sResponse', self::convertToClassName($response));
$responseInstance = ObjectFactory::createObjectByName($responseClass, array($this));
- // Remember both in this application
- $this->setRequestInstance($requestInstance);
+ // Remember response instance here
$this->setResponseInstance($responseInstance);
// Get the parameter from the request
- $commandName = $requestInstance->getRequestElement('page');
+ $commandName = $requestInstance->getRequestElement('command');
// If it is null then get default command
if (is_null($commandName)) {
// Get default command
- $commandName = $responseInstance->getDefaultCommand();
+ $commandName = $responseInstance->determineDefaultCommand();
// Set it in request
- $requestInstance->setRequestElement('page', $commandName);
+ $requestInstance->setRequestElement('command', $commandName);
} // END - if
- // Get a resolver
- $resolverClass = sprintf("%sControllerResolver", $this->convertToClassName($responseType));
+ // Get a controller resolver
+ $resolverClass = self::convertToClassName($this->getAppShortName() . '_' . $responseType . '_controller_resolver');
$resolverInstance = ObjectFactory::createObjectByName($resolverClass, array($commandName, $this));
// Get a controller instance as well
- $this->controllerInstance = $resolverInstance->resolveController();
+ $this->setControllerInstance($resolverInstance->resolveController());
+
+ // Initialize language system
+ $languageInstance = ObjectFactory::createObjectByConfiguredName('language_system_class');
- // Get a web output class
- $outputInstance = ObjectFactory::createObjectByConfiguredName('output_class', array($this));
+ // And set it here
+ $this->setLanguageInstance($languageInstance);
- // Set it in this application
- $this->setWebOutputInstance($outputInstance);
+ // Launch the main routine here
+ $this->getControllerInstance()->handleRequest($requestInstance, $responseInstance);
+ }
- // Handle the request
- $this->controllerInstance->handleRequest($requestInstance, $responseInstance);
+ /**
+ * Assigns extra application-depending data
+ *
+ * @param $templateInstance An instance of a CompileableTemplate
+ * @return void
+ * @todo Nothing to add?
+ */
+ public function assignExtraTemplateData (CompileableTemplate $templateInstance) {
}
/**
public function handleFatalMessages (array $messageList) {
// Walk through all messages
foreach ($messageList as $message) {
- print("MSG:" . $message . "<br />\n");
- } // END - if
+ exit(__METHOD__ . ':MSG:' . $message);
+ } // END - foreach
}
/**
- * Assigns application-depending data
+ * Builds the master template's name
*
- * @param $templateInstance An instance of a template engine
- * @return void
+ * @return $masterTemplateName Name of the master template
*/
- public function assignExtraTemplateData (CompileableTemplate $templateInstance) {
- // Assign charset
- $templateInstance->assignConfigVariable('header_charset');
+ public function buildMasterTemplateName () {
+ return 'node_main';
}
}