feat: change death logic

This commit is contained in:
Иванов Иван
2024-08-21 15:00:17 +02:00
parent ad7a4c3074
commit 4e2e108076
8 changed files with 64 additions and 12 deletions

View File

@@ -83,6 +83,7 @@ namespace Interlude
{
Services::ServiceLocator::GetInstance().GetLogger()->App(L"{} died", m_Hero->GetFullName().GetNickname());
m_Hero->ClearAttackers();
m_Hero->MarkAsDead();
}
else
{

View File

@@ -111,6 +111,9 @@ namespace Interlude
m_Spoiled[casted.GetCreatureId()] = Enums::SpoilStateEnum::none;
}
}
if (m_Npcs.find(casted.GetCreatureId()) != m_Npcs.end()) {
m_Npcs[casted.GetCreatureId()]->MarkAsDead();
}
}
}

View File

@@ -46,6 +46,13 @@ namespace Interlude
m_Players.clear();
}
void Init() override
{
Services::ServiceLocator::GetInstance().GetEventDispatcher()->Subscribe(Events::CreatureDiedEvent::name, [this](const Events::Event& evt) {
OnCreatureDied(evt);
});
}
PlayerRepository(const NetworkHandlerWrapper& networkHandler, const PlayerFactory& factory, const uint16_t radius) :
m_NetworkHandler(networkHandler),
m_Factory(factory),
@@ -57,6 +64,18 @@ namespace Interlude
PlayerRepository() = delete;
virtual ~PlayerRepository() = default;
void OnCreatureDied(const Events::Event& evt)
{
std::shared_lock<std::shared_timed_mutex>(m_Mutex);
if (evt.GetName() == Events::CreatureDiedEvent::name)
{
const auto casted = static_cast<const Events::CreatureDiedEvent&>(evt);
if (m_Players.find(casted.GetCreatureId()) != m_Players.end()) {
m_Players[casted.GetCreatureId()]->MarkAsDead();
}
}
}
private:
const PlayerFactory& m_Factory;
const NetworkHandlerWrapper& m_NetworkHandler;