Initial commit
This commit is contained in:
544
scripting/towerdefense/database/general.sp
Normal file
544
scripting/towerdefense/database/general.sp
Normal file
@@ -0,0 +1,544 @@
|
||||
#pragma semicolon 1
|
||||
|
||||
#include <sourcemod>
|
||||
|
||||
#if defined INFO_INCLUDES
|
||||
#include "../info/constants.sp"
|
||||
#include "../info/enums.sp"
|
||||
#include "../info/variables.sp"
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Database Connection Callback
|
||||
*/
|
||||
public void ConnectToDB(Database db, const char[] error, any data) {
|
||||
if (!db || error[0]) {
|
||||
LogError("Database failure: %s", error);
|
||||
SetFailState("OnDatabaseConnectionResult: %s", error);
|
||||
} else {
|
||||
g_hDatabase = db;
|
||||
}
|
||||
}
|
||||
|
||||
/*======================================
|
||||
= Data Functions =
|
||||
======================================*/
|
||||
|
||||
/**
|
||||
* Starts to load all data from the database, calls Database_OnDataLoaded() when finished.
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadData() {
|
||||
Database_LoadTowers();
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads towers to its map.
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadTowers() {
|
||||
char sQuery[512];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery),
|
||||
"SELECT `tower`.`tower_id`, `level`, `tower`.`name`, `class`, `price`, `teleport_tower`, `damagetype`, `description`, `metal`, `weapon_id`, `attack`, `rotate`, `pitch`, `damage`, `attackspeed`, `area` " ...
|
||||
"FROM `tower` " ...
|
||||
"INNER JOIN `map` " ...
|
||||
"ON (`map`.`map_id` = %d) " ...
|
||||
"INNER JOIN `towerlevel` " ...
|
||||
"ON (`tower`.`tower_id` = `towerlevel`.`tower_id`) " ...
|
||||
"ORDER BY `tower`.`name` ASC, `level` ASC",
|
||||
g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadTowers, sQuery);
|
||||
}
|
||||
|
||||
public void Database_OnLoadTowers(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadTowers > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
int iTowerId = 0, iTowerLevel = 0;
|
||||
char sKey[64], sBuffer[128];
|
||||
|
||||
// Level Name Class Price Location Damagetype Description Metal WeaponId AttackPrimary AttackSecondary Rotate Pitch Damage Attackspeed Area
|
||||
// 1 EngineerTower Engineer 500 666 -626 -2 0 0 0 Melee ... 1000 1 1 0 0 45 1.0 1.0 1.0
|
||||
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
iTowerId = SQL_FetchInt(hResult, 0) - 1;
|
||||
iTowerLevel = SQL_FetchInt(hResult, 1);
|
||||
|
||||
// Save data only once
|
||||
if (iTowerLevel == 1) {
|
||||
// Save tower name
|
||||
Format(sKey, sizeof(sKey), "%d_name", iTowerId);
|
||||
SQL_FetchString(hResult, 2, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save tower class
|
||||
Format(sKey, sizeof(sKey), "%d_class", iTowerId);
|
||||
SQL_FetchString(hResult, 3, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save tower price
|
||||
Format(sKey, sizeof(sKey), "%d_price", iTowerId);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// Save tower location
|
||||
Format(sKey, sizeof(sKey), "%d_location", iTowerId);
|
||||
SQL_FetchString(hResult, 5, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save tower damagetype
|
||||
Format(sKey, sizeof(sKey), "%d_damagetype", iTowerId);
|
||||
SQL_FetchString(hResult, 6, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save tower description
|
||||
Format(sKey, sizeof(sKey), "%d_description", iTowerId);
|
||||
SQL_FetchString(hResult, 7, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
}
|
||||
|
||||
// PrintToServer("Level %d:", iTowerLevel);
|
||||
|
||||
// Save tower level metal
|
||||
Format(sKey, sizeof(sKey), "%d_%d_metal", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchInt(hResult, 8));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 8));
|
||||
|
||||
// Save tower level weapon index
|
||||
Format(sKey, sizeof(sKey), "%d_%d_weapon", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchInt(hResult, 9));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 9));
|
||||
|
||||
// Save tower level attack mode
|
||||
Format(sKey, sizeof(sKey), "%d_%d_attack", iTowerId, iTowerLevel);
|
||||
SQL_FetchString(hResult, 10, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapTowers, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save tower level rotate
|
||||
Format(sKey, sizeof(sKey), "%d_%d_rotate", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchInt(hResult, 11));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 11));
|
||||
|
||||
// Save tower level pitch
|
||||
Format(sKey, sizeof(sKey), "%d_%d_pitch", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchInt(hResult, 12));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 12));
|
||||
|
||||
// Save tower level damage
|
||||
Format(sKey, sizeof(sKey), "%d_%d_damage", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchFloat(hResult, 13));
|
||||
|
||||
// PrintToServer("%s => %f", sKey, SQL_FetchFloat(hResult, 13));
|
||||
|
||||
// Save tower level attackspeed
|
||||
Format(sKey, sizeof(sKey), "%d_%d_attackspeed", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchFloat(hResult, 14));
|
||||
|
||||
// PrintToServer("%s => %f", sKey, SQL_FetchFloat(hResult, 14));
|
||||
|
||||
// Save tower level area
|
||||
Format(sKey, sizeof(sKey), "%d_%d_area", iTowerId, iTowerLevel);
|
||||
SetTrieValue(g_hMapTowers, sKey, SQL_FetchFloat(hResult, 15));
|
||||
|
||||
// PrintToServer("%s => %f", sKey, SQL_FetchFloat(hResult, 15));
|
||||
}
|
||||
}
|
||||
|
||||
if (hResult != null) {
|
||||
CloseHandle(hResult);
|
||||
hResult = null;
|
||||
}
|
||||
|
||||
Database_LoadWeapons();
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads weapons to its map.
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadWeapons() {
|
||||
char sQuery[256];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery),
|
||||
"SELECT `name`, `index`, (`slot` - 1), `level`, (`quality` - 1), `classname`, `attributes`, (`preserve_attributes` - 1) " ...
|
||||
"FROM `weapon` " ...
|
||||
"ORDER BY `weapon_id` ASC");
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadWeapons, sQuery);
|
||||
}
|
||||
|
||||
public void Database_OnLoadWeapons(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadWeapons > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
int iWeaponId = 1;
|
||||
char sKey[64], sBuffer[128];
|
||||
|
||||
// Name Index Slot Level Quality Classname Attributes Preserve
|
||||
// Wrench 7 2 1 0 tf_weapon_wrench 1
|
||||
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
// Save weapon name
|
||||
Format(sKey, sizeof(sKey), "%d_name", iWeaponId);
|
||||
SQL_FetchString(hResult, 0, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWeapons, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save weapon index
|
||||
Format(sKey, sizeof(sKey), "%d_index", iWeaponId);
|
||||
SetTrieValue(g_hMapWeapons, sKey, SQL_FetchInt(hResult, 1));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 1));
|
||||
|
||||
// Save weapon slot
|
||||
Format(sKey, sizeof(sKey), "%d_slot", iWeaponId);
|
||||
SetTrieValue(g_hMapWeapons, sKey, SQL_FetchInt(hResult, 2));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 2));
|
||||
|
||||
// Save weapon level
|
||||
Format(sKey, sizeof(sKey), "%d_level", iWeaponId);
|
||||
SetTrieValue(g_hMapWeapons, sKey, SQL_FetchInt(hResult, 3));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 3));
|
||||
|
||||
// Save weapon quality
|
||||
Format(sKey, sizeof(sKey), "%d_quality", iWeaponId);
|
||||
SetTrieValue(g_hMapWeapons, sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// Save weapon classname
|
||||
Format(sKey, sizeof(sKey), "%d_classname", iWeaponId);
|
||||
SQL_FetchString(hResult, 5, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWeapons, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save weapon attributes
|
||||
Format(sKey, sizeof(sKey), "%d_attributes", iWeaponId);
|
||||
SQL_FetchString(hResult, 6, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWeapons, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save weapon preserve attributes
|
||||
Format(sKey, sizeof(sKey), "%d_preserve_attributes", iWeaponId);
|
||||
SetTrieValue(g_hMapWeapons, sKey, SQL_FetchInt(hResult, 7));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 7));
|
||||
|
||||
iWeaponId++;
|
||||
}
|
||||
}
|
||||
|
||||
if (hResult != null) {
|
||||
CloseHandle(hResult);
|
||||
hResult = null;
|
||||
}
|
||||
|
||||
Database_LoadWaves();
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads waves to its map.
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadWaves() {
|
||||
char sQuery[512];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery),
|
||||
"SELECT `wavetype`, `wave`.`name`, `class`, `quantity`, `health`, IF(`wavetype` & (SELECT `bit_value` FROM `wavetype` WHERE `wavetype`.`type` = 'air'), `teleport_air`, `teleport_ground`) " ...
|
||||
"FROM `wave` " ...
|
||||
"INNER JOIN `map` " ...
|
||||
"ON (`map`.`map_id` = %d) " ...
|
||||
"WHERE `wave_id` >= `wave_start` AND `wave_id` <= `wave_end` " ...
|
||||
"ORDER BY `wave_id` ASC",
|
||||
g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadWaves, sQuery);
|
||||
}
|
||||
|
||||
public void Database_OnLoadWaves(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadWaves > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
int iWaveId = 0;
|
||||
char sKey[64], sBuffer[128];
|
||||
|
||||
iMaxWaves = 0;
|
||||
|
||||
// Type Name Class Quantiy Health Location
|
||||
// 0 WeakScout Scout 4 125 560 -1795 -78 0 90 0
|
||||
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
// Save wave type
|
||||
Format(sKey, sizeof(sKey), "%d_type", iWaveId);
|
||||
SetTrieValue(g_hMapWaves, sKey, SQL_FetchInt(hResult, 0));
|
||||
|
||||
if (iWaveId == 0) {
|
||||
g_iNextWaveType = SQL_FetchInt(hResult, 0);
|
||||
}
|
||||
|
||||
// Save wave name
|
||||
Format(sKey, sizeof(sKey), "%d_name", iWaveId);
|
||||
SQL_FetchString(hResult, 1, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWaves, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save wave class
|
||||
Format(sKey, sizeof(sKey), "%d_class", iWaveId);
|
||||
SQL_FetchString(hResult, 2, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWaves, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save wave quantity
|
||||
Format(sKey, sizeof(sKey), "%d_quantity", iWaveId);
|
||||
SetTrieValue(g_hMapWaves, sKey, SQL_FetchInt(hResult, 3));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 3));
|
||||
|
||||
// Save wave health
|
||||
Format(sKey, sizeof(sKey), "%d_health", iWaveId);
|
||||
SetTrieValue(g_hMapWaves, sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// PrintToServer("%s => %d", sKey, SQL_FetchInt(hResult, 4));
|
||||
|
||||
// Save wave location
|
||||
Format(sKey, sizeof(sKey), "%d_location", iWaveId);
|
||||
SQL_FetchString(hResult, 5, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapWaves, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
iWaveId++;
|
||||
iMaxWaves++;
|
||||
}
|
||||
}
|
||||
|
||||
if (hResult != null) {
|
||||
CloseHandle(hResult);
|
||||
hResult = null;
|
||||
}
|
||||
|
||||
Database_LoadAirWaveSpawn();
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the spawn location of air waves (for anti-air towers).
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadAirWaveSpawn() {
|
||||
char sQuery[512];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery),
|
||||
"SELECT `teleport_air` " ...
|
||||
"FROM `map` " ...
|
||||
"WHERE (`map_id` = %d)",
|
||||
g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadAirWaveSpawn, sQuery);
|
||||
}
|
||||
|
||||
public void Database_OnLoadAirWaveSpawn(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadAirWaveSpawn > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
SQL_FetchRow(hResult);
|
||||
|
||||
SQL_FetchString(hResult, 0, g_sAirWaveSpawn, sizeof(g_sAirWaveSpawn));
|
||||
|
||||
char sLocationParts[6][16];
|
||||
ExplodeString(g_sAirWaveSpawn, " ", sLocationParts, sizeof(sLocationParts), sizeof(sLocationParts[]));
|
||||
|
||||
g_fAirWaveSpawn[0] = StringToFloat(sLocationParts[0]);
|
||||
g_fAirWaveSpawn[1] = StringToFloat(sLocationParts[1]);
|
||||
g_fAirWaveSpawn[2] = StringToFloat(sLocationParts[2]);
|
||||
}
|
||||
|
||||
if (hResult != null) {
|
||||
CloseHandle(hResult);
|
||||
hResult = null;
|
||||
}
|
||||
|
||||
Database_LoadMetalpacks();
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads metalpacks to its map.
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
stock void Database_LoadMetalpacks() {
|
||||
char sQuery[256];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery),
|
||||
"SELECT `type`, `metal`, `location` " ...
|
||||
"FROM `metalpack` " ...
|
||||
"INNER JOIN `metalpacktype` " ...
|
||||
"ON (`metalpack`.`metalpacktype_id` = `metalpacktype`.`metalpacktype_id`) " ...
|
||||
"WHERE `map_id` = %d " ...
|
||||
"ORDER BY `metalpack_id` ASC",
|
||||
g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadMetalpacks, sQuery);
|
||||
}
|
||||
|
||||
public void Database_OnLoadMetalpacks(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadMetalpacks > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
int iMetalpackId = 0;
|
||||
char sKey[64], sBuffer[128];
|
||||
|
||||
// Type Metal Location
|
||||
// start 400 1100 -1200 -90
|
||||
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
// Save metalpack type
|
||||
Format(sKey, sizeof(sKey), "%d_type", iMetalpackId);
|
||||
SQL_FetchString(hResult, 0, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapMetalpacks, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save metalpack metal
|
||||
Format(sKey, sizeof(sKey), "%d_metal", iMetalpackId);
|
||||
SetTrieValue(g_hMapMetalpacks, sKey, SQL_FetchInt(hResult, 1));
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
// Save metalpack location
|
||||
Format(sKey, sizeof(sKey), "%d_location", iMetalpackId);
|
||||
SQL_FetchString(hResult, 2, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMapMetalpacks, sKey, sBuffer);
|
||||
|
||||
// PrintToServer("%s => %s", sKey, sBuffer);
|
||||
|
||||
iMetalpackId++;
|
||||
}
|
||||
|
||||
// Save metalpack quantity
|
||||
SetTrieValue(g_hMapMetalpacks, "quantity", iMetalpackId);
|
||||
}
|
||||
|
||||
if (hResult != null) {
|
||||
CloseHandle(hResult);
|
||||
hResult = null;
|
||||
}
|
||||
|
||||
Database_LoadMultipliersTypes();
|
||||
|
||||
}
|
||||
|
||||
stock void Database_LoadMultipliersTypes() {
|
||||
char sQuery[512];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery), "SELECT type FROM multipliertype ORDER BY `multipliertype_id` ASC", g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadMultipliersTypes, sQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* Load Multiplier Types
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
public void Database_OnLoadMultipliersTypes(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadMaxWaves > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
// type
|
||||
// bullet
|
||||
int iMultiplierTypeId = 1;
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
char sKey[64], sBuffer[128];
|
||||
|
||||
// Save type
|
||||
Format(sKey, sizeof(sKey), "%d_type", iMultiplierTypeId);
|
||||
SQL_FetchString(hResult, 0, sBuffer, sizeof(sBuffer));
|
||||
SetTrieString(g_hMultiplierType, sKey, sBuffer);
|
||||
|
||||
iMultiplierTypeId++;
|
||||
}
|
||||
}
|
||||
|
||||
Database_LoadMultipliers();
|
||||
}
|
||||
|
||||
stock void Database_LoadMultipliers() {
|
||||
char sQuery[512];
|
||||
|
||||
g_hDatabase.Format(sQuery, sizeof(sQuery), "SELECT price,increase FROM `multiplier` WHERE map_id=%d ORDER BY `multipliertype_id` ASC", g_iServerMap);
|
||||
|
||||
g_hDatabase.Query(Database_OnLoadMultipliers, sQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* Load Multipliers
|
||||
*
|
||||
* @noreturn
|
||||
*/
|
||||
|
||||
public void Database_OnLoadMultipliers(Handle hDriver, Handle hResult, const char[] sError, any iData) {
|
||||
if (hResult == null) {
|
||||
Log(TDLogLevel_Error, "Query failed at Database_LoadMaxWaves > Error: %s", sError);
|
||||
} else if (SQL_GetRowCount(hResult)) {
|
||||
// multipliertype_id price increase
|
||||
// 1 1000 1000
|
||||
|
||||
iMaxMultiplierTypes = 0;
|
||||
int iMultiplierTypeId = 1;
|
||||
|
||||
while (SQL_FetchRow(hResult)) {
|
||||
char sKey[64];
|
||||
|
||||
// Save price
|
||||
Format(sKey, sizeof(sKey), "%d_price", iMultiplierTypeId);
|
||||
SetTrieValue(g_hMultiplier, sKey, SQL_FetchInt(hResult, 0));
|
||||
|
||||
// Save increase
|
||||
Format(sKey, sizeof(sKey), "%d_increase", iMultiplierTypeId);
|
||||
SetTrieValue(g_hMultiplier, sKey, SQL_FetchInt(hResult, 1));
|
||||
|
||||
iMultiplierTypeId++;
|
||||
iMaxMultiplierTypes++;
|
||||
}
|
||||
}
|
||||
|
||||
Database_OnDataLoaded();
|
||||
}
|
Reference in New Issue
Block a user