mirror of
				https://github.com/DarkflameUniverse/DarkflameServer.git
				synced 2025-10-25 00:38:08 +00:00 
			
		
		
		
	 0c1ee0513d
			
		
	
	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);
 | |
| 		}
 | |
| 	}
 | |
| }
 |