瀏覽代碼

Merge pull request #5465 from IvanSavenko/lobby_connect_fix

[1.6.7] Fix crash on attempting to connect newly created lobby room
Ivan Savenko 8 月之前
父節點
當前提交
ebb294e9dd
共有 2 個文件被更改,包括 10 次插入13 次删除
  1. 10 12
      server/CVCMIServer.cpp
  2. 0 1
      server/GlobalLobbyProcessor.cpp

+ 10 - 12
server/CVCMIServer.cpp

@@ -80,27 +80,25 @@ CVCMIServer::CVCMIServer(uint16_t port, bool runByClient)
 
 CVCMIServer::~CVCMIServer() = default;
 
-uint16_t CVCMIServer::prepare(bool connectToLobby, bool listenForConnections) {
-	if(connectToLobby) {
+uint16_t CVCMIServer::prepare(bool connectToLobby, bool listenForConnections)
+{
+	if(connectToLobby)
 		lobbyProcessor = std::make_unique<GlobalLobbyProcessor>(*this);
-		return 0;
-	} else {
-		return startAcceptingIncomingConnections(listenForConnections);
-	}
+
+	return startAcceptingIncomingConnections(listenForConnections);
 }
 
 uint16_t CVCMIServer::startAcceptingIncomingConnections(bool listenForConnections)
 {
 	networkServer = networkHandler->createServerTCP(*this);
 
-	port
-		? logNetwork->info("Port %d will be used", port)
-		: logNetwork->info("Randomly assigned port will be used");
-
-	// config port may be 0 => srvport will contain the OS-assigned port value
-
 	if (listenForConnections)
 	{
+		// config port may be 0 => srvport will contain the OS-assigned port value
+		port
+			? logNetwork->info("Port %d will be used", port)
+			: logNetwork->info("Randomly assigned port will be used");
+
 		auto srvport = networkServer->start(port);
 		logNetwork->info("Listening for connections at port %d", srvport);
 		return srvport;

+ 0 - 1
server/GlobalLobbyProcessor.cpp

@@ -99,7 +99,6 @@ void GlobalLobbyProcessor::receiveServerLoginSuccess(const JsonNode & json)
 {
 	// no-op, wait just for any new commands from lobby
 	logGlobal->info("Lobby: Successfully connected to lobby server");
-	owner.startAcceptingIncomingConnections(true);
 }
 
 void GlobalLobbyProcessor::receiveAccountJoinsRoom(const JsonNode & json)