Merge pull request #557 optimized LUP Component

Optimized LUP Component to not use a query to build its list of worlds
This commit is contained in:
David Markowitz 2022-05-17 21:30:12 -07:00 committed by GitHub
commit a363d0734c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,21 +1,17 @@
#include "RocketLaunchLupComponent.h" #include "RocketLaunchLupComponent.h"
#include "CDClientDatabase.h"
#include "RocketLaunchpadControlComponent.h" #include "RocketLaunchpadControlComponent.h"
#include "InventoryComponent.h" #include "InventoryComponent.h"
#include "CharacterComponent.h" #include "CharacterComponent.h"
RocketLaunchLupComponent::RocketLaunchLupComponent(Entity* parent) : Component(parent) { RocketLaunchLupComponent::RocketLaunchLupComponent(Entity* parent) : Component(parent) {
m_Parent = parent; m_Parent = parent;
std::string zoneString = GeneralUtils::UTF16ToWTF8(m_Parent->GetVar<std::u16string>(u"MultiZoneIDs"));
// get the lup worlds from the cdclient std::stringstream ss(zoneString);
std::string query = "SELECT * FROM LUPZoneIDs;"; for (int i; ss >> i;) {
auto results = CDClientDatabase::ExecuteQuery(query); m_LUPWorlds.push_back(i);
while (!results.eof()) { if (ss.peek() == ';')
// fallback to 1600 incase there is an issue ss.ignore();
m_LUPWorlds.push_back(results.getIntField(0, 1600));
results.nextRow();
} }
results.finalize();
} }
RocketLaunchLupComponent::~RocketLaunchLupComponent() {} RocketLaunchLupComponent::~RocketLaunchLupComponent() {}
@ -29,11 +25,7 @@ void RocketLaunchLupComponent::OnUse(Entity* originator) {
} }
void RocketLaunchLupComponent::OnSelectWorld(Entity* originator, uint32_t index) { void RocketLaunchLupComponent::OnSelectWorld(Entity* originator, uint32_t index) {
// Add one to index because the actual LUP worlds start at index 1.
index++;
auto* rocketLaunchpadControlComponent = m_Parent->GetComponent<RocketLaunchpadControlComponent>(); auto* rocketLaunchpadControlComponent = m_Parent->GetComponent<RocketLaunchpadControlComponent>();
if (!rocketLaunchpadControlComponent) return; if (!rocketLaunchpadControlComponent) return;
rocketLaunchpadControlComponent->Launch(originator, m_LUPWorlds[index], 0); rocketLaunchpadControlComponent->Launch(originator, m_LUPWorlds[index], 0);