Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/new_class_id/src/orxonox.cc @ 9839

Last change on this file since 9839 was 9839, checked in by bensch, 18 years ago

Font completely ported to the new Resource-Format.
Now all the Basic Resources previously loaded from a central ResourceManager are Distributed over the Resource-Types

File size: 16.4 KB
RevLine 
[4982]1/*
[1850]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,
[4556]18   Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
[1850]19
[1855]20
21   ### File Specific:
22   main-programmer: Patrick Boenzli
[5303]23   co-programmer: Christian Meyer
[4054]24   co-programmer: Benjamin Grauer: injected ResourceManager/GraphicsEngine/GUI
[1850]25*/
26
[5303]27#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_ORXONOX
[2190]28#include "orxonox.h"
[3610]29
[5819]30#include "globals.h"
31
[8145]32#include "gui/qt/qt_gui.h"
[8749]33#include "gui/qt/qt_gui_datadir_fallback.h"
[4054]34
[5944]35#include "parser/ini_parser/ini_parser.h"
[7193]36#include "util/loading/game_loader.h"
[7440]37#include "util/signal_handler.h"
[4786]38
39//ENGINES
[3610]40#include "graphics_engine.h"
[4504]41#include "sound_engine.h"
[7193]42#include "util/loading/resource_manager.h"
[9836]43#include "util/loading/old_resource_manager.h"
[9797]44
[4786]45#include "cd_engine.h"
46#include "event_handler.h"
47
[9709]48#include "loading/fast_factory.h"
[4980]49
[9817]50#include "subprojects/benchmark.h"
[3610]51
[5641]52#include "shell_command_class.h"
[5165]53#include "shell_command.h"
[5175]54#include "shell_buffer.h"
[4748]55
[5996]56#include "network_manager.h"
[9406]57#include "shared_network_data.h"
[5996]58
[6695]59#include "state.h"
[7256]60#include "lib/parser/preferences/cmd_line_prefs_reader.h"
61#include "lib/parser/preferences/ini_file_prefs_reader.h"
[2190]62#include <string.h>
[4032]63
[7711]64int verbose = 5;
[2036]65
[1803]66
[9406]67
[5207]68SHELL_COMMAND(restart, Orxonox, restart);
69
[7258]70REGISTER_ARG_FLAG( l, license,    "misc",  "showLicenseAndExit", "Prints the license and exit",      "1" );
71REGISTER_ARG_FLAG( c, client,     "game",  "gameType",           "Connect to Server (-H)",           "multiplayer_client" );
[9406]72REGISTER_ARG_FLAG( s, server,     "game",  "gameType",           "Start Orxonox as Game Server",     "multiplayer_master_server" );
73REGISTER_ARG_FLAG( x, proxy,      "game",  "gameType",           "Start Orxonox as Proxy Server",    "multiplayer_proxy_server" );
[7258]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");
[7256]77
[7258]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");
[9406]80REGISTER_ARG_ARG(  r, resolution, "video", "Resolution",         "sets resolution / window size",    "res");
81REGISTER_ARG_FLAG( d, dedicated,  "video", "Norender-mode",      "the scene is not rendered",        "1" );
[7258]82
[7261]83REGISTER_ARG_FLAG( a, audio,      "audio", "Disable-Audio",      "Enable audio",                     "0" );
84REGISTER_ARG_FLAG( m, mute ,      "audio", "Disable-Audio",      "Disable audio",                    "1" );
85REGISTER_ARG_ARG(  _, audio_channels, "audio", "Audio-Channels", "Sets # audio channels", "num" );
86REGISTER_ARG_ARG(  _, music_volume, "audio", "Music-Volume", "Sets music volume", "vol" );
87REGISTER_ARG_ARG(  _, effects_volume, "audio", "Effects-Volume", "Sets effects volume", "vol" );
88
[7440]89#ifndef __WIN32__
90REGISTER_ARG_FLAG( _, write_bt_to_file, "misc", "bt-to-file", "Write backtrace to file", "1");
91#endif
92
[7954]93REGISTER_ARG_ARG(  t, telnetport,  "network","telnetport",        "Port to use for network debug output",               "port" );
94REGISTER_ARG_ARG(  _, write_dict,  "compression", "writedict",    "write packets to DATA/dicts/newdict",               "numBytes" );
95
[9715]96ObjectListDefinition(Orxonox);
[7954]97
[2190]98/**
[4836]99 *  create a new Orxonox
[4135]100
101   In this funcitons only global values are set. The game will not be started here.
[2190]102*/
103Orxonox::Orxonox ()
[1872]104{
[9709]105  this->registerObject(this, Orxonox::_objectList);
[4766]106  this->setName("orxonox-main");
[4059]107
[4135]108  this->argc = 0;
109  this->argv = NULL;
[4782]110
[5996]111  /* this way, there is no network enabled: */
[7256]112  this->serverName = "";
[5996]113  this->port = -1;
114
[7221]115  this->configFileName = "";
[1872]116}
[1803]117
[2190]118/**
[4836]119 *  remove Orxonox from memory
[2190]120*/
[4556]121Orxonox::~Orxonox ()
[2190]122{
[5285]123  // game-specific
[4815]124  delete GameLoader::getInstance();
[5285]125
126  // class-less services/factories
[4980]127  FastFactory::deleteAll();
[7374]128  OrxShell::ShellCommandClass::unregisterAllCommands();
[5332]129
[7427]130  // handlers
[9836]131  Resources::ResourceManager::deleteInstance(); // deletes the Resource Manager
[7427]132
[5285]133  // engines
134  delete CDEngine::getInstance();
[7460]135  delete OrxSound::SoundEngine::getInstance();
[5285]136  delete GraphicsEngine::getInstance(); // deleting the Graphics
[4817]137  delete EventHandler::getInstance();
[5285]138
139  // output-buffer
[7374]140  delete OrxShell::ShellBuffer::getInstance();
[5285]141
[5225]142  SDL_QuitSubSystem(SDL_INIT_TIMER);
[9406]143
[9709]144
[9715]145  ObjectListBase::debugAll(1);
[9709]146
[9235]147  Preferences::getInstance()->save();
[1850]148
[4833]149  PRINT(3)
[5996]150  (
151    "===================================================\n" \
152    "Thanks for playing orxonox.\n" \
153    "visit: http://www.orxonox.net for new versions.\n" \
154    "===================================================\n" \
155    ORXONOX_LICENSE_SHORT
156  );
[1872]157
[4766]158  Orxonox::singletonRef = NULL;
[1850]159}
160
[2190]161/**
[4836]162 *  this is a singleton class to prevent duplicates
[4766]163 */
164Orxonox* Orxonox::singletonRef = NULL;
[4556]165
[5207]166// DANGEROUS
167void Orxonox::restart()
168{
[5996]169  //   int argc = this->argc;
170  //   char** argv = this->argv;
171  //
172  //   Orxonox *orx = Orxonox::getInstance();
173  //
174  //   delete orx;
175  //
176  //   orx = Orxonox::getInstance();
177  //
178  //   if((*orx).init(argc, argv) == -1)
179  //   {
180  //     PRINTF(1)("! Orxonox initialization failed\n");
181  //     return;
182  //   }
183  //
184  //   printf("finished inizialisation\n");
185  //   orx->start();
[5207]186}
187
[4766]188/**
[7221]189 * @brief this finds the config file
[4766]190 * @returns the new config-fileName
191 * Since the config file varies from user to user and since one may want to specify different config files
192 * for certain occasions or platforms this function finds the right config file for every occasion and stores
193 * it's path and name into configfilename
[2190]194*/
[7221]195const std::string& Orxonox::getConfigFile ()
[1850]196{
[7661]197  File orxConfFile("orxonox.conf");
198  if (orxConfFile.isFile())
[5424]199  {
[7221]200    this->configFileName =  "orxonox.conf";
[5424]201  }
202  else
[7661]203    this->configFileName = File(DEFAULT_CONFIG_FILE).name();
[7256]204
[7677]205  PRINTF(3)("Parsed Config File: '%s'\n", this->configFileName.c_str());
[8316]206  return this->configFileName;
[1803]207}
208
[2190]209/**
[4833]210 * initialize Orxonox with command line
211 */
[7256]212int Orxonox::init (int argc, char** argv, const std::string & name, int port)
[1803]213{
[4135]214  this->argc = argc;
215  this->argv = argv;
[4556]216
[5996]217  this->serverName = name;
218  this->port = port;
219
[4766]220  // initialize the Config-file
[4830]221  this->getConfigFile();
[4766]222
[5788]223  // windows must not write into stdout.txt and stderr.txt
[6833]224  /*#ifdef __WIN32__
[5788]225  freopen( "CON", "w", stdout );
226  freopen( "CON", "w", stderr );
[6833]227  #endif*/
[5788]228
[5996]229  // initialize everything
[6079]230  SDL_Init(0);
[8749]231  if( initVideo() == -1)
232    return -1;
[5996]233  if( initResources () == -1)
234    return -1;
235  if( initSound() == -1)
236    return -1;
237  if( initInput() == -1)
238    return -1;
239  if( initNetworking () == -1)
240    return -1;
241  if( initMisc () == -1)
242    return -1;
[4556]243
[2636]244  return 0;
[1850]245}
[1849]246
[5996]247
[2190]248/**
[4833]249 * initializes SDL and OpenGL
[5996]250 */
[4556]251int Orxonox::initVideo()
[2190]252{
[3611]253  PRINTF(3)("> Initializing video\n");
[4556]254
[3610]255  GraphicsEngine::getInstance();
[4556]256
[7256]257  GraphicsEngine::getInstance()->initFromPreferences();
[4766]258
[9836]259  std::string iconName = Resources::ResourceManager::getInstance()->prependAbsoluteMainPath("pictures/fighter-top-32x32.bmp");
[7221]260  if (!iconName.empty())
[5225]261  {
262    GraphicsEngine::getInstance()->setWindowName(PACKAGE_NAME " " PACKAGE_VERSION, iconName);
263  }
[2190]264  return 0;
265}
[1850]266
[5996]267
[2190]268/**
[4833]269 * initializes the sound engine
270 */
[4556]271int Orxonox::initSound()
[2190]272{
[4504]273  PRINT(3)("> Initializing sound\n");
[5225]274  // SDL_InitSubSystem(SDL_INIT_AUDIO);
[7460]275  OrxSound::SoundEngine::getInstance();
[4985]276
[7460]277  OrxSound::SoundEngine::getInstance()->loadSettings();
278  OrxSound::SoundEngine::getInstance()->initAudio();
[2636]279  return 0;
[2190]280}
[1900]281
[3214]282
[2190]283/**
[4833]284 * initializes input functions
285 */
[4556]286int Orxonox::initInput()
[2190]287{
[4766]288  PRINT(3)("> Initializing input\n");
289
[7256]290  EventHandler::getInstance()->init();
[4833]291  EventHandler::getInstance()->subscribe(GraphicsEngine::getInstance(), ES_ALL, EV_VIDEO_RESIZE);
[4556]292
[2636]293  return 0;
[1803]294}
295
[3214]296
[2190]297/**
[4833]298 * initializes network system
299 */
[4556]300int Orxonox::initNetworking()
[1897]301{
[4766]302  PRINT(3)("> Initializing networking\n");
[9406]303  std::string gameType = Preferences::getInstance()->getString( "game", "gameType", "" );
[4766]304
[9406]305  if( gameType == "multiplayer_client")
306  {    // we are a client
[6695]307    State::setOnline(true);
[9406]308    SharedNetworkData::getInstance()->setNodeType(NET_CLIENT);
309    NetworkManager::getInstance()->createClient(this->serverName, port);
[6695]310  }
[9406]311  else if( gameType == "multiplayer_master_server")
312  {    // we are a master server
[6695]313    State::setOnline(true);
[9406]314    SharedNetworkData::getInstance()->setNodeType(NET_MASTER_SERVER);
315
316    NetworkManager::getInstance()->createMasterServer(port);
[6139]317  }
[9406]318  else if( gameType == "multiplayer_proxy_server")
319  {    // we are a proxy server
320    State::setOnline(true);
321    SharedNetworkData::getInstance()->setNodeType(NET_PROXY_SERVER_ACTIVE);
322    NetworkManager::getInstance()->createProxyServer(port);
323  }
324
[2636]325  return 0;
[9406]326
[1897]327}
328
[7355]329//#include "util/loading/dynamic_loader.h"
[2190]330/**
[4833]331 * initializes and loads resource files
[4766]332 */
[4833]333int Orxonox::initResources()
[1858]334{
[4766]335  PRINTF(3)("> Initializing resources\n");
[4091]336
[4766]337  PRINT(3)("initializing ResourceManager\n");
338
[5488]339  // init the resource manager
[7221]340  std::string dataPath;
[7661]341  if ((dataPath = Preferences::getInstance()->getString(CONFIG_SECTION_GENERAL, CONFIG_NAME_DATADIR, ""))!= "")
[4766]342  {
[9836]343    Resources::ResourceManager::getInstance()->setMainGlobalPath(dataPath) ;
344    if(!Resources::ResourceManager::getInstance()->checkFileInMainPath(File(DEFAULT_DATA_DIR_CHECKFILE)))
[4766]345    {
[7221]346      PRINTF(1)("Data Could not be located in %s\n", dataPath.c_str());
[4766]347    }
348  }
[9836]349  while (!Resources::ResourceManager::getInstance()->checkFileInMainPath(File(DEFAULT_DATA_DIR_CHECKFILE)))
[4766]350  {
[8749]351
[5510]352    PRINTF(1)("The DataDirectory %s could not be verified\n\nh" \
353              "!!!  Please Change in File %s Section %s Entry %s to a suitable value !!!\n",
[9836]354              Resources::ResourceManager::getInstance()->mainGlobalPath().name().c_str(),
[7714]355              this->configFileName.c_str(),
[7661]356              CONFIG_SECTION_GENERAL,
[5510]357              CONFIG_NAME_DATADIR );
[8749]358    OrxGui::Gui* gui = new OrxGui::QtGuiDataDirFallback(argc, argv);
[5479]359    gui->startGui();
[8750]360    if (gui->getState() == OrxGui::Gui::Quitting)
361      return(-1);
[5479]362    delete gui;
[9836]363    Resources::ResourceManager::getInstance()->setMainGlobalPath(Preferences::getInstance()->getString(CONFIG_SECTION_GENERAL, CONFIG_NAME_DATADIR, ""));
[4766]364  }
[8749]365
[5996]366  //! @todo this is a hack and should be loadable
[9836]367  Resources::ResourceManager::getInstance()->addResourceSubPath("Texture", "maps");
368  Resources::ResourceManager::getInstance()->addResourceSubPath("Texture", "pictures");
[4009]369
[9836]370  Resources::ResourceManager::getInstance()->addResourceSubPath("SoundBuffer", "sound");
371  Resources::ResourceManager::getInstance()->addResourceSubPath("SoundBuffer", "music");
[9806]372
[9836]373  Resources::ResourceManager::getInstance()->addKeepLevelName("Imediately");
374  Resources::ResourceManager::getInstance()->addKeepLevelName("LevelEnd");
375  Resources::ResourceManager::getInstance()->addKeepLevelName("CampaignEnd");
376  Resources::ResourceManager::getInstance()->addKeepLevelName("GameEnd");
[9798]377
378
[9836]379  Resources::ResourceManager::getInstance()->debug();
[7355]380  //  DynamicLoader::loadDyLib("libtest.so");
[5074]381  return 0;
382}
383
384/**
385 * initializes miscelaneous features
386 * @return -1 on failure
387 */
388int Orxonox::initMisc()
389{
[7374]390  OrxShell::ShellBuffer::getInstance();
[8749]391
392  // start the collision detection engine
393  CDEngine::getInstance();
394
[4766]395  return 0;
[1858]396}
[1849]397
[2190]398/**
[4836]399 *  starts the orxonox game or menu
[4833]400 * here is the central orxonox state manager. There are currently two states
401 * - menu
402 * - game-play
403 * both states manage their states themselfs again.
[2190]404*/
[2636]405void Orxonox::start()
406{
[4556]407
[2636]408  this->gameLoader = GameLoader::getInstance();
[5996]409
[6139]410  if( this->port != -1)
411    this->gameLoader->loadNetworkCampaign("worlds/DefaultNetworkCampaign.oxc");
[5996]412  else
[6139]413    this->gameLoader->loadCampaign("worlds/DefaultCampaign.oxc");                       /* start orxonox in single player mode */
[5996]414
[4010]415  //  this->gameLoader->loadDebugCampaign(DEBUG_CAMPAIGN_0);
[2636]416  this->gameLoader->init();
417  this->gameLoader->start();
418}
419
[3214]420
[2636]421/**
[4833]422 * handles sprecial events from localinput
423 * @param event: an event not handled by the CommandNode
424 */
[4817]425// void Orxonox::graphicsHandler(SDL_Event* event)
426// {
427//   // Handle special events such as reshape, quit, focus changes
428//   switch (event->type)
429//     {
430//     case SDL_VIDEORESIZE:
431//       GraphicsEngine* tmpGEngine = GraphicsEngine::getInstance();
432//       tmpGEngine->resolutionChanged(event->resize);
433//       break;
434//     }
435// }
[1875]436
[4556]437
[4408]438
[1803]439
[3214]440
[4782]441
[4059]442bool showGui = false;
[3648]443
[4766]444/**********************************
445*** ORXONOX MAIN STARTING POINT ***
446**********************************/
[3449]447/**
[4833]448 *
[4836]449 *  main function
[4833]450 *
451 * here the journey begins
[3449]452*/
[4556]453int main(int argc, char** argv)
454{
[7256]455  CmdLinePrefsReader prefs;
[7374]456
[7661]457  IniFilePrefsReader ini(File(DEFAULT_CONFIG_FILE).name());
458  Preferences::getInstance()->setUserIni(File(DEFAULT_CONFIG_FILE).name());
[7374]459
[7256]460  prefs.parse(argc, argv);
[7374]461
[7256]462  if ( Preferences::getInstance()->getString("misc", "showLicenseAndExit", "") == "1" )
[5996]463  {
[7256]464    PRINT(0)(ORXONOX_LICENSE_SHORT);
465    return 0;
[5996]466  }
[7374]467
[9240]468  if ( Preferences::getInstance()->getString("misc", "bt-to-file", "1") == "1" )
[7440]469  {
[9406]470    SignalHandler::getInstance()->doCatch( argv[0], "orxonox.backtrace" );
471    SignalHandler::getInstance()->registerCallback( EventHandler::releaseMouse, NULL );
[7440]472  }
[7460]473
[7256]474  if( Preferences::getInstance()->getString("game", "showGui", "") == "1" )
475    showGui = true;
[9406]476  else if( Preferences::getInstance()->getString( "game", "gameType", "" ) == "multiplayer_master_server" ||
477           Preferences::getInstance()->getString( "game", "gameType", "" ) == "multiplayer_proxy_server" ||
[7256]478           Preferences::getInstance()->getString( "game", "gameType", "" ) == "multiplayer_client" )
479    return startNetworkOrxonox(argc, argv);
[7374]480
[7256]481  return startOrxonox(argc, argv, "", -1);
[3648]482}
483
484
485
[5996]486/**
487 * starts orxonox in network mode
488 * @param argc parameters count given to orxonox
489 * @param argv parameters given to orxonox
490 */
491int startNetworkOrxonox(int argc, char** argv)
492{
493
[7256]494  std::string gameType = Preferences::getInstance()->getString( "game", "gameType", "" );
[7374]495
[7256]496  if ( gameType == "multiplayer_client" )
[4132]497  {
[7256]498    int port = Preferences::getInstance()->getInt( "game", "port", DEFAULT_ORXONOX_PORT );
499    std::string host = Preferences::getInstance()->getString( "game", "host", "" );
[7374]500
[7256]501    if ( host == "" )
[5996]502    {
[7256]503      printf("You need to specify a host to connect to ( -H <host> )\n");
504      return 1;
[5996]505    }
[7374]506
[7256]507    printf("Starting Orxonox as client: connecting to %s, on port %i\n", host.c_str(), port);
[7374]508
[7256]509    startOrxonox(argc, argv, host.c_str(), port);
[4132]510  }
[9406]511  else if ( gameType == "multiplayer_master_server" )
[7256]512  {
513    int port = Preferences::getInstance()->getInt( "game", "port", DEFAULT_ORXONOX_PORT );
[7374]514
[7256]515    printf("Starting Orxonox as server: listening on port %i\n", port);
[7374]516
[7256]517    startOrxonox(argc, argv, "", port);
518  }
[9406]519  else if ( gameType == "multiplayer_proxy_server" )
520  {
521    int port = Preferences::getInstance()->getInt( "game", "port", DEFAULT_ORXONOX_PORT );
522
523    printf("Starting Orxonox as proxy server: listening on port %i\n", port);
524
525    startOrxonox(argc, argv, "", port);
526  }
[8316]527  return 1;
[3648]528}
529
[3649]530
[4766]531
532/**
533 * starts orxonox
534 * @param argc parameters count given to orxonox
535 * @param argv parameters given to orxonox
536 */
[7256]537int startOrxonox(int argc, char** argv, const std::string & name, int port)
[3648]538{
[4830]539  // checking for existence of the configuration-files, or if the lock file is still used
[7661]540  if (showGui || (!File("./orxonox.conf").isFile() &&
[7714]541                  !File(DEFAULT_CONFIG_FILE).isFile())
[7729]542#if DEBUG_LEVEL <= 3 // developers do not need to see the GUI, when orxonox fails
[5996]543      || ResourceManager::isFile(DEFAULT_LOCK_FILE)
[4981]544#endif
545     )
[5996]546  {
[7661]547    File lockFile(DEFAULT_LOCK_FILE);
548    if (lockFile.isFile())
549      lockFile.remove();
[4556]550
[5996]551    // starting the GUI
[7661]552    OrxGui::QtGui gui(argc, argv);
553    gui.startGui();
[4132]554
[7661]555    if (gui.getState() & OrxGui::Gui::Quitting)
[5996]556      return 0;
[4556]557
[5996]558  }
[4556]559
[4032]560  PRINT(0)(">>> Starting Orxonox <<<\n");
[4033]561
[7661]562  File(DEFAULT_LOCK_FILE).touch();
[4033]563
[1850]564  Orxonox *orx = Orxonox::getInstance();
[4556]565
[5996]566  if( orx->init(argc, argv, name, port) == -1)
567  {
568    PRINTF(1)("! Orxonox initialization failed\n");
569    return -1;
570  }
[4556]571
[5996]572  printf("finished inizialisation\n");
[2636]573  orx->start();
[4556]574
[3676]575  delete orx;
[7661]576  File("~/.orxonox/orxonox.lock").remove();
[8363]577  return 0;
[1803]578}
Note: See TracBrowser for help on using the repository browser.