2012-01-29 14:28:19 -05:00
|
|
|
|
|
|
|
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
2011-10-03 14:41:19 -04:00
|
|
|
|
|
|
|
#include "cRoot.h"
|
|
|
|
|
2011-10-21 20:15:12 -04:00
|
|
|
#include <exception> //std::exception
|
|
|
|
#include <csignal> //std::signal
|
|
|
|
#include <stdlib.h> //exit()
|
|
|
|
|
2011-11-07 20:25:01 -05:00
|
|
|
#include "SquirrelBindings.h"
|
|
|
|
#if USE_SQUIRREL
|
2012-01-29 14:28:19 -05:00
|
|
|
#pragma warning(disable:4100;disable:4127;disable:4510;disable:4610;disable:4244;disable:4512) // Getting A LOT of these warnings from SqPlus
|
|
|
|
#include <sqplus/sqplus.h>
|
|
|
|
#pragma warning(default:4100;default:4127;default:4510;default:4610;default:4244;default:4512)
|
2011-11-07 20:25:01 -05:00
|
|
|
#endif
|
|
|
|
|
2012-01-29 14:28:19 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2012-02-13 16:47:03 -05:00
|
|
|
/// If defined, a thorough leak finder will be used (debug MSVC only); leaks will be output to the Output window
|
|
|
|
#define ENABLE_LEAK_FINDER
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if defined(_MSC_VER) && defined(_DEBUG) && defined(ENABLE_LEAK_FINDER)
|
|
|
|
#define XML_LEAK_FINDER
|
|
|
|
#include "LeakFinder.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-01-29 14:28:19 -05:00
|
|
|
|
2011-10-21 20:15:12 -04:00
|
|
|
void ShowCrashReport(int)
|
|
|
|
{
|
|
|
|
std::signal(SIGSEGV, SIG_DFL);
|
|
|
|
|
|
|
|
printf("\n\nMCServer has crashed!\n");
|
|
|
|
|
|
|
|
exit(-1);
|
|
|
|
}
|
2011-10-03 14:41:19 -04:00
|
|
|
|
2012-02-13 16:47:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-10-03 14:41:19 -04:00
|
|
|
int main( int argc, char **argv )
|
|
|
|
{
|
|
|
|
(void)argc;
|
|
|
|
(void)argv;
|
2012-02-13 16:47:03 -05:00
|
|
|
|
|
|
|
#if defined(_MSC_VER) && defined(_DEBUG) && defined(ENABLE_LEAK_FINDER)
|
|
|
|
InitLeakFinder();
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef _DEBUG
|
2011-10-03 14:41:19 -04:00
|
|
|
_CrtSetDbgFlag ( _CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF );
|
2012-02-13 16:47:03 -05:00
|
|
|
|
|
|
|
// _X: The simple built-in CRT leak finder - simply break when allocating the Nth block ({N} is listed in the leak output)
|
|
|
|
// Only useful when the leak is in the same sequence all the time
|
|
|
|
// _CrtSetBreakAlloc(85950);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _DEBUG
|
2011-10-21 20:15:12 -04:00
|
|
|
std::signal(SIGSEGV, ShowCrashReport);
|
2012-02-13 16:47:03 -05:00
|
|
|
#endif
|
2011-10-21 20:15:12 -04:00
|
|
|
|
2011-10-03 14:41:19 -04:00
|
|
|
try
|
|
|
|
{
|
2011-10-21 20:15:12 -04:00
|
|
|
cRoot Root;
|
2011-10-03 14:41:19 -04:00
|
|
|
Root.Start();
|
|
|
|
}
|
|
|
|
catch( std::exception& e )
|
|
|
|
{
|
|
|
|
LOGERROR("Standard exception: %s", e.what() );
|
|
|
|
}
|
|
|
|
catch( ... )
|
|
|
|
{
|
|
|
|
LOGERROR("Unknown exception!");
|
|
|
|
}
|
2011-11-07 20:25:01 -05:00
|
|
|
|
2012-02-13 16:47:03 -05:00
|
|
|
#if USE_SQUIRREL
|
2011-11-07 20:25:01 -05:00
|
|
|
SquirrelVM::Shutdown();
|
2012-02-13 16:47:03 -05:00
|
|
|
#endif
|
2011-11-07 20:25:01 -05:00
|
|
|
|
2012-02-13 16:47:03 -05:00
|
|
|
#if defined(_MSC_VER) && defined(_DEBUG) && defined(ENABLE_LEAK_FINDER)
|
|
|
|
DeinitLeakFinder();
|
|
|
|
#endif
|
|
|
|
|
2011-10-03 14:41:19 -04:00
|
|
|
return 0;
|
|
|
|
}
|
2012-02-13 16:47:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|