diff options
author | Machiavelli <none@none> | 2010-03-20 21:49:01 +0100 |
---|---|---|
committer | Machiavelli <none@none> | 2010-03-20 21:49:01 +0100 |
commit | a0fd280a34b6e7c2c6bf3570d0420675222950ba (patch) | |
tree | ba86cbdf1ad149e0e2d0b3e38148a9c810802f98 /src/game/Player.cpp | |
parent | f7ffd77123b5f6c943f7d280fbea5742e2c5d9b9 (diff) |
Memory optimization by making m_refundableItems a std::set<uint64>. Also fix a crash caused by invalid iterator in Player::_SaveInventory(). This should fix the last of the item save related crashes.
--HG--
branch : trunk
Diffstat (limited to 'src/game/Player.cpp')
-rw-r--r-- | src/game/Player.cpp | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/src/game/Player.cpp b/src/game/Player.cpp index 7fcc5559a1b..8def5f05d35 100644 --- a/src/game/Player.cpp +++ b/src/game/Player.cpp @@ -16412,7 +16412,7 @@ void Player::_LoadInventory(QueryResult_AutoPtr result, uint32 timediff) item->SetRefundRecipient(fields[0].GetUInt32()); item->SetPaidMoney(fields[1].GetUInt32()); item->SetPaidExtendedCost(fields[2].GetUInt32()); - AddRefundReference(item); + AddRefundReference(item->GetGUID()); } } } @@ -17499,9 +17499,14 @@ void Player::_SaveInventory() // the client auto counts down in real time after having received the initial played time on the first // SMSG_ITEM_REFUND_INFO_RESPONSE packet. // Item::UpdatePlayedTime is only called when needed, which is in DB saves, and item refund info requests. - for (std::set<Item*>::iterator itr = m_refundableItems.begin(); itr!= m_refundableItems.end(); ++itr) + std::set<uint64>::iterator i_next; + for (std::set<uint64>::iterator itr = m_refundableItems.begin(); itr!= m_refundableItems.end(); itr = i_next) { - Item* iPtr = *itr; + // use copy iterator because UpdatePlayedTime may invalidate itr + i_next = itr; + ++i_next; + + Item* iPtr = GetItemByGuid(*itr); ASSERT(iPtr); // Sanity check, if this assertion is hit then the item wasn't removed from the set correctly./ iPtr->UpdatePlayedTime(this); } @@ -19362,7 +19367,7 @@ bool Player::BuyItemFromVendor(uint64 vendorguid, uint32 item, uint8 count, uint it->SetPaidMoney(price); it->SetPaidExtendedCost(crItem->ExtendedCost); it->SaveRefundDataToDB(); - AddRefundReference(it); + AddRefundReference(it->GetGUID()); } } } @@ -19420,7 +19425,7 @@ bool Player::BuyItemFromVendor(uint64 vendorguid, uint32 item, uint8 count, uint it->SetPaidMoney(price); it->SetPaidExtendedCost(crItem->ExtendedCost); it->SaveRefundDataToDB(); - AddRefundReference(it); + AddRefundReference(it->GetGUID()); } } } @@ -23347,12 +23352,12 @@ void Player::SendDuelCountdown(uint32 counter) GetSession()->SendPacket(&data); } -void Player::AddRefundReference(Item* it) +void Player::AddRefundReference(uint64 it) { m_refundableItems.insert(it); } -void Player::DeleteRefundReference(Item* it) +void Player::DeleteRefundReference(uint64 it) { m_refundableItems.erase(it); }
\ No newline at end of file |