EntryPoint.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /*
  2. * EntryPoint.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "LobbyServer.h"
  12. #include "../lib/logging/CBasicLogConfigurator.h"
  13. #include "../lib/filesystem/CFilesystemLoader.h"
  14. #include "../lib/filesystem/Filesystem.h"
  15. #include "../lib/VCMIDirs.h"
  16. static const int LISTENING_PORT = 3031;
  17. int main(int argc, const char * argv[])
  18. {
  19. CResourceHandler::initialize();
  20. CResourceHandler::load("config/filesystem.json"); // FIXME: we actually need only config directory for schemas, can be reduced
  21. #ifndef VCMI_IOS
  22. console = new CConsoleHandler();
  23. #endif
  24. CBasicLogConfigurator logConfig(VCMIDirs::get().userLogsPath() / "VCMI_Lobby_log.txt", console);
  25. logConfig.configureDefault();
  26. auto databasePath = VCMIDirs::get().userDataPath() / "vcmiLobby.db";
  27. logGlobal->info("Opening database %s", databasePath.string());
  28. LobbyServer server(databasePath);
  29. logGlobal->info("Starting server on port %d", LISTENING_PORT);
  30. try
  31. {
  32. server.start(LISTENING_PORT);
  33. }
  34. catch (const boost::system::system_error & e)
  35. {
  36. logGlobal->error("Failed to start server! Another server already uses the same port? Reason: '%s'", e.what());
  37. return 1;
  38. }
  39. server.run();
  40. return 0;
  41. }