Create lobby even if the run callbacks function is never run.

This commit is contained in:
Mr_Goldberg 2019-06-01 13:11:27 -04:00
parent c4e0c855df
commit 794469c4cf
No known key found for this signature in database
GPG Key ID: 8597D87419DEF278
4 changed files with 16 additions and 10 deletions

View File

@ -19,21 +19,22 @@
#include <fstream>
static void network_thread(Networking *network)
static void background_thread(Steam_Client *client)
{
PRINT_DEBUG("network thread starting\n");
PRINT_DEBUG("background thread starting\n");
while (1) {
std::this_thread::sleep_for(std::chrono::seconds(1));
global_mutex.lock();
if (!network->isAlive()) {
if (!client->network->isAlive()) {
global_mutex.unlock();
//delete network;
PRINT_DEBUG("network thread exit\n");
PRINT_DEBUG("background thread exit\n");
return;
}
PRINT_DEBUG("network thread run\n");
network->Run();
PRINT_DEBUG("background thread run\n");
client->network->Run();
client->steam_matchmaking->RunBackground();
global_mutex.unlock();
}
}
@ -1672,7 +1673,7 @@ void Steam_Client::UnregisterCallResult( class CCallbackBase *pCallback, SteamAP
void Steam_Client::RunCallbacks(bool runClientCB, bool runGameserverCB)
{
std::lock_guard<std::recursive_mutex> lock(global_mutex);
if (!network_keepalive.joinable()) network_keepalive = std::thread(network_thread, network);
if (!background_keepalive.joinable()) background_keepalive = std::thread(background_thread, this);
network->Run();
PRINT_DEBUG("Steam_Client::RunCallbacks steam_matchmaking_servers\n");

View File

@ -115,7 +115,7 @@ public:
bool user_logged_in = false;
bool server_init = false;
std::thread network_keepalive;
std::thread background_keepalive;
Steam_Client();
~Steam_Client();

View File

@ -462,6 +462,7 @@ CSteamID GetFriendFromSourceByIndex( CSteamID steamIDSource, int iFriend )
bool IsUserInSource( CSteamID steamIDUser, CSteamID steamIDSource )
{
PRINT_DEBUG("Steam_Friends::IsUserInSource %llu %llu\n", steamIDUser.ConvertToUint64(), steamIDSource.ConvertToUint64());
std::lock_guard<std::recursive_mutex> lock(global_mutex);
if (steamIDUser == settings->get_local_steam_id()) {
if (settings->get_lobby() == steamIDSource) {
return true;

View File

@ -1115,8 +1115,7 @@ bool SetLinkedLobby( CSteamID steamIDLobby, CSteamID steamIDLobbyDependent )
return false;
}
void RunCallbacks()
void RunBackground()
{
remove_lobbies();
Create_pending_lobbies();
@ -1125,6 +1124,11 @@ void RunCallbacks()
send_lobby_data();
last_sent_lobbies = std::chrono::high_resolution_clock::now();
}
}
void RunCallbacks()
{
RunBackground();
if (searching) {
PRINT_DEBUG("Searching for lobbies %zu\n", lobbies.size());