summaryrefslogtreecommitdiffstats
path: root/source/cRoot.cpp
diff options
context:
space:
mode:
authorfaketruth <faketruth@0a769ca7-a7f5-676a-18bf-c427514a06d6>2011-10-03 20:41:19 +0200
committerfaketruth <faketruth@0a769ca7-a7f5-676a-18bf-c427514a06d6>2011-10-03 20:41:19 +0200
commit386d58b5862d8b76925c6523721594887606e82a (patch)
treeef073e7a843f4b75a4008d4b7383f7cdf08ceee5 /source/cRoot.cpp
parentVisual Studio 2010 solution and project files (diff)
downloadcuberite-386d58b5862d8b76925c6523721594887606e82a.tar
cuberite-386d58b5862d8b76925c6523721594887606e82a.tar.gz
cuberite-386d58b5862d8b76925c6523721594887606e82a.tar.bz2
cuberite-386d58b5862d8b76925c6523721594887606e82a.tar.lz
cuberite-386d58b5862d8b76925c6523721594887606e82a.tar.xz
cuberite-386d58b5862d8b76925c6523721594887606e82a.tar.zst
cuberite-386d58b5862d8b76925c6523721594887606e82a.zip
Diffstat (limited to '')
-rw-r--r--source/cRoot.cpp162
1 files changed, 162 insertions, 0 deletions
diff --git a/source/cRoot.cpp b/source/cRoot.cpp
new file mode 100644
index 000000000..7f0012764
--- /dev/null
+++ b/source/cRoot.cpp
@@ -0,0 +1,162 @@
+#include "cRoot.h"
+#include "cMCLogger.h"
+#include "cServer.h"
+#include "cWorld.h"
+#include "cWebAdmin.h"
+#include "cFurnaceRecipe.h"
+#include "cGroupManager.h"
+#include "cRecipeChecker.h"
+#include "cPluginManager.h"
+#include "cMonsterConfig.h"
+#include "cSleep.h"
+
+#include "../iniFile/iniFile.h"
+
+#include <iostream>
+#include <time.h>
+#include <cstdio>
+
+#ifndef _WIN32
+#include <cstring>
+#endif
+
+cRoot* cRoot::s_Root = 0;
+
+cRoot::cRoot()
+ : m_Server( 0 )
+ , m_World( 0 )
+ , m_MonsterConfig( 0 )
+ , m_GroupManager( 0 )
+ , m_RecipeChecker( 0 )
+ , m_FurnaceRecipe( 0 )
+ , m_WebAdmin( 0 )
+ , m_PluginManager( 0 )
+ , m_Log( 0 )
+ , m_bStop( false )
+ , m_bRestart( false )
+ , m_hInputThread( 0 )
+{
+ s_Root = this;
+}
+
+cRoot::~cRoot()
+{
+ s_Root = 0;
+}
+
+#ifdef _WIN32
+DWORD WINAPI cRoot_InputThread(LPVOID lpParam)
+#else
+void *cRoot_InputThread( void *lpParam )
+#endif
+{
+ cRoot* Root = (cRoot*)lpParam;
+
+ while( 1 )
+ {
+ std::string Command;
+ std::getline(std::cin, Command);
+ Root->ServerCommand( Command.c_str() );
+ }
+ return 0;
+}
+
+void cRoot::Start()
+{
+ if( m_Log ) delete m_Log, m_Log = 0;
+ m_Log = new cMCLogger();
+
+#ifdef _WIN32
+ m_hInputThread = CreateThread(
+ NULL, // default security
+ 0, // default stack size
+ cRoot_InputThread, // name of the thread function
+ this, // thread parameters
+ 0, // default startup flags
+ NULL);
+#else
+ m_hInputThread = new pthread_t;
+ pthread_create( (pthread_t*)m_hInputThread, NULL, cRoot_InputThread, this );
+#endif
+
+ m_bStop = false;
+ while(!m_bStop)
+ {
+ m_bRestart = false;
+
+ m_Server = new cServer();
+
+ cIniFile IniFile("settings.ini"); IniFile.ReadFile();
+ int Port = IniFile.GetValueI("Server", "Port", 25565 );
+ if(!m_Server->InitServer( Port ))
+ {
+ LOG("Failed to start server, shutting down.");
+ return;
+ }
+
+
+ cIniFile WebIniFile("webadmin.ini");
+ if( WebIniFile.ReadFile() )
+ {
+ if( WebIniFile.GetValueB("WebAdmin", "Enabled", false ) == true )
+ {
+ m_WebAdmin = new cWebAdmin(8080);
+ }
+ }
+
+ m_GroupManager = new cGroupManager();
+ m_RecipeChecker = new cRecipeChecker();
+ m_FurnaceRecipe = new cFurnaceRecipe();
+ m_World = new cWorld();
+ m_World->InitializeSpawn();
+
+ m_PluginManager = new cPluginManager(); // This should be last
+ m_PluginManager->ReloadPluginsNow();
+ m_MonsterConfig = new cMonsterConfig(2);
+
+ // This sets stuff in motion
+ m_Server->StartListenThread();
+ //cHeartBeat* HeartBeat = new cHeartBeat();
+
+ while( !m_bStop && !m_bRestart ) // These are modified by external threads
+ {
+ cSleep::MilliSleep( 1000 );
+ }
+
+ // Deallocate stuffs
+ m_Server->Shutdown(); // This waits for threads to stop and d/c clients
+ delete m_PluginManager; m_PluginManager = 0; // This should be first
+ delete m_MonsterConfig; m_MonsterConfig = 0;
+ if( m_WebAdmin ) { delete m_WebAdmin; m_WebAdmin = 0; }
+ delete m_FurnaceRecipe; m_FurnaceRecipe = 0;
+ delete m_RecipeChecker; m_RecipeChecker = 0;
+ delete m_GroupManager; m_GroupManager = 0;
+ delete m_World; m_World = 0;
+ //delete HeartBeat; HeartBeat = 0;
+ delete m_Server; m_Server = 0;
+ }
+
+ // No other way to get it to exit
+#ifdef _WIN32
+ TerminateThread( m_hInputThread, 0 );
+#else
+ // TODO: pthread_kill
+ delete (pthread_t*)m_hInputThread;
+#endif
+
+ delete m_Log; m_Log = 0;
+}
+
+void cRoot::ServerCommand( const char* a_Cmd )
+{
+ //LOG("Command: %s", a_Cmd );
+ m_Server->ServerCommand( a_Cmd );
+ if( strcmp(a_Cmd, "stop") == 0 )
+ {
+ m_bStop = true;
+ }
+ else if( strcmp( a_Cmd, "restart") == 0 )
+ {
+ m_bRestart = true;
+ }
+}