Messages translated to english, a lot uneccessary debug messages removed
[shipsimu.git] / application / ship-simu / starter.php
1 <?php
2 /**
3  * The application launcher
4  *
5  * @author              Roland Haeder <webmaster@ship-simu.org>
6  * @version             0.0.0
7  * @copyright   Copyright(c) 2007, 2008 Roland Haeder, this is free software
8  * @license             GNU GPL 3.0 or any newer version
9  * @link                http://www.ship-simu.org
10  *
11  * This program is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU General Public License as published by
13  * the Free Software Foundation, either version 3 of the License, or
14  * (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program. If not, see <http://www.gnu.org/licenses/>.
23  */
24
25 // Is there an application helper instance? We need the method main() for
26 // maining the application
27 $app = ApplicationHelper::getInstance();
28
29 // Some sanity checks
30 if ((empty($app)) || (is_null($app))) {
31         // Something went wrong!
32         ApplicationEntryPoint::app_die(sprintf("[Main:] The application <strong>%s</strong> could not be launched because the helper class <strong>%s</strong> is not loaded.",
33                 $application,
34                 FrameworkConfiguration::getInstance()->readConfig("app_helper_class")
35         ));
36 } elseif (!is_object($app)) {
37         // No object!
38         ApplicationEntryPoint::app_die(sprintf("[Main:] The application <strong>%s</strong> could not be launched because &#39;app&#39; is not an object.",
39                 $application
40         ));
41 } elseif (!method_exists($app, FrameworkConfiguration::getInstance()->readConfig("entry_method"))) {
42         // Method not found!
43         ApplicationEntryPoint::app_die(sprintf("[Main:] The application <strong>%s</strong> could not be launched because the method <strong>%s</strong> is missing.",
44                 $application,
45                 FrameworkConfiguration::getInstance()->readConfig("entry_method")
46         ));
47 }
48
49 // Call the entry point method
50 try {
51         $eval = sprintf("%s::getInstance()->%s();",
52                 FrameworkConfiguration::getInstance()->readConfig("app_helper_class"),
53                 FrameworkConfiguration::getInstance()->readConfig("entry_method")
54         );
55         eval($eval);
56 } catch (FrameworkException  $e) {
57         ApplicationEntryPoint::app_die(sprintf("[Main:] The application <strong>%s</strong> could not be launched for the follwing reason: <strong>%s</strong>",
58                 $application,
59                 $e->getMessage()
60         ));
61 }
62
63
64 // [EOF]
65 ?>