mirror of
https://github.com/EQEmu/Server.git
synced 2026-04-05 11:12:42 +00:00
GetPoweredPetEntry converted to QueryDatabase
This commit is contained in:
parent
8b89beb02e
commit
977b28cb9c
@ -450,46 +450,35 @@ bool ZoneDatabase::GetPetEntry(const char *pet_type, PetRecord *into) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ZoneDatabase::GetPoweredPetEntry(const char *pet_type, int16 petpower, PetRecord *into) {
|
bool ZoneDatabase::GetPoweredPetEntry(const char *pet_type, int16 petpower, PetRecord *into) {
|
||||||
char errbuf[MYSQL_ERRMSG_SIZE];
|
std::string query;
|
||||||
char *query = 0;
|
|
||||||
uint32 querylen = 0;
|
|
||||||
MYSQL_RES *result;
|
|
||||||
MYSQL_ROW row;
|
|
||||||
|
|
||||||
if (petpower <= 0) {
|
if (petpower <= 0)
|
||||||
querylen = MakeAnyLenString(&query,
|
query = StringFormat("SELECT npcID, temp, petpower, petcontrol, petnaming, monsterflag, equipmentset "
|
||||||
"SELECT npcID, temp, petpower, petcontrol, petnaming, monsterflag, equipmentset FROM pets "
|
"FROM pets WHERE type='%s' AND petpower<=0", pet_type);
|
||||||
"WHERE type='%s' AND petpower<=0", pet_type);
|
else
|
||||||
}
|
query = StringFormat("SELECT npcID, temp, petpower, petcontrol, petnaming, monsterflag, equipmentset "
|
||||||
else {
|
"FROM pets WHERE type='%s' AND petpower<=%d ORDER BY petpower DESC LIMIT 1",
|
||||||
querylen = MakeAnyLenString(&query,
|
pet_type, petpower);
|
||||||
"SELECT npcID, temp, petpower, petcontrol, petnaming, monsterflag, equipmentset FROM pets "
|
auto results = QueryDatabase(query);
|
||||||
"WHERE type='%s' AND petpower<=%d ORDER BY petpower DESC LIMIT 1", pet_type, petpower);
|
if (!results.Success()) {
|
||||||
}
|
LogFile->write(EQEMuLog::Error, "Error in GetPoweredPetEntry query '%s': %s", query.c_str(), results.ErrorMessage().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (RunQuery(query, querylen, errbuf, &result)) {
|
if (results.RowCount() != 1)
|
||||||
safe_delete_array(query);
|
return false;
|
||||||
if (mysql_num_rows(result) == 1) {
|
|
||||||
row = mysql_fetch_row(result);
|
|
||||||
|
|
||||||
into->npc_type = atoi(row[0]);
|
auto row = results.begin();
|
||||||
into->temporary = atoi(row[1]);
|
|
||||||
into->petpower = atoi(row[2]);
|
|
||||||
into->petcontrol = atoi(row[3]);
|
|
||||||
into->petnaming = atoi(row[4]);
|
|
||||||
into->monsterflag = atoi(row[5]);
|
|
||||||
into->equipmentset = atoi(row[6]);
|
|
||||||
|
|
||||||
mysql_free_result(result);
|
into->npc_type = atoi(row[0]);
|
||||||
return(true);
|
into->temporary = atoi(row[1]);
|
||||||
}
|
into->petpower = atoi(row[2]);
|
||||||
mysql_free_result(result);
|
into->petcontrol = atoi(row[3]);
|
||||||
}
|
into->petnaming = atoi(row[4]);
|
||||||
else {
|
into->monsterflag = atoi(row[5]);
|
||||||
LogFile->write(EQEMuLog::Error, "Error in GetPoweredPetEntry query '%s': %s", query, errbuf);
|
into->equipmentset = atoi(row[6]);
|
||||||
safe_delete_array(query);
|
|
||||||
}
|
return true;
|
||||||
return(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Mob* Mob::GetPet() {
|
Mob* Mob::GetPet() {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user