1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-20 06:53:52 +00:00

[Client] Simplify Processors

This commit is contained in:
Koncord 2017-04-18 15:05:32 +08:00
parent cc2250815d
commit 67aba35d37
10 changed files with 73 additions and 88 deletions

View file

@ -98,7 +98,7 @@ add_openmw_dir (mwbase
add_openmw_dir (mwmp Main Networking LocalPlayer DedicatedPlayer LocalActor DedicatedActor ActorList WorldEvent Cell add_openmw_dir (mwmp Main Networking LocalPlayer DedicatedPlayer LocalActor DedicatedActor ActorList WorldEvent Cell
CellController MechanicsHelper GUIChat GUILogin GUIController PlayerMarkerCollection GUIDialogList WorldController CellController MechanicsHelper GUIChat GUILogin GUIController PlayerMarkerCollection GUIDialogList WorldController
PlayerProcessor WorldProcessor ActorProcessor ProcessorInitializer) BaseClientPacketProcessor PlayerProcessor WorldProcessor ActorProcessor ProcessorInitializer)
# Main executable # Main executable

View file

@ -10,9 +10,6 @@
using namespace mwmp; using namespace mwmp;
ActorProcessor::processors_t ActorProcessor::processors; ActorProcessor::processors_t ActorProcessor::processors;
RakNet::RakNetGUID ActorProcessor::guid;
RakNet::SystemAddress ActorProcessor::serverAddr;
bool ActorProcessor::request;
bool ActorProcessor::Process(RakNet::Packet &packet, ActorList &actorList) bool ActorProcessor::Process(RakNet::Packet &packet, ActorList &actorList)
{ {
@ -28,6 +25,7 @@ bool ActorProcessor::Process(RakNet::Packet &packet, ActorList &actorList)
{ {
if(processor.first == packet.data[0]) if(processor.first == packet.data[0])
{ {
myGuid = Main::get().getLocalPlayer()->guid;
request = packet.length == myPacket->headerSize(); request = packet.length == myPacket->headerSize();
if(!request && !processor.second->avoidReading) if(!request && !processor.second->avoidReading)
@ -53,8 +51,3 @@ void ActorProcessor::AddProcessor(mwmp::ActorProcessor *processor)
} }
processors.insert(processors_t::value_type(processor->GetPacketID(), boost::shared_ptr<ActorProcessor>(processor))); processors.insert(processors_t::value_type(processor->GetPacketID(), boost::shared_ptr<ActorProcessor>(processor)));
} }
LocalPlayer *ActorProcessor::getLocalPlayer()
{
return Main::get().getLocalPlayer();
}

View file

@ -10,41 +10,25 @@
#include <components/openmw-mp/Log.hpp> #include <components/openmw-mp/Log.hpp>
#include <components/openmw-mp/NetworkMessages.hpp> #include <components/openmw-mp/NetworkMessages.hpp>
#include <components/openmw-mp/Base/BasePacketProcessor.hpp>
#include <components/openmw-mp/Packets/Actor/ActorPacket.hpp> #include <components/openmw-mp/Packets/Actor/ActorPacket.hpp>
#include "WorldEvent.hpp" #include "WorldEvent.hpp"
#include "LocalPlayer.hpp"
#include "DedicatedPlayer.hpp"
#include "ActorList.hpp" #include "ActorList.hpp"
#include "BaseClientPacketProcessor.hpp"
namespace mwmp namespace mwmp
{ {
class ActorProcessor : public BasePacketProcessor class ActorProcessor : public BaseClientPacketProcessor
{ {
public: public:
virtual void Do(ActorPacket &packet, ActorList &actorList) = 0; virtual void Do(ActorPacket &packet, ActorList &actorList) = 0;
static bool Process(RakNet::Packet &packet, ActorList &actorList); static bool Process(RakNet::Packet &packet, ActorList &actorList);
static void AddProcessor(ActorProcessor *processor); static void AddProcessor(ActorProcessor *processor);
static void SetServerAddr(RakNet::SystemAddress addr)
{
serverAddr = addr;
}
typedef boost::unordered_map<unsigned char, boost::shared_ptr<ActorProcessor> > processors_t; typedef boost::unordered_map<unsigned char, boost::shared_ptr<ActorProcessor> > processors_t;
protected:
inline bool isRequest()
{
return request;
}
LocalPlayer *getLocalPlayer();
protected:
static RakNet::RakNetGUID guid;
static RakNet::SystemAddress serverAddr;
private: private:
static processors_t processors; static processors_t processors;
static bool request;
}; };
} }

View file

@ -0,0 +1,18 @@
//
// Created by koncord on 18.04.17.
//
#include "BaseClientPacketProcessor.hpp"
#include "Main.hpp"
using namespace mwmp;
RakNet::RakNetGUID BaseClientPacketProcessor::guid;
RakNet::RakNetGUID BaseClientPacketProcessor::myGuid;
RakNet::SystemAddress BaseClientPacketProcessor::serverAddr;
bool BaseClientPacketProcessor::request;
LocalPlayer *BaseClientPacketProcessor::getLocalPlayer()
{
return Main::get().getLocalPlayer();
}

View file

@ -0,0 +1,43 @@
//
// Created by koncord on 18.04.17.
//
#ifndef OPENMW_BASECLIENTPACKETPROCESSOR_HPP
#define OPENMW_BASECLIENTPACKETPROCESSOR_HPP
#include <components/openmw-mp/Base/BasePacketProcessor.hpp>
#include "LocalPlayer.hpp"
#include "DedicatedPlayer.hpp"
namespace mwmp
{
class BaseClientPacketProcessor : public BasePacketProcessor
{
public:
static void SetServerAddr(RakNet::SystemAddress addr)
{
serverAddr = addr;
}
protected:
inline bool isRequest()
{
return request;
}
inline bool isLocal()
{
return guid == myGuid;
}
LocalPlayer *getLocalPlayer();
protected:
static RakNet::RakNetGUID guid, myGuid;
static RakNet::SystemAddress serverAddr;
static bool request;
};
}
#endif //OPENMW_BASECLIENTPACKETPROCESSOR_HPP

View file

@ -153,9 +153,7 @@ void Networking::connect(const std::string &ip, unsigned short port, std::vector
case ID_CONNECTION_REQUEST_ACCEPTED: case ID_CONNECTION_REQUEST_ACCEPTED:
{ {
serverAddr = packet->systemAddress; serverAddr = packet->systemAddress;
PlayerProcessor::SetServerAddr(packet->systemAddress); BaseClientPacketProcessor::SetServerAddr(packet->systemAddress);
WorldProcessor::SetServerAddr(packet->systemAddress);
ActorProcessor::SetServerAddr(packet->systemAddress);
connected = true; connected = true;
queue = false; queue = false;

View file

@ -12,10 +12,6 @@
using namespace mwmp; using namespace mwmp;
PlayerProcessor::processors_t PlayerProcessor::processors; PlayerProcessor::processors_t PlayerProcessor::processors;
RakNet::RakNetGUID PlayerProcessor::myGuid;
RakNet::RakNetGUID PlayerProcessor::guid;
RakNet::SystemAddress PlayerProcessor::serverAddr;
bool PlayerProcessor::request;
void PlayerProcessor::AddProcessor(PlayerProcessor *processor) void PlayerProcessor::AddProcessor(PlayerProcessor *processor)
{ {
@ -66,8 +62,3 @@ bool PlayerProcessor::Process(RakNet::Packet &packet)
} }
return false; return false;
} }
LocalPlayer *PlayerProcessor::getLocalPlayer()
{
return Main::get().getLocalPlayer();
}

View file

@ -10,46 +10,25 @@
#include <components/openmw-mp/Log.hpp> #include <components/openmw-mp/Log.hpp>
#include <components/openmw-mp/NetworkMessages.hpp> #include <components/openmw-mp/NetworkMessages.hpp>
#include <components/openmw-mp/Base/BasePacketProcessor.hpp>
#include <components/openmw-mp/Packets/Player/PlayerPacket.hpp> #include <components/openmw-mp/Packets/Player/PlayerPacket.hpp>
#include "LocalPlayer.hpp" #include "LocalPlayer.hpp"
#include "DedicatedPlayer.hpp" #include "DedicatedPlayer.hpp"
#include "BaseClientPacketProcessor.hpp"
namespace mwmp namespace mwmp
{ {
class PlayerProcessor : public BasePacketProcessor class PlayerProcessor : public BaseClientPacketProcessor
{ {
public: public:
virtual void Do(PlayerPacket &packet, BasePlayer *player) = 0; virtual void Do(PlayerPacket &packet, BasePlayer *player) = 0;
static bool Process(RakNet::Packet &packet); static bool Process(RakNet::Packet &packet);
static void AddProcessor(PlayerProcessor *processor); static void AddProcessor(PlayerProcessor *processor);
static void SetServerAddr(RakNet::SystemAddress addr)
{
serverAddr = addr;
}
typedef boost::unordered_map<unsigned char, boost::shared_ptr<PlayerProcessor> > processors_t; typedef boost::unordered_map<unsigned char, boost::shared_ptr<PlayerProcessor> > processors_t;
//typedef std::unordered_map<unsigned char, std::unique_ptr<PlayerProcessor> > processors_t; //typedef std::unordered_map<unsigned char, std::unique_ptr<PlayerProcessor> > processors_t;
private: private:
static processors_t processors; static processors_t processors;
static bool request;
protected:
inline bool isRequest()
{
return request;
}
inline bool isLocal()
{
return guid == myGuid;
}
LocalPlayer *getLocalPlayer();
protected:
static RakNet::RakNetGUID myGuid;
static RakNet::RakNetGUID guid;
static RakNet::SystemAddress serverAddr;
}; };
} }

View file

@ -10,9 +10,6 @@
using namespace mwmp; using namespace mwmp;
WorldProcessor::processors_t WorldProcessor::processors; WorldProcessor::processors_t WorldProcessor::processors;
RakNet::RakNetGUID WorldProcessor::guid;
RakNet::SystemAddress WorldProcessor::serverAddr;
bool WorldProcessor::request;
bool WorldProcessor::Process(RakNet::Packet &packet, WorldEvent &event) bool WorldProcessor::Process(RakNet::Packet &packet, WorldEvent &event)
{ {
@ -28,6 +25,7 @@ bool WorldProcessor::Process(RakNet::Packet &packet, WorldEvent &event)
{ {
if(processor.first == packet.data[0]) if(processor.first == packet.data[0])
{ {
myGuid = Main::get().getLocalPlayer()->guid;
request = packet.length == myPacket->headerSize(); request = packet.length == myPacket->headerSize();
if(!request && !processor.second->avoidReading) if(!request && !processor.second->avoidReading)
@ -53,8 +51,3 @@ void WorldProcessor::AddProcessor(mwmp::WorldProcessor *processor)
} }
processors.insert(processors_t::value_type(processor->GetPacketID(), boost::shared_ptr<WorldProcessor>(processor))); processors.insert(processors_t::value_type(processor->GetPacketID(), boost::shared_ptr<WorldProcessor>(processor)));
} }
LocalPlayer *WorldProcessor::getLocalPlayer()
{
return Main::get().getLocalPlayer();
}

View file

@ -10,40 +10,26 @@
#include <components/openmw-mp/Log.hpp> #include <components/openmw-mp/Log.hpp>
#include <components/openmw-mp/NetworkMessages.hpp> #include <components/openmw-mp/NetworkMessages.hpp>
#include <components/openmw-mp/Base/BasePacketProcessor.hpp>
#include <components/openmw-mp/Packets/World/WorldPacket.hpp> #include <components/openmw-mp/Packets/World/WorldPacket.hpp>
#include "WorldEvent.hpp" #include "WorldEvent.hpp"
#include "LocalPlayer.hpp" #include "LocalPlayer.hpp"
#include "DedicatedPlayer.hpp" #include "DedicatedPlayer.hpp"
#include "BaseClientPacketProcessor.hpp"
namespace mwmp namespace mwmp
{ {
class WorldProcessor : public BasePacketProcessor class WorldProcessor : public BaseClientPacketProcessor
{ {
public: public:
virtual void Do(WorldPacket &packet, WorldEvent &event) = 0; virtual void Do(WorldPacket &packet, WorldEvent &event) = 0;
static bool Process(RakNet::Packet &packet, WorldEvent &event); static bool Process(RakNet::Packet &packet, WorldEvent &event);
static void AddProcessor(WorldProcessor *processor); static void AddProcessor(WorldProcessor *processor);
static void SetServerAddr(RakNet::SystemAddress addr)
{
serverAddr = addr;
}
typedef boost::unordered_map<unsigned char, boost::shared_ptr<WorldProcessor> > processors_t; typedef boost::unordered_map<unsigned char, boost::shared_ptr<WorldProcessor> > processors_t;
protected:
inline bool isRequest()
{
return request;
}
LocalPlayer *getLocalPlayer();
protected:
static RakNet::RakNetGUID guid;
static RakNet::SystemAddress serverAddr;
private: private:
static processors_t processors; static processors_t processors;
static bool request;
}; };
} }