forked from mirror/openmw-tes3mp
Create placeholders for WorldPacket classes
This commit is contained in:
parent
790d41e278
commit
285f89573d
8 changed files with 201 additions and 4 deletions
|
@ -147,14 +147,17 @@ add_component_dir (version
|
|||
|
||||
add_component_dir (openmw-mp
|
||||
Log
|
||||
Controllers/PlayerPacketController
|
||||
Packets/BasePacket Packets/Player/PlayerPacket
|
||||
Controllers/PlayerPacketController Controllers/WorldPacketController
|
||||
Packets/BasePacket Packets/Player/PlayerPacket Packets/World/WorldPacket
|
||||
|
||||
Packets/Player/PacketBaseInfo Packets/Player/PacketPosition Packets/Player/PacketEquipment
|
||||
Packets/Player/PacketAttack Packets/Player/PacketDynamicStats Packets/Player/PacketCell
|
||||
Packets/Player/PacketDrawState Packets/Player/PacketChatMessage Packets/Player/PacketCharGen
|
||||
Packets/Player/PacketAttribute Packets/Player/PacketSkill Packets/Player/PacketLevel
|
||||
Packets/Player/PacketHandshake Packets/Player/PacketGUIBoxes Packets/Player/PacketClass
|
||||
Packets/Player/PacketTime)
|
||||
Packets/Player/PacketTime
|
||||
|
||||
Packets/World/PacketObjectRemoval)
|
||||
|
||||
add_component_dir (fallback
|
||||
fallback validate
|
||||
|
|
32
components/openmw-mp/Controllers/WorldPacketController.cpp
Normal file
32
components/openmw-mp/Controllers/WorldPacketController.cpp
Normal file
|
@ -0,0 +1,32 @@
|
|||
#include <boost/shared_ptr.hpp>
|
||||
#include <boost/foreach.hpp>
|
||||
#include <boost/make_shared.hpp>
|
||||
|
||||
#include "../Packets/World/PacketObjectRemoval.hpp"
|
||||
|
||||
#include "WorldPacketController.hpp"
|
||||
|
||||
template <typename T>
|
||||
inline void AddPacket(mwmp::WorldPacketController::packets_t *packets, RakNet::RakPeerInterface *peer)
|
||||
{
|
||||
T *packet = new T(peer);
|
||||
typedef mwmp::WorldPacketController::packets_t::value_type value_t;
|
||||
packets->insert(value_t(packet->GetPacketID(), value_t::second_type(packet)));
|
||||
}
|
||||
|
||||
mwmp::WorldPacketController::WorldPacketController(RakNet::RakPeerInterface *peer)
|
||||
{
|
||||
AddPacket<PacketObjectRemoval>(&packets, peer);
|
||||
}
|
||||
|
||||
|
||||
mwmp::WorldPacket *mwmp::WorldPacketController::GetPacket(RakNet::MessageID id)
|
||||
{
|
||||
return packets[(unsigned char)id].get();
|
||||
}
|
||||
|
||||
void mwmp::WorldPacketController::SetStream(RakNet::BitStream *inStream, RakNet::BitStream *outStream)
|
||||
{
|
||||
BOOST_FOREACH( packets_t::value_type &packet, packets )
|
||||
packet.second->SetStreams(inStream, outStream);
|
||||
}
|
25
components/openmw-mp/Controllers/WorldPacketController.hpp
Normal file
25
components/openmw-mp/Controllers/WorldPacketController.hpp
Normal file
|
@ -0,0 +1,25 @@
|
|||
#ifndef OPENMW_WORLDPACKETCONTROLLER_HPP
|
||||
#define OPENMW_WORLDPACKETCONTROLLER_HPP
|
||||
|
||||
|
||||
#include <RakPeerInterface.h>
|
||||
#include "../Packets/World/WorldPacket.hpp"
|
||||
#include <map>
|
||||
#include <boost/shared_ptr.hpp>
|
||||
|
||||
namespace mwmp
|
||||
{
|
||||
class WorldPacketController
|
||||
{
|
||||
public:
|
||||
WorldPacketController(RakNet::RakPeerInterface *peer);
|
||||
WorldPacket *GetPacket(RakNet::MessageID id);
|
||||
void SetStream(RakNet::BitStream *inStream, RakNet::BitStream *outStream);
|
||||
|
||||
typedef std::map<unsigned char, boost::shared_ptr<WorldPacket> > packets_t;
|
||||
private:
|
||||
packets_t packets;
|
||||
};
|
||||
}
|
||||
|
||||
#endif //OPENMW_WORLDPACKETCONTROLLER_HPP
|
|
@ -30,7 +30,9 @@ enum GameMessages
|
|||
ID_HANDSHAKE,
|
||||
ID_LOADED,
|
||||
ID_GUI_MESSAGEBOX,
|
||||
ID_GAME_TIME
|
||||
ID_GAME_TIME,
|
||||
|
||||
ID_WORLD_OBJECT_REMOVAL
|
||||
};
|
||||
|
||||
|
||||
|
|
14
components/openmw-mp/Packets/World/PacketObjectRemoval.cpp
Normal file
14
components/openmw-mp/Packets/World/PacketObjectRemoval.cpp
Normal file
|
@ -0,0 +1,14 @@
|
|||
#include <components/openmw-mp/NetworkMessages.hpp>
|
||||
#include "PacketObjectRemoval.hpp"
|
||||
|
||||
using namespace mwmp;
|
||||
|
||||
PacketObjectRemoval::PacketObjectRemoval(RakNet::RakPeerInterface *peer) : WorldPacket(peer)
|
||||
{
|
||||
packetID = ID_WORLD_OBJECT_REMOVAL;
|
||||
}
|
||||
|
||||
void PacketObjectRemoval::Packet(RakNet::BitStream *bs, BasePlayer *player, bool send)
|
||||
{
|
||||
WorldPacket::Packet(bs, player, send);
|
||||
}
|
17
components/openmw-mp/Packets/World/PacketObjectRemoval.hpp
Normal file
17
components/openmw-mp/Packets/World/PacketObjectRemoval.hpp
Normal file
|
@ -0,0 +1,17 @@
|
|||
#ifndef OPENMW_PACKETOBJECTREMOVAL_HPP
|
||||
#define OPENMW_PACKETOBJECTREMOVAL_HPP
|
||||
|
||||
#include <components/openmw-mp/Packets/World/WorldPacket.hpp>
|
||||
|
||||
namespace mwmp
|
||||
{
|
||||
class PacketObjectRemoval : public WorldPacket
|
||||
{
|
||||
public:
|
||||
PacketObjectRemoval(RakNet::RakPeerInterface *peer);
|
||||
|
||||
virtual void Packet(RakNet::BitStream *bs, BasePlayer *player, bool send);
|
||||
};
|
||||
}
|
||||
|
||||
#endif //OPENMW_PACKETOBJECTREMOVAL_HPP
|
58
components/openmw-mp/Packets/World/WorldPacket.cpp
Normal file
58
components/openmw-mp/Packets/World/WorldPacket.cpp
Normal file
|
@ -0,0 +1,58 @@
|
|||
#include <components/openmw-mp/NetworkMessages.hpp>
|
||||
#include <PacketPriority.h>
|
||||
#include <RakPeer.h>
|
||||
#include "WorldPacket.hpp"
|
||||
|
||||
using namespace mwmp;
|
||||
|
||||
void WorldPacket::Packet(RakNet::BitStream *bs, BasePlayer *player, bool send)
|
||||
{
|
||||
this->player = player;
|
||||
this->bs = bs;
|
||||
|
||||
if (send)
|
||||
{
|
||||
bs->Write(packetID);
|
||||
bs->Write(player->guid);
|
||||
}
|
||||
}
|
||||
|
||||
WorldPacket::WorldPacket(RakNet::RakPeerInterface *peer) : BasePacket(peer)
|
||||
{
|
||||
packetID = 0;
|
||||
priority = HIGH_PRIORITY;
|
||||
reliability = RELIABLE_ORDERED;
|
||||
this->peer = peer;
|
||||
}
|
||||
|
||||
WorldPacket::~WorldPacket()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void WorldPacket::Send(BasePlayer *player, RakNet::AddressOrGUID destination)
|
||||
{
|
||||
bsSend->ResetWritePointer();
|
||||
Packet(bsSend, player, true);
|
||||
peer->Send(bsSend, priority, reliability, 0, destination, false);
|
||||
}
|
||||
|
||||
void WorldPacket::Send(BasePlayer *player, bool toOther)
|
||||
{
|
||||
bsSend->ResetWritePointer();
|
||||
Packet(bsSend, player, true);
|
||||
peer->Send(bsSend, priority, reliability, 0, player->guid, toOther);
|
||||
}
|
||||
|
||||
void WorldPacket::Read(BasePlayer *player)
|
||||
{
|
||||
Packet(bsRead, player, false);
|
||||
}
|
||||
|
||||
void WorldPacket::RequestData(RakNet::RakNetGUID guid)
|
||||
{
|
||||
bsSend->ResetWritePointer();
|
||||
bsSend->Write(packetID);
|
||||
bsSend->Write(guid);
|
||||
peer->Send(bsSend, HIGH_PRIORITY, RELIABLE_ORDERED, 0, guid, false);
|
||||
}
|
46
components/openmw-mp/Packets/World/WorldPacket.hpp
Normal file
46
components/openmw-mp/Packets/World/WorldPacket.hpp
Normal file
|
@ -0,0 +1,46 @@
|
|||
#ifndef OPENMW_WORLDPACKET_HPP
|
||||
#define OPENMW_WORLDPACKET_HPP
|
||||
|
||||
#include <string>
|
||||
#include <RakNetTypes.h>
|
||||
#include <BitStream.h>
|
||||
#include <PacketPriority.h>
|
||||
#include <components/openmw-mp/Base/BasePlayer.hpp>
|
||||
|
||||
#include <components/openmw-mp/Packets/BasePacket.hpp>
|
||||
|
||||
|
||||
namespace mwmp
|
||||
{
|
||||
class WorldPacket : public BasePacket
|
||||
{
|
||||
public:
|
||||
WorldPacket(RakNet::RakPeerInterface *peer);
|
||||
|
||||
~WorldPacket();
|
||||
|
||||
virtual void Packet(RakNet::BitStream *bs, BasePlayer *player, bool send);
|
||||
|
||||
virtual void Send(BasePlayer *player, bool toOtherPlayers = true);
|
||||
virtual void Send(BasePlayer *player, RakNet::AddressOrGUID destination);
|
||||
virtual void Read(BasePlayer *player);
|
||||
|
||||
virtual void RequestData(RakNet::RakNetGUID player);
|
||||
|
||||
static size_t headerSize()
|
||||
{
|
||||
return (size_t)(1 + RakNet::RakNetGUID::size()); // packetID + RakNetGUID (uint64_t)
|
||||
}
|
||||
|
||||
unsigned char GetPacketID()
|
||||
{
|
||||
return packetID;
|
||||
}
|
||||
|
||||
protected:
|
||||
BasePlayer *player;
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
#endif //OPENMW_WORLDPACKET_HPP
|
Loading…
Reference in a new issue