From ee0cf4e0a9bc7cc114d67e3746a4444d85e730e0 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Sat, 1 Aug 2015 14:15:55 -0400 Subject: [PATCH] Fix custom startup ages So, that net comm auth message was actually useful... Trololololo. Whatever. --- Sources/Plasma/Apps/plClient/plClient.cpp | 21 ++++++++++++++++++--- Sources/Plasma/Apps/plClient/plClient.h | 2 ++ 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/Sources/Plasma/Apps/plClient/plClient.cpp b/Sources/Plasma/Apps/plClient/plClient.cpp index f134e84a..9ff117ed 100644 --- a/Sources/Plasma/Apps/plClient/plClient.cpp +++ b/Sources/Plasma/Apps/plClient/plClient.cpp @@ -807,6 +807,17 @@ bool plClient::MsgReceive(plMessage* msg) return true; } + //============================================================================ + // plNetCommAuthMsg + //============================================================================ + if (plNetCommAuthMsg* authMsg = plNetCommAuthMsg::ConvertNoRef(msg)) { + plgDispatch::Dispatch()->UnRegisterForExactType(plNetCommAuthMsg::Index(), GetKey()); + if (IS_NET_SUCCESS(authMsg->result)) { + SetFlag(kFlagInitialAuthComplete); + IPatchGlobalAgeFiles(); + } + } + return hsKeyedObject::MsgReceive(msg); } @@ -1427,6 +1438,7 @@ bool plClient::StartInit() // // Init Net before loading things // + plgDispatch::Dispatch()->RegisterForExactType(plNetCommAuthMsg::Index(), GetKey()); plNetClientMgr::GetInstance()->RegisterAs(kNetClientMgr_KEY); plAgeLoader::GetInstance()->Init(); @@ -1465,6 +1477,7 @@ bool plClient::BeginGame() { plNetClientMgr::GetInstance()->Init(); IPlayIntroMovie("avi/CyanWorlds.webm", 0.f, 0.f, 0.f, 1.f, 1.f, 0.75); + SetFlag(kFlagIntroComplete); if (GetDone()) return false; IPatchGlobalAgeFiles(); return true; @@ -1473,10 +1486,12 @@ bool plClient::BeginGame() //============================================================================ void plClient::IPatchGlobalAgeFiles( void ) { - plgDispatch::Dispatch()->RegisterForExactType(plResPatcherMsg::Index(), GetKey()); + if (HasFlag(kFlagIntroComplete) && HasFlag(kFlagInitialAuthComplete)) { + plgDispatch::Dispatch()->RegisterForExactType(plResPatcherMsg::Index(), GetKey()); - plResPatcher* patcher = plResPatcher::GetInstance(); - patcher->Update(plManifest::EssentialGameManifests()); + plResPatcher* patcher = plResPatcher::GetInstance(); + patcher->Update(plManifest::EssentialGameManifests()); + } } void plClient::InitDLLs() diff --git a/Sources/Plasma/Apps/plClient/plClient.h b/Sources/Plasma/Apps/plClient/plClient.h index 485d5045..197cbbdf 100644 --- a/Sources/Plasma/Apps/plClient/plClient.h +++ b/Sources/Plasma/Apps/plClient/plClient.h @@ -248,6 +248,8 @@ public: kFlagDBGDisableRRequests, kFlagAsyncInitComplete, kFlagGlobalDataLoaded, + kFlagInitialAuthComplete, + kFlagIntroComplete, }; bool HasFlag(int f) const { return fFlags.IsBitSet(f); }