1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-21 23:53:56 +00:00

[Server] Use Utils function as workaround for "bad exception" on Windows

This commit is contained in:
David Cernat 2017-12-04 14:32:23 +02:00
parent cfb5835e17
commit 456bcee68a
6 changed files with 43 additions and 14 deletions

View file

@ -93,10 +93,10 @@ std::deque<std::string> CommandController::cmdParser(const std::string &message)
/*auto const command = '/' >> *~x3::char_(sep) >> sep; /*auto const command = '/' >> *~x3::char_(sep) >> sep;
if (!x3::phrase_parse(message.cbegin(), message.cend(), arguments, command, ret)) if (!x3::phrase_parse(message.cbegin(), message.cend(), arguments, command, ret))
throw runtime_error("failed to parse message: "+ message);*/ Utils::throwError("failed to parse message: "+ message);*/
if (!x3::parse(message.cbegin(), message.cend(), arguments, ret)) if (!x3::parse(message.cbegin(), message.cend(), arguments, ret))
throw runtime_error("failed to parse message: " + message); Utils::throwError("failed to parse message: " + message);
return ret; return ret;
} }

View file

@ -100,7 +100,7 @@ EventController::EventController(LuaState *luaCtrl)
}); });
if (!found) if (!found)
throw runtime_error("Event " + to_string(i) + " is not registered. Dear developer, please fix me :D"); Utils::throwError("Event " + to_string(i) + " is not registered");
#endif #endif
events[i]; // create core event events[i]; // create core event
} }

View file

@ -406,7 +406,7 @@ void checkDependencies(const vector<ServerModuleInfo> &modules, const ServerModu
sstr << depNameRequest << ": version \"" << depVersionFound << "\" is not applicable for \"" sstr << depNameRequest << ": version \"" << depVersionFound << "\" is not applicable for \""
<< smi.name << "\" expected \"" << depVersionRequest + "\""; << smi.name << "\" expected \"" << depVersionRequest + "\"";
if (fatal) if (fatal)
throw runtime_error(sstr.str()); Utils::throwError(sstr.str());
else else
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "%s", sstr.str().c_str()); LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "%s", sstr.str().c_str());
} }
@ -416,7 +416,7 @@ void checkDependencies(const vector<ServerModuleInfo> &modules, const ServerModu
stringstream sstr; stringstream sstr;
sstr << depNameRequest + " \"" << depVersionRequest << "\" not found."; sstr << depNameRequest + " \"" << depVersionRequest << "\" not found.";
if (fatal) if (fatal)
throw runtime_error(sstr.str()); Utils::throwError(sstr.str());
else else
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "%s", sstr.str().c_str()); LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "%s", sstr.str().c_str());
} }
@ -468,7 +468,7 @@ vector<vector<ServerModuleInfo>::iterator> loadOrderSolver(vector<ServerModuleIn
stringstream sstr; stringstream sstr;
sstr << "Found circular dependency: \"" << (*it)->name << "\" and \"" << (*found)->name sstr << "Found circular dependency: \"" << (*it)->name << "\" and \"" << (*found)->name
<< "\" depend on each other" << endl; << "\" depend on each other" << endl;
throw runtime_error(sstr.str()); Utils::throwError(sstr.str());
} }
} }
@ -497,7 +497,7 @@ void LuaState::loadModules(const std::string &moduleDir, std::vector<std::string
auto readConfig = [this](path homePath){ auto readConfig = [this](path homePath){
const auto mainScript = "main.lua"; const auto mainScript = "main.lua";
if (!is_directory(homePath / "modules")) if (!is_directory(homePath / "modules"))
throw runtime_error(homePath.string() + ": No such directory."); Utils::throwError(homePath.string() + ": No such directory.");
for (const auto &moduleDir : directory_iterator(homePath / "modules")) for (const auto &moduleDir : directory_iterator(homePath / "modules"))
{ {
if (is_directory(moduleDir.status()) && exists(moduleDir.path() / mainScript)) if (is_directory(moduleDir.status()) && exists(moduleDir.path() / mainScript))
@ -557,7 +557,7 @@ void LuaState::loadModules(const std::string &moduleDir, std::vector<std::string
} }
} }
if (!found) if (!found)
throw runtime_error("Module: \"" + mssp + "\" not found"); Utils::throwError("Module: \"" + mssp + "\" not found");
} }
} }
else else

View file

@ -6,6 +6,8 @@
using namespace std; using namespace std;
static std::string lastErrorMessage = "unknown error";
const vector<string> Utils::split(const string &str, int delimiter) const vector<string> Utils::split(const string &str, int delimiter)
{ {
string buffer; string buffer;
@ -52,3 +54,20 @@ ESM::Cell Utils::getCellFromDescription(std::string cellDescription)
return cell; return cell;
} }
const std::string Utils::getLastError()
{
return lastErrorMessage;
}
void Utils::throwError(const std::string errorMessage)
{
#ifdef _WIN32
// Throwing exceptions makes them show up as "bad exception" on Windows with
// our stacktracer, so record their intended error messages separately here
// when possible
lastErrorMessage = errorMessage;
#endif
throw runtime_error(errorMessage);
}

View file

@ -40,6 +40,10 @@ namespace Utils
ESM::Cell getCellFromDescription(std::string cellDescription); ESM::Cell getCellFromDescription(std::string cellDescription);
const std::string getLastError();
void throwError(std::string errorMessage);
template<size_t N> template<size_t N>
constexpr unsigned int hash(const char(&str)[N], size_t I = N) constexpr unsigned int hash(const char(&str)[N], size_t I = N)
{ {

View file

@ -151,7 +151,13 @@ int main(int argc, char *argv[])
} }
catch (const exception &e) catch (const exception &e)
{ {
LOG_MESSAGE_SIMPLE(Log::LOG_FATAL, " Woops, something wrong! Exception:\n\t%s", e.what()); LOG_MESSAGE_SIMPLE(Log::LOG_FATAL, "A fatal error has occurred!");
#ifndef _WIN32
LOG_APPEND(Log::LOG_FATAL, "\t%s", e.what());
#else
LOG_APPEND(Log::LOG_FATAL, "\t%s", Utils::getLastError().c_str());
#endif
} }
stacktrace(); stacktrace();
@ -232,21 +238,21 @@ int main(int argc, char *argv[])
case RakNet::RAKNET_STARTED: case RakNet::RAKNET_STARTED:
break; break;
case RakNet::RAKNET_ALREADY_STARTED: case RakNet::RAKNET_ALREADY_STARTED:
throw runtime_error("Already started"); Utils::throwError("Already started");
case RakNet::INVALID_SOCKET_DESCRIPTORS: case RakNet::INVALID_SOCKET_DESCRIPTORS:
throw runtime_error("Incorrect port or address"); Utils::throwError("Incorrect port or address");
case RakNet::INVALID_MAX_CONNECTIONS: case RakNet::INVALID_MAX_CONNECTIONS:
throw runtime_error("Max players cannot be negative or 0"); Utils::throwError("Max players cannot be negative or 0");
case RakNet::SOCKET_FAILED_TO_BIND: case RakNet::SOCKET_FAILED_TO_BIND:
case RakNet::SOCKET_PORT_ALREADY_IN_USE: case RakNet::SOCKET_PORT_ALREADY_IN_USE:
case RakNet::PORT_CANNOT_BE_ZERO: case RakNet::PORT_CANNOT_BE_ZERO:
throw runtime_error("Failed to bind port"); Utils::throwError("Failed to bind port");
case RakNet::SOCKET_FAILED_TEST_SEND: case RakNet::SOCKET_FAILED_TEST_SEND:
case RakNet::SOCKET_FAMILY_NOT_SUPPORTED: case RakNet::SOCKET_FAMILY_NOT_SUPPORTED:
case RakNet::FAILED_TO_CREATE_NETWORK_THREAD: case RakNet::FAILED_TO_CREATE_NETWORK_THREAD:
case RakNet::COULD_NOT_GENERATE_GUID: case RakNet::COULD_NOT_GENERATE_GUID:
case RakNet::STARTUP_OTHER_FAILURE: case RakNet::STARTUP_OTHER_FAILURE:
throw runtime_error("Cannot start server"); Utils::throwError("Cannot start server");
} }
peer->SetMaximumIncomingConnections((unsigned short) (players)); peer->SetMaximumIncomingConnections((unsigned short) (players));