mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-12-04 12:43:37 +00:00
5eca25e42a
* 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 * Update CDBehaviorParameterTable.cpp
53 lines
2.0 KiB
C++
53 lines
2.0 KiB
C++
#include "CDComponentsRegistryTable.h"
|
|
#include "eReplicaComponentType.h"
|
|
|
|
void CDComponentsRegistryTable::LoadValuesFromDatabase() {
|
|
// Now get the data
|
|
auto tableData = CDClientDatabase::ExecuteQuery("SELECT * FROM ComponentsRegistry");
|
|
while (!tableData.eof()) {
|
|
CDComponentsRegistry entry;
|
|
entry.id = tableData.getIntField("id", -1);
|
|
entry.component_type = static_cast<eReplicaComponentType>(tableData.getIntField("component_type", 0));
|
|
entry.component_id = tableData.getIntField("component_id", -1);
|
|
|
|
this->mappedEntries.insert_or_assign(((uint64_t)entry.component_type) << 32 | ((uint64_t)entry.id), entry.component_id);
|
|
this->mappedEntries.insert_or_assign(entry.id, 0);
|
|
|
|
tableData.nextRow();
|
|
}
|
|
|
|
tableData.finalize();
|
|
}
|
|
|
|
int32_t CDComponentsRegistryTable::GetByIDAndType(uint32_t id, eReplicaComponentType componentType, int32_t defaultValue) {
|
|
auto exists = mappedEntries.find(id);
|
|
if (exists != mappedEntries.end()) {
|
|
auto iter = mappedEntries.find(((uint64_t)componentType) << 32 | ((uint64_t)id));
|
|
return iter == mappedEntries.end() ? defaultValue : iter->second;
|
|
}
|
|
|
|
// Now get the data. Get all components of this entity so we dont do a query for each component
|
|
auto query = CDClientDatabase::CreatePreppedStmt("SELECT * FROM ComponentsRegistry WHERE id = ?;");
|
|
query.bind(1, static_cast<int32_t>(id));
|
|
|
|
auto tableData = query.execQuery();
|
|
|
|
while (!tableData.eof()) {
|
|
CDComponentsRegistry entry;
|
|
entry.id = tableData.getIntField("id", -1);
|
|
entry.component_type = static_cast<eReplicaComponentType>(tableData.getIntField("component_type", 0));
|
|
entry.component_id = tableData.getIntField("component_id", -1);
|
|
|
|
this->mappedEntries.insert_or_assign(((uint64_t)entry.component_type) << 32 | ((uint64_t)entry.id), entry.component_id);
|
|
|
|
tableData.nextRow();
|
|
}
|
|
|
|
mappedEntries.insert_or_assign(id, 0);
|
|
|
|
auto iter = this->mappedEntries.find(((uint64_t)componentType) << 32 | ((uint64_t)id));
|
|
|
|
return iter == this->mappedEntries.end() ? defaultValue : iter->second;
|
|
}
|
|
|