Fix abused unordered map

This commit is contained in:
Gent 2020-10-24 18:24:39 -04:00
parent 2302c28ac5
commit 4ab686bc46

View File

@ -651,9 +651,11 @@ void MobManager::step(CNServer *serv, time_t currTime) {
} }
// unbuffing // unbuffing
for (auto& pair2 : pair.second->unbuffTimes) { std::unordered_map<int32_t, time_t>::iterator it = pair.second->unbuffTimes.begin();
if (currTime >= pair2.second) { while (it != pair.second->unbuffTimes.end()) {
pair.second->appearanceData.iConditionBitFlag &= ~pair2.first;
if (currTime >= it->second) {
pair.second->appearanceData.iConditionBitFlag &= ~it->first;
INITSTRUCT(sP_FE2CL_CHAR_TIME_BUFF_TIME_OUT, pkt1); INITSTRUCT(sP_FE2CL_CHAR_TIME_BUFF_TIME_OUT, pkt1);
pkt1.eCT = 2; pkt1.eCT = 2;
@ -661,7 +663,9 @@ void MobManager::step(CNServer *serv, time_t currTime) {
pkt1.iConditionBitFlag = pair.second->appearanceData.iConditionBitFlag; pkt1.iConditionBitFlag = pair.second->appearanceData.iConditionBitFlag;
NPCManager::sendToViewable(pair.second, &pkt1, P_FE2CL_CHAR_TIME_BUFF_TIME_OUT, sizeof(sP_FE2CL_CHAR_TIME_BUFF_TIME_OUT)); NPCManager::sendToViewable(pair.second, &pkt1, P_FE2CL_CHAR_TIME_BUFF_TIME_OUT, sizeof(sP_FE2CL_CHAR_TIME_BUFF_TIME_OUT));
pair.second->unbuffTimes.erase(pair2.first); it = pair.second->unbuffTimes.erase(it);
} else {
it++;
} }
} }