aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Cache/CharacterCache.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2024-01-27 00:13:34 +0100
committerfunjoker <funjoker109@gmail.com>2024-01-29 22:19:44 +0100
commit2db09c3fe7202df53b9056c157c6b759793a68e0 (patch)
tree39afcc129c5efc5d586351ef44c57903cb976ae6 /src/server/game/Cache/CharacterCache.cpp
parent3a9c997e3926ff29f3ac7f18724ed1f73818fb17 (diff)
Core/Players: Fixed CharacterCache by-name storage holding data for deleted characters
(cherry picked from commit d03e0d69353852636e12911a7f7149cb0bca40ef)
Diffstat (limited to 'src/server/game/Cache/CharacterCache.cpp')
-rw-r--r--src/server/game/Cache/CharacterCache.cpp14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/server/game/Cache/CharacterCache.cpp b/src/server/game/Cache/CharacterCache.cpp
index 20b0e1ffd9d..f424e5bd113 100644
--- a/src/server/game/Cache/CharacterCache.cpp
+++ b/src/server/game/Cache/CharacterCache.cpp
@@ -107,7 +107,8 @@ void CharacterCache::AddCharacterCacheEntry(ObjectGuid const& guid, uint32 accou
data.IsDeleted = isDeleted;
// Fill Name to Guid Store
- _characterCacheByNameStore[name] = &data;
+ if (!isDeleted)
+ _characterCacheByNameStore[name] = &data;
}
void CharacterCache::DeleteCharacterCacheEntry(ObjectGuid const& guid, std::string const& name)
@@ -186,16 +187,19 @@ void CharacterCache::UpdateCharacterArenaTeamId(ObjectGuid const& guid, uint8 sl
itr->second.ArenaTeamId[slot] = arenaTeamId;
}
-void CharacterCache::UpdateCharacterInfoDeleted(ObjectGuid const& guid, bool deleted, std::string const* name /*=nullptr*/)
+void CharacterCache::UpdateCharacterInfoDeleted(ObjectGuid const& guid, bool deleted, std::string const& name /*=nullptr*/)
{
auto itr = _characterCacheStore.find(guid);
if (itr == _characterCacheStore.end())
return;
- itr->second.IsDeleted = deleted;
+ if (deleted)
+ _characterCacheByNameStore.erase(itr->second.Name);
+ else
+ _characterCacheByNameStore[name] = &itr->second;
- if (name)
- itr->second.Name = *name;
+ itr->second.Name = name;
+ itr->second.IsDeleted = deleted;
}
/*