EntryPoint.cpp 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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/CConsoleHandler.h"
  13. #include "../lib/logging/CBasicLogConfigurator.h"
  14. #include "../lib/filesystem/CFilesystemLoader.h"
  15. #include "../lib/filesystem/Filesystem.h"
  16. #include "../lib/VCMIDirs.h"
  17. static const int LISTENING_PORT = 3031;
  18. int main(int argc, const char * argv[])
  19. {
  20. CResourceHandler::initialize();
  21. CResourceHandler::load("config/filesystem.json"); // FIXME: we actually need only config directory for schemas, can be reduced
  22. #ifndef VCMI_IOS
  23. CConsoleHandler console;
  24. #endif
  25. CBasicLogConfigurator logConfigurator(VCMIDirs::get().userLogsPath() / "VCMI_Lobby_log.txt", &console);
  26. logConfigurator.configureDefault();
  27. auto databasePath = VCMIDirs::get().userDataPath() / "vcmiLobby.db";
  28. logGlobal->info("Opening database %s", databasePath.string());
  29. LobbyServer server(databasePath);
  30. logGlobal->info("Starting server on port %d", LISTENING_PORT);
  31. try
  32. {
  33. server.start(LISTENING_PORT);
  34. }
  35. catch (const boost::system::system_error & e)
  36. {
  37. logGlobal->error("Failed to start server! Another server already uses the same port? Reason: '%s'", e.what());
  38. return 1;
  39. }
  40. server.run();
  41. return 0;
  42. }