From 910448b0e79f386efd33a5f62774c50718eecc47 Mon Sep 17 00:00:00 2001 From: Marcono1234 Date: Tue, 25 Jan 2022 00:35:26 +0100 Subject: [PATCH 1/2] Fix MasterServer not always closing database connection on exit --- dMasterServer/MasterServer.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/dMasterServer/MasterServer.cpp b/dMasterServer/MasterServer.cpp index b6ccac63..eb8a7f0f 100644 --- a/dMasterServer/MasterServer.cpp +++ b/dMasterServer/MasterServer.cpp @@ -66,7 +66,7 @@ int main(int argc, char** argv) { //Create all the objects we need to run our service: Game::logger = SetupLogger(); - if (!Game::logger) return 0; + if (!Game::logger) return -1; Game::logger->Log("MasterServer", "Starting Master server...\n"); Game::logger->Log("MasterServer", "Version: %i.%i\n", PROJECT_VERSION_MAJOR, PROJECT_VERSION_MINOR); @@ -118,7 +118,7 @@ int main(int argc, char** argv) { Database::Connect(mysql_host, mysql_database, mysql_username, mysql_password); } catch (sql::SQLException& ex) { Game::logger->Log("MasterServer", "Got an error while connecting to the database: %s\n", ex.what()); - return 0; + return -1; } //If the first command line argument is -a or --account then make the user @@ -166,6 +166,10 @@ int main(int argc, char** argv) { delete statement; std::cout << "Account created successfully!\n"; + + Database::Destroy(); + delete Game::logger; + return 0; } @@ -266,7 +270,8 @@ int main(int argc, char** argv) { //10m shutdown for universe kill command if (shouldShutdown) { if (framesSinceKillUniverseCommand >= 40000) { - std::exit(0); + //Break main loop and exit + break; } else framesSinceKillUniverseCommand++; From 4cd38f117461643f6d3dcec8501849022797ed95 Mon Sep 17 00:00:00 2001 From: Marcono1234 Date: Tue, 25 Jan 2022 00:41:35 +0100 Subject: [PATCH 2/2] Use exit code macros --- dMasterServer/MasterServer.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/dMasterServer/MasterServer.cpp b/dMasterServer/MasterServer.cpp index eb8a7f0f..aa79b5df 100644 --- a/dMasterServer/MasterServer.cpp +++ b/dMasterServer/MasterServer.cpp @@ -66,7 +66,7 @@ int main(int argc, char** argv) { //Create all the objects we need to run our service: Game::logger = SetupLogger(); - if (!Game::logger) return -1; + if (!Game::logger) return EXIT_FAILURE; Game::logger->Log("MasterServer", "Starting Master server...\n"); Game::logger->Log("MasterServer", "Version: %i.%i\n", PROJECT_VERSION_MAJOR, PROJECT_VERSION_MINOR); @@ -83,7 +83,7 @@ int main(int argc, char** argv) { std::ifstream cdclient_fd(cdclient_path); if (!cdclient_fd.good()) { Game::logger->Log("WorldServer", "%s could not be opened\n", cdclient_path.c_str()); - return -1; + return EXIT_FAILURE; } cdclient_fd.close(); @@ -94,7 +94,7 @@ int main(int argc, char** argv) { Game::logger->Log("WorldServer", "Unable to connect to CDServer SQLite Database\n"); Game::logger->Log("WorldServer", "Error: %s\n", e.errorMessage()); Game::logger->Log("WorldServer", "Error Code: %i\n", e.errorCode()); - return -1; + return EXIT_FAILURE; } //Get CDClient initial information @@ -105,7 +105,7 @@ int main(int argc, char** argv) { Game::logger->Log("WorldServer", "May be caused by corrupted file: %s\n", cdclient_path.c_str()); Game::logger->Log("WorldServer", "Error: %s\n", e.errorMessage()); Game::logger->Log("WorldServer", "Error Code: %i\n", e.errorCode()); - return -1; + return EXIT_FAILURE; } //Connect to the MySQL Database @@ -118,7 +118,7 @@ int main(int argc, char** argv) { Database::Connect(mysql_host, mysql_database, mysql_username, mysql_password); } catch (sql::SQLException& ex) { Game::logger->Log("MasterServer", "Got an error while connecting to the database: %s\n", ex.what()); - return -1; + return EXIT_FAILURE; } //If the first command line argument is -a or --account then make the user @@ -170,7 +170,7 @@ int main(int argc, char** argv) { Database::Destroy(); delete Game::logger; - return 0; + return EXIT_SUCCESS; } int maxClients = 999; @@ -324,7 +324,7 @@ int main(int argc, char** argv) { delete Game::server; delete Game::logger; - return 0; + return EXIT_SUCCESS; } dLogger* SetupLogger() {