Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/signals/src/orxonox.cc @ 7422

Last change on this file since 7422 was 7361, checked in by rennerc, 19 years ago

added signalhandling class to orx

File size: 14.3 KB
Line 
1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10
11   This program is distributed in the hope that it will be useful,
12   but WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   GNU General Public License for more details.
15
16   You should have received a copy of the GNU General Public License
17   along with this program; if not, write to the Free Software Foundation,
18   Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19
20
21   ### File Specific:
22   main-programmer: Patrick Boenzli
23   co-programmer: Christian Meyer
24   co-programmer: Benjamin Grauer: injected ResourceManager/GraphicsEngine/GUI
25*/
26
27#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_ORXONOX
28#include "orxonox.h"
29
30#include "globals.h"
31
32#include "gui.h"
33
34#include "parser/ini_parser/ini_parser.h"
35#include "util/loading/game_loader.h"
36#include "util/signal_handler.h"
37
38//ENGINES
39#include "graphics_engine.h"
40#include "sound_engine.h"
41#include "util/loading/resource_manager.h"
42#include "cd_engine.h"
43#include "text_engine.h"
44#include "event_handler.h"
45
46#include "util/loading/factory.h"
47#include "fast_factory.h"
48
49#include "benchmark.h"
50
51#include "class_list.h"
52#include "shell_command_class.h"
53#include "shell_command.h"
54#include "shell_buffer.h"
55
56#include "util/loading/load_param_description.h"
57
58#include "network_manager.h"
59
60#include "state.h"
61#include "lib/parser/preferences/cmd_line_prefs_reader.h"
62#include "lib/parser/preferences/ini_file_prefs_reader.h"
63#include <string.h>
64
65int verbose = 4;
66
67using namespace std;
68
69SHELL_COMMAND(restart, Orxonox, restart);
70
71REGISTER_ARG_FLAG( l, license,    "misc",  "showLicenseAndExit", "Prints the license and exit",      "1" );
72REGISTER_ARG_FLAG( c, client,     "game",  "gameType",           "Connect to Server (-H)",           "multiplayer_client" );
73REGISTER_ARG_FLAG( s, server,     "game",  "gameType",           "Start Orxonox as Game Server",     "multiplayer_server" );
74REGISTER_ARG_ARG(  H, host,       "game",  "host",               "Host to connect to",               "host");
75REGISTER_ARG_ARG(  p, port,       "game",  "port",               "Port to use",                      "port" );
76REGISTER_ARG_FLAG( g, gui,        "game",  "showGui",            "starts the orxonox with the configuration GUI", "1");
77
78REGISTER_ARG_FLAG( f, fullscreen, "video", "Fullscreen-mode",    "start Orxonox in fullscreen mode", "1");
79REGISTER_ARG_FLAG( w, windowed,   "video", "Fullscreen-mode",    "start Orxonox in windowed mode",   "0");
80REGISTER_ARG_ARG(  r, resolution, "video", "Resolution",         "Sets resolution / window size",    "res");
81
82REGISTER_ARG_FLAG( a, audio,      "audio", "Disable-Audio",      "Enable audio",                     "0" );
83REGISTER_ARG_FLAG( m, mute ,      "audio", "Disable-Audio",      "Disable audio",                    "1" );
84REGISTER_ARG_ARG(  _, audio_channels, "audio", "Audio-Channels", "Sets # audio channels", "num" );
85REGISTER_ARG_ARG(  _, music_volume, "audio", "Music-Volume", "Sets music volume", "vol" );
86REGISTER_ARG_ARG(  _, effects_volume, "audio", "Effects-Volume", "Sets effects volume", "vol" );
87
88#ifndef __WIN32__
89REGISTER_ARG_FLAG( _, start_gdb_on_signal, "misc", "start-gdb", "Start gdb on signal", "1");
90REGISTER_ARG_FLAG( _, write_bt_to_file, "misc", "bt-to-file", "Write backtrace to file", "1");
91#endif
92
93/**
94 *  create a new Orxonox
95
96   In this funcitons only global values are set. The game will not be started here.
97*/
98Orxonox::Orxonox ()
99{
100  this->setClassID(CL_ORXONOX, "Orxonox");
101  this->setName("orxonox-main");
102
103  this->argc = 0;
104  this->argv = NULL;
105
106  /* this way, there is no network enabled: */
107  this->serverName = "";
108  this->port = -1;
109
110  this->configFileName = "";
111}
112
113/**
114 *  remove Orxonox from memory
115*/
116Orxonox::~Orxonox ()
117{
118  // game-specific
119  delete GameLoader::getInstance();
120
121  // class-less services/factories
122  Factory::deleteFactories();
123  FastFactory::deleteAll();
124  ShellCommandClass::unregisterAllCommands();
125
126  LoadClassDescription::deleteAllDescriptions();
127
128  // engines
129  delete CDEngine::getInstance();
130  delete SoundEngine::getInstance();
131  delete GraphicsEngine::getInstance(); // deleting the Graphics
132  delete EventHandler::getInstance();
133
134  // handlers
135  delete ResourceManager::getInstance(); // deletes the Resource Manager
136  // output-buffer
137  delete ShellBuffer::getInstance();
138
139  SDL_QuitSubSystem(SDL_INIT_TIMER);
140  ClassList::debug();
141
142  PRINT(3)
143  (
144    "===================================================\n" \
145    "Thanks for playing orxonox.\n" \
146    "visit: http://www.orxonox.net for new versions.\n" \
147    "===================================================\n" \
148    ORXONOX_LICENSE_SHORT
149  );
150
151  Orxonox::singletonRef = NULL;
152}
153
154/**
155 *  this is a singleton class to prevent duplicates
156 */
157Orxonox* Orxonox::singletonRef = NULL;
158
159// DANGEROUS
160void Orxonox::restart()
161{
162  //   int argc = this->argc;
163  //   char** argv = this->argv;
164  //
165  //   Orxonox *orx = Orxonox::getInstance();
166  //
167  //   delete orx;
168  //
169  //   orx = Orxonox::getInstance();
170  //
171  //   if((*orx).init(argc, argv) == -1)
172  //   {
173  //     PRINTF(1)("! Orxonox initialization failed\n");
174  //     return;
175  //   }
176  //
177  //   printf("finished inizialisation\n");
178  //   orx->start();
179}
180
181/**
182 * @brief this finds the config file
183 * @returns the new config-fileName
184 * Since the config file varies from user to user and since one may want to specify different config files
185 * for certain occasions or platforms this function finds the right config file for every occasion and stores
186 * it's path and name into configfilename
187*/
188const std::string& Orxonox::getConfigFile ()
189{
190  if (ResourceManager::isFile("orxonox.conf"))
191  {
192    this->configFileName =  "orxonox.conf";
193  }
194  else
195    this->configFileName = ResourceManager::homeDirCheck(DEFAULT_CONFIG_FILE);
196
197  PRINTF(3)("Parsed Config File: '%s'\n", this->configFileName);
198}
199
200/**
201 * initialize Orxonox with command line
202 */
203int Orxonox::init (int argc, char** argv, const std::string & name, int port)
204{
205  this->argc = argc;
206  this->argv = argv;
207
208  this->serverName = name;
209  this->port = port;
210
211  // initialize the Config-file
212  this->getConfigFile();
213
214  // windows must not write into stdout.txt and stderr.txt
215  /*#ifdef __WIN32__
216  freopen( "CON", "w", stdout );
217  freopen( "CON", "w", stderr );
218  #endif*/
219
220  // initialize everything
221  SDL_Init(0);
222  if( initResources () == -1)
223    return -1;
224  if( initVideo() == -1)
225    return -1;
226  if( initSound() == -1)
227    return -1;
228  if( initInput() == -1)
229    return -1;
230  if( initNetworking () == -1)
231    return -1;
232  if( initMisc () == -1)
233    return -1;
234
235  return 0;
236}
237
238
239/**
240 * initializes SDL and OpenGL
241 */
242int Orxonox::initVideo()
243{
244  PRINTF(3)("> Initializing video\n");
245
246  GraphicsEngine::getInstance();
247
248  GraphicsEngine::getInstance()->initFromPreferences();
249
250  std::string iconName = ResourceManager::getFullName("pictures/fighter-top-32x32.bmp");
251  if (!iconName.empty())
252  {
253    GraphicsEngine::getInstance()->setWindowName(PACKAGE_NAME " " PACKAGE_VERSION, iconName);
254  }
255  return 0;
256}
257
258
259/**
260 * initializes the sound engine
261 */
262int Orxonox::initSound()
263{
264  PRINT(3)("> Initializing sound\n");
265  // SDL_InitSubSystem(SDL_INIT_AUDIO);
266  SoundEngine::getInstance();
267
268  SoundEngine::getInstance()->loadSettings();
269  SoundEngine::getInstance()->initAudio();
270  return 0;
271}
272
273
274/**
275 * initializes input functions
276 */
277int Orxonox::initInput()
278{
279  PRINT(3)("> Initializing input\n");
280
281  EventHandler::getInstance()->init();
282  EventHandler::getInstance()->subscribe(GraphicsEngine::getInstance(), ES_ALL, EV_VIDEO_RESIZE);
283
284  return 0;
285}
286
287
288/**
289 * initializes network system
290 */
291int Orxonox::initNetworking()
292{
293  PRINT(3)("> Initializing networking\n");
294
295  if( this->serverName != "") // we are a client
296  {
297    State::setOnline(true);
298    NetworkManager::getInstance()->establishConnection(this->serverName, port);
299  }
300  else if( this->port > 0) {    // we are a server
301    State::setOnline(true);
302    NetworkManager::getInstance()->createServer(port);
303  }
304  return 0;
305}
306
307//#include "util/loading/dynamic_loader.h"
308
309/**
310 * initializes and loads resource files
311 */
312int Orxonox::initResources()
313{
314  PRINTF(3)("> Initializing resources\n");
315
316  PRINT(3)("initializing ResourceManager\n");
317
318  // init the resource manager
319  std::string dataPath;
320  if ((dataPath = Preferences::getInstance()->getString(CONFIG_SECTION_DATA, CONFIG_NAME_DATADIR, ""))!= "")
321  {
322    if (!ResourceManager::getInstance()->setDataDir(dataPath) &&
323        !ResourceManager::getInstance()->verifyDataDir(DEFAULT_DATA_DIR_CHECKFILE))
324    {
325      PRINTF(1)("Data Could not be located in %s\n", dataPath.c_str());
326    }
327  }
328
329  if (!ResourceManager::getInstance()->verifyDataDir(DEFAULT_DATA_DIR_CHECKFILE))
330  {
331    PRINTF(1)("The DataDirectory %s could not be verified\n\nh" \
332              "!!!  Please Change in File %s Section %s Entry %s to a suitable value !!!\n",
333    ResourceManager::getInstance()->getDataDir().c_str(),
334    this->configFileName.c_str(),
335              CONFIG_SECTION_DATA,
336              CONFIG_NAME_DATADIR );
337    Gui* gui = new Gui(argc, argv);
338    gui->startGui();
339    delete gui;
340    exit(-1);
341  }
342  //! @todo this is a hack and should be loadable
343  std::string imageDir = ResourceManager::getInstance()->getFullName("maps");
344  ResourceManager::getInstance()->addImageDir(imageDir);
345  imageDir = ResourceManager::getInstance()->getFullName("pictures");
346  ResourceManager::getInstance()->addImageDir(imageDir);
347
348  //  DynamicLoader::loadDyLib("libtest.so");
349
350  // start the collision detection engine
351  CDEngine::getInstance();
352  return 0;
353}
354
355/**
356 * initializes miscelaneous features
357 * @return -1 on failure
358 */
359int Orxonox::initMisc()
360{
361  ShellBuffer::getInstance();
362  return 0;
363}
364
365/**
366 *  starts the orxonox game or menu
367 * here is the central orxonox state manager. There are currently two states
368 * - menu
369 * - game-play
370 * both states manage their states themselfs again.
371*/
372void Orxonox::start()
373{
374
375  this->gameLoader = GameLoader::getInstance();
376
377  if( this->port != -1)
378    this->gameLoader->loadNetworkCampaign("worlds/DefaultNetworkCampaign.oxc");
379  else
380    this->gameLoader->loadCampaign("worlds/DefaultCampaign.oxc");                       /* start orxonox in single player mode */
381
382  //  this->gameLoader->loadDebugCampaign(DEBUG_CAMPAIGN_0);
383  this->gameLoader->init();
384  this->gameLoader->start();
385}
386
387
388/**
389 * handles sprecial events from localinput
390 * @param event: an event not handled by the CommandNode
391 */
392// void Orxonox::graphicsHandler(SDL_Event* event)
393// {
394//   // Handle special events such as reshape, quit, focus changes
395//   switch (event->type)
396//     {
397//     case SDL_VIDEORESIZE:
398//       GraphicsEngine* tmpGEngine = GraphicsEngine::getInstance();
399//       tmpGEngine->resolutionChanged(event->resize);
400//       break;
401//     }
402// }
403
404
405
406
407
408
409bool showGui = false;
410
411
412
413/**********************************
414*** ORXONOX MAIN STARTING POINT ***
415**********************************/
416/**
417 *
418 *  main function
419 *
420 * here the journey begins
421*/
422int main(int argc, char** argv)
423{
424  CmdLinePrefsReader prefs;
425 
426  IniFilePrefsReader ini(ResourceManager::homeDirCheck(DEFAULT_CONFIG_FILE));
427 
428  prefs.parse(argc, argv);
429 
430  if ( Preferences::getInstance()->getString("misc", "showLicenseAndExit", "") == "1" )
431  {
432    PRINT(0)(ORXONOX_LICENSE_SHORT);
433    return 0;
434  }
435 
436#ifndef __WIN32__
437  if ( Preferences::getInstance()->getString("misc", "start-gdb", "0") == "1" )
438  {
439    SignalHandler::getInstance()->doCatch( argv[0], GDB_RUN_IN_FOREGROUND );
440  }
441  else if ( Preferences::getInstance()->getString("misc", "bt-to-file", "1") == "1" )
442  {      SignalHandler::getInstance()->doCatch( argv[0], GDB_RUN_WRITE_TO_FILE );
443   
444  }
445#endif
446 
447  if( Preferences::getInstance()->getString("game", "showGui", "") == "1" )
448    showGui = true;
449  else if( Preferences::getInstance()->getString( "game", "gameType", "" ) == "multiplayer_server" ||
450           Preferences::getInstance()->getString( "game", "gameType", "" ) == "multiplayer_client" )
451    return startNetworkOrxonox(argc, argv);
452 
453  return startOrxonox(argc, argv, "", -1);
454  return 0;
455}
456
457
458
459/**
460 * starts orxonox in network mode
461 * @param argc parameters count given to orxonox
462 * @param argv parameters given to orxonox
463 */
464int startNetworkOrxonox(int argc, char** argv)
465{
466
467  std::string gameType = Preferences::getInstance()->getString( "game", "gameType", "" );
468 
469  if ( gameType == "multiplayer_client" )
470  {
471    int port = Preferences::getInstance()->getInt( "game", "port", DEFAULT_ORXONOX_PORT );
472    std::string host = Preferences::getInstance()->getString( "game", "host", "" );
473   
474    if ( host == "" )
475    {
476      printf("You need to specify a host to connect to ( -H <host> )\n");
477      return 1;
478    }
479   
480    printf("Starting Orxonox as client: connecting to %s, on port %i\n", host.c_str(), port);
481   
482    startOrxonox(argc, argv, host.c_str(), port);
483  }
484  else if ( gameType == "multiplayer_server" )
485  {
486    int port = Preferences::getInstance()->getInt( "game", "port", DEFAULT_ORXONOX_PORT );
487   
488    printf("Starting Orxonox as server: listening on port %i\n", port);
489   
490    startOrxonox(argc, argv, "", port);
491  }
492}
493
494
495
496/**
497 * starts orxonox
498 * @param argc parameters count given to orxonox
499 * @param argv parameters given to orxonox
500 */
501int startOrxonox(int argc, char** argv, const std::string & name, int port)
502{
503  // checking for existence of the configuration-files, or if the lock file is still used
504  if (showGui || (!ResourceManager::isFile("./orxonox.conf") &&
505                  !ResourceManager::isFile(DEFAULT_CONFIG_FILE))
506#if DEBUG < 3 // developers do not need to see the GUI, when orxonox fails
507      || ResourceManager::isFile(DEFAULT_LOCK_FILE)
508#endif
509     )
510  {
511    if (ResourceManager::isFile(DEFAULT_LOCK_FILE))
512      ResourceManager::deleteFile(DEFAULT_LOCK_FILE);
513
514    // starting the GUI
515    Gui* gui = new Gui(argc, argv);
516    gui->startGui();
517
518    if (! gui->startOrxonox)
519      return 0;
520
521    delete gui;
522  }
523
524  PRINT(0)(">>> Starting Orxonox <<<\n");
525
526  ResourceManager::touchFile(DEFAULT_LOCK_FILE);
527
528  Orxonox *orx = Orxonox::getInstance();
529
530  if( orx->init(argc, argv, name, port) == -1)
531  {
532    PRINTF(1)("! Orxonox initialization failed\n");
533    return -1;
534  }
535
536  printf("finished inizialisation\n");
537  orx->start();
538
539  delete orx;
540  ResourceManager::deleteFile("~/.orxonox/orxonox.lock");
541}
Note: See TracBrowser for help on using the repository browser.