forked from mirror/openmw-tes3mp
141eb8b7c2
Additionally, delete DedicatedPlayers who disconnect. Previously, all disconnected DedicatedPlayers were still kept in memory, but never used again. There was code that suggested they were meant to be reused upon reconnecting, but that reuse had never actually been implemented, and would probably not be that useful anyway.
107 lines
2.5 KiB
C++
107 lines
2.5 KiB
C++
#include <components/openmw-mp/Log.hpp>
|
|
#include <apps/openmw/mwclass/creature.hpp>
|
|
|
|
#include "../mwbase/environment.hpp"
|
|
|
|
#include "../mwclass/npc.hpp"
|
|
|
|
#include "../mwmechanics/creaturestats.hpp"
|
|
|
|
#include "../mwworld/cellstore.hpp"
|
|
#include "../mwworld/player.hpp"
|
|
#include "../mwworld/worldimp.hpp"
|
|
|
|
#include "PlayerList.hpp"
|
|
#include "Main.hpp"
|
|
#include "DedicatedPlayer.hpp"
|
|
#include "CellController.hpp"
|
|
#include "GUIController.hpp"
|
|
|
|
|
|
using namespace mwmp;
|
|
using namespace std;
|
|
|
|
std::map <RakNet::RakNetGUID, DedicatedPlayer *> PlayerList::players;
|
|
|
|
void PlayerList::update(float dt)
|
|
{
|
|
for (auto &p : players)
|
|
{
|
|
DedicatedPlayer *player = p.second;
|
|
if (player == 0) continue;
|
|
|
|
player->update(dt);
|
|
}
|
|
}
|
|
|
|
DedicatedPlayer *PlayerList::newPlayer(RakNet::RakNetGUID guid)
|
|
{
|
|
LOG_APPEND(Log::LOG_INFO, "- Creating new DedicatedPlayer with guid %s", guid.ToString());
|
|
|
|
players[guid] = new DedicatedPlayer(guid);
|
|
|
|
LOG_APPEND(Log::LOG_INFO, "- There are now %i DedicatedPlayers", players.size());
|
|
|
|
return players[guid];
|
|
}
|
|
|
|
void PlayerList::deletePlayer(RakNet::RakNetGUID guid)
|
|
{
|
|
if (players[guid]->reference)
|
|
players[guid]->deleteReference();
|
|
|
|
delete players[guid];
|
|
players.erase(guid);
|
|
}
|
|
|
|
void PlayerList::cleanUp()
|
|
{
|
|
for (auto &p : players)
|
|
delete p.second;
|
|
}
|
|
|
|
DedicatedPlayer *PlayerList::getPlayer(RakNet::RakNetGUID guid)
|
|
{
|
|
return players[guid];
|
|
}
|
|
|
|
DedicatedPlayer *PlayerList::getPlayer(const MWWorld::Ptr &ptr)
|
|
{
|
|
for (auto &p : players)
|
|
{
|
|
if (p.second == 0 || p.second->getPtr().mRef == 0)
|
|
continue;
|
|
string refid = ptr.getCellRef().getRefId();
|
|
if (p.second->getPtr().getCellRef().getRefId() == refid)
|
|
return p.second;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
bool PlayerList::isDedicatedPlayer(const MWWorld::Ptr &ptr)
|
|
{
|
|
if (ptr.mRef == nullptr)
|
|
return false;
|
|
|
|
return (getPlayer(ptr) != 0);
|
|
}
|
|
|
|
/*
|
|
Go through all DedicatedPlayers checking if their mHitAttemptActorId matches this one
|
|
and set it to -1 if it does
|
|
|
|
This resets the combat target for a DedicatedPlayer's followers in Actors::update()
|
|
*/
|
|
void PlayerList::clearHitAttemptActorId(int actorId)
|
|
{
|
|
for (auto &p : players)
|
|
{
|
|
if (p.second == 0 || p.second->getPtr().mRef == 0)
|
|
continue;
|
|
|
|
MWMechanics::CreatureStats &playerCreatureStats = p.second->getPtr().getClass().getCreatureStats(p.second->getPtr());
|
|
|
|
if (playerCreatureStats.getHitAttemptActorId() == actorId)
|
|
playerCreatureStats.setHitAttemptActorId(-1);
|
|
}
|
|
}
|