From 729da2c0baaa2aa8441bd132ebd98d72b5a5d52d Mon Sep 17 00:00:00 2001 From: David Cernat Date: Fri, 11 Nov 2016 23:46:17 +0200 Subject: [PATCH] Improve logic and clarity of LocalPlayer's charGenThread() Until now, the fact that charGenThread() returned false whenever the player had a menu open was preventing Main::UpdateWorld() from running at all with a menu open. The result was that no player packets from LocalPlayer::Update() were being sent by a player in a menu. --- apps/openmw/mwmp/LocalPlayer.cpp | 104 ++++++++++++++++--------------- 1 file changed, 55 insertions(+), 49 deletions(-) diff --git a/apps/openmw/mwmp/LocalPlayer.cpp b/apps/openmw/mwmp/LocalPlayer.cpp index f2221d41f..24dedc79d 100644 --- a/apps/openmw/mwmp/LocalPlayer.cpp +++ b/apps/openmw/mwmp/LocalPlayer.cpp @@ -76,63 +76,69 @@ void LocalPlayer::charGen(int stageFirst, int stageEnd) bool LocalPlayer::charGenThread() // todo: need fix { MWBase::WindowManager *windowManager = MWBase::Environment::get().getWindowManager(); - if (windowManager->isGuiMode()) + + // If we haven't finished CharGen and we're in a menu, it must be + // one of the CharGen menus, so go no further until it's closed + if (windowManager->isGuiMode() && CharGenStage()->end != 0) return false; - if (CharGenStage()->current >= CharGenStage()->end) + // If the current stage of CharGen is not the last one, + // move to the next one + else if (CharGenStage()->current < CharGenStage()->end) { - - if (GetNetworking()->isConnected() && CharGenStage()->current == CharGenStage()->end && - CharGenStage()->end != 0) + switch (CharGenStage()->current) { - MWBase::World *world = MWBase::Environment::get().getWorld(); - MWWorld::Ptr player = world->getPlayerPtr(); - (*Npc()) = *player.get()->mBase; - (*BirthSign()) = world->getPlayer().getBirthSign(); + case 0: + windowManager->pushGuiMode(MWGui::GM_Name); + break; + case 1: + windowManager->pushGuiMode(MWGui::GM_Race); + break; + case 2: + windowManager->pushGuiMode(MWGui::GM_Class); + break; + case 3: + windowManager->pushGuiMode(MWGui::GM_Birth); + break; + default: + windowManager->pushGuiMode(MWGui::GM_Review); + break; + } + GetNetworking()->GetPlayerPacket(ID_GAME_CHARGEN)->Send(this); + CharGenStage()->current++; - LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "%s", "Sending ID_GAME_BASE_INFO to server with my CharGen info"); - GetNetworking()->GetPlayerPacket(ID_GAME_BASE_INFO)->Send(this); + return false; + } + + // If we've reached the last stage of CharGen, send the + // corresponding packets and mark CharGen as finished + else if (CharGenStage()->end != 0) + { + MWBase::World *world = MWBase::Environment::get().getWorld(); + MWWorld::Ptr player = world->getPlayerPtr(); + (*Npc()) = *player.get()->mBase; + (*BirthSign()) = world->getPlayer().getBirthSign(); - if (CharGenStage()->end != 1) - { - updateDynamicStats(true); - updateAttributes(true); - updateSkills(true); - updateLevel(true); - sendClass(); - GetNetworking()->GetPlayerPacket(ID_GAME_CHARGEN)->Send(this); - } - CharGenStage()->end = 0; - /*RakNet::BitStream bs; - GetNetworking()->GetPlayerPacket(ID_GAME_BASE_INFO)->Packet(&bs, this, true); - GetNetworking()->SendData(&bs);*/ + LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "%s", "Sending ID_GAME_BASE_INFO to server with my CharGen info"); + GetNetworking()->GetPlayerPacket(ID_GAME_BASE_INFO)->Send(this); + // Send stats packets if this is the 2nd round of CharGen that + // only happens for new characters + if (CharGenStage()->end != 1) + { + updateDynamicStats(true); + updateAttributes(true); + updateSkills(true); + updateLevel(true); + sendClass(); + GetNetworking()->GetPlayerPacket(ID_GAME_CHARGEN)->Send(this); } - return true; - } - - switch (CharGenStage()->current) - { - case 0: - windowManager->pushGuiMode(MWGui::GM_Name); - break; - case 1: - windowManager->pushGuiMode(MWGui::GM_Race); - break; - case 2: - windowManager->pushGuiMode(MWGui::GM_Class); - break; - case 3: - windowManager->pushGuiMode(MWGui::GM_Birth); - break; - default: - windowManager->pushGuiMode(MWGui::GM_Review); - break; - } - GetNetworking()->GetPlayerPacket(ID_GAME_CHARGEN)->Send(this); - CharGenStage()->current++; - - return false; + + // Set the last stage variable to 0 to indicate that CharGen is finished + CharGenStage()->end = 0; + } + + return true; } void LocalPlayer::updateDynamicStats(bool forceUpdate)