GetPoweredPetEntry converted to QueryDatabase

This commit is contained in:
Arthur Ice 2014-08-18 22:02:35 -07:00
parent 8b89beb02e
commit 977b28cb9c

View File

@ -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() {