mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-10-24 00:08:07 +00:00

* Move away from constructor queries Fix up other large tables to have proper backup lookups Revert "idk im just dumb ig" This reverts commit 5d5be5df53b8959b42b291613d7db749a65a3585. idk im just dumb ig * Fix slow components registry lookup * add define for cdclient cache all * Huge loot namespace rework - Remove all excess memory usage - do not cache components registry - cache loot matrices on startup of the destroyable component - convert loot singleton class to a namespace - rework loot cdclient tables to operate closer to how someone would actually use them (basically doing the previous LootGenerator::LootGenerator caching but in those tables) - Memory usage reduced by 10%+ across the board * cache rebuild matrix * Database: move reading to own function Also change name of cache to PascalCase * Database: Move common function rading
39 lines
1.5 KiB
C++
39 lines
1.5 KiB
C++
#include "GrowingFlower.h"
|
|
#include "MissionComponent.h"
|
|
#include "eMissionTaskType.h"
|
|
#include "eMissionState.h"
|
|
#include "Loot.h"
|
|
|
|
void GrowingFlower::OnSkillEventFired(Entity* self, Entity* target, const std::string& message) {
|
|
if (!self->GetVar<bool>(u"blooming") && (message == "waterspray" || message == "shovelgrow")) {
|
|
self->SetVar<bool>(u"blooming", true);
|
|
self->SetNetworkVar(u"blooming", true);
|
|
self->AddTimer("FlowerDie", GrowingFlower::aliveTime);
|
|
|
|
const auto mission1 = self->GetVar<int32_t>(u"missionID");
|
|
const auto mission2 = self->GetVar<int32_t>(u"missionID2");
|
|
|
|
Loot::DropActivityLoot(target, self, self->GetLOT(), 0);
|
|
|
|
auto* missionComponent = target->GetComponent<MissionComponent>();
|
|
if (missionComponent != nullptr) {
|
|
for (const auto mission : achievementIDs)
|
|
missionComponent->ForceProgressTaskType(mission, static_cast<uint32_t>(eMissionTaskType::SCRIPT), 1);
|
|
|
|
if (mission1 && missionComponent->GetMissionState(mission1) == eMissionState::ACTIVE)
|
|
missionComponent->ForceProgressTaskType(mission1, static_cast<uint32_t>(eMissionTaskType::SCRIPT), 1);
|
|
|
|
if (mission2 && missionComponent->GetMissionState(mission2) == eMissionState::ACTIVE)
|
|
missionComponent->ForceProgressTaskType(mission2, static_cast<uint32_t>(eMissionTaskType::SCRIPT), 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
void GrowingFlower::OnTimerDone(Entity* self, std::string message) {
|
|
if (message == "FlowerDie") {
|
|
self->Smash();
|
|
}
|
|
}
|
|
|
|
const std::vector<uint32_t> GrowingFlower::achievementIDs = { 143, 152, 153, 1409, 1507, 1544, 1581, 1845 };
|