mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-25 14:17:00 +00:00
0c1ee0513d
* Changed how the TryParse function works (and also did some general cleanup along the way) * Update noexcept attributes (verified these are correct) * Add fp overload for MacOS functionality * resolving some feedback * Split out unrelated changes to CleanupRoundup branch * Update in response to feedback * the consequences of emo's member variable renaming request * Revert "the consequences of emo's member variable renaming request" This reverts commitbf318caeda
. * Fully revert renaming attempt * Revert "the consequences of emo's member variable renaming request" This reverts commitbf318caeda
. Fully revert renaming attempt * Created ClientVersion.h and moved the client version defaults to it * Fix partial parsing and MacOS floating point errors * attempting fix to MacOS compiler error * syntax pass (should be the last commit unless the CI fails) * ah, wait, forgot to uncomment the preprocessor statements for MacOS. THIS should be the last commit pending CI * Okay, one last thing I noticed: We were including C headers here. Now they're C++ headers. Pinky swear this is it! * typo and I am OCD. please let this be the last * hash is usally but not always noexcept, so the specifier should go * Address MOST of the feedback * address the claim codes issue
65 lines
1.8 KiB
C++
65 lines
1.8 KiB
C++
#include "FvBrickPuzzleServer.h"
|
|
#include "GeneralUtils.h"
|
|
#include "dZoneManager.h"
|
|
#include "Spawner.h"
|
|
#include "QuickBuildComponent.h"
|
|
|
|
void FvBrickPuzzleServer::OnStartup(Entity* self) {
|
|
const auto myGroup = GeneralUtils::UTF16ToWTF8(self->GetVar<std::u16string>(u"spawner_name"));
|
|
|
|
const auto pipeNum = GeneralUtils::TryParse<int32_t>(myGroup.substr(10, 1));
|
|
if (!pipeNum) return;
|
|
|
|
if (pipeNum != 1) {
|
|
self->AddTimer("reset", 30);
|
|
}
|
|
}
|
|
|
|
void FvBrickPuzzleServer::OnDie(Entity* self, Entity* killer) {
|
|
const auto myGroup = GeneralUtils::UTF16ToWTF8(self->GetVar<std::u16string>(u"spawner_name"));
|
|
|
|
const auto pipeNum = GeneralUtils::TryParse<int32_t>(myGroup.substr(10, 1));
|
|
if (!pipeNum) return;
|
|
|
|
const auto pipeGroup = myGroup.substr(0, 10);
|
|
|
|
const auto nextPipeNum = pipeNum.value() + 1;
|
|
|
|
const auto samePipeSpawners = Game::zoneManager->GetSpawnersByName(myGroup);
|
|
|
|
if (!samePipeSpawners.empty()) {
|
|
samePipeSpawners[0]->SoftReset();
|
|
|
|
samePipeSpawners[0]->Deactivate();
|
|
}
|
|
|
|
if (killer && killer->IsPlayer()) {
|
|
const auto nextPipe = pipeGroup + std::to_string(nextPipeNum);
|
|
|
|
const auto nextPipeSpawners = Game::zoneManager->GetSpawnersByName(nextPipe);
|
|
|
|
if (!nextPipeSpawners.empty()) {
|
|
nextPipeSpawners[0]->Activate();
|
|
}
|
|
} else {
|
|
const auto nextPipe = pipeGroup + "1";
|
|
|
|
const auto firstPipeSpawners = Game::zoneManager->GetSpawnersByName(nextPipe);
|
|
|
|
if (!firstPipeSpawners.empty()) {
|
|
firstPipeSpawners[0]->Activate();
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
void FvBrickPuzzleServer::OnTimerDone(Entity* self, std::string timerName) {
|
|
if (timerName == "reset") {
|
|
auto* quickBuildComponent = self->GetComponent<QuickBuildComponent>();
|
|
|
|
if (quickBuildComponent != nullptr && quickBuildComponent->GetState() == eQuickBuildState::OPEN) {
|
|
self->Smash(self->GetObjectID(), eKillType::SILENT);
|
|
}
|
|
}
|
|
}
|