forked from mirror/openmw-tes3mp
54 lines
1.5 KiB
C++
54 lines
1.5 KiB
C++
//
|
|
// Created by koncord on 04.04.17.
|
|
//
|
|
|
|
#include "../Networking.hpp"
|
|
#include "PlayerProcessor.hpp"
|
|
#include "../Main.hpp"
|
|
|
|
using namespace mwmp;
|
|
|
|
template<class T>
|
|
typename BasePacketProcessor<T>::processors_t BasePacketProcessor<T>::processors;
|
|
|
|
bool PlayerProcessor::Process(RakNet::Packet &packet)
|
|
{
|
|
RakNet::BitStream bsIn(&packet.data[1], packet.length, false);
|
|
bsIn.Read(guid);
|
|
|
|
PlayerPacket *myPacket = Main::get().getNetworking()->getPlayerPacket(packet.data[0]);
|
|
myPacket->SetReadStream(&bsIn);
|
|
|
|
/*if (myPacket == 0)
|
|
{
|
|
// error: packet not found
|
|
}*/
|
|
|
|
for (auto &processor : processors)
|
|
{
|
|
if (processor.first == packet.data[0])
|
|
{
|
|
myGuid = Main::get().getLocalPlayer()->guid;
|
|
request = packet.length == myPacket->headerSize();
|
|
|
|
BasePlayer *player = 0;
|
|
if (guid != myGuid)
|
|
player = PlayerList::getPlayer(guid);
|
|
else
|
|
player = Main::get().getLocalPlayer();
|
|
|
|
if (player != 0)
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_TRACE, "Processing %s about %s", processor.second->strPacketID.c_str(), player->npc.mName.c_str());
|
|
|
|
if (!request && !processor.second->avoidReading && player != 0)
|
|
{
|
|
myPacket->setPlayer(player);
|
|
myPacket->Read();
|
|
}
|
|
|
|
processor.second->Do(*myPacket, player);
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|