mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-20 07:53:51 +00:00
[Client] Enable world processors
This commit is contained in:
parent
7dcaef5a5a
commit
578d305d86
1 changed files with 10 additions and 186 deletions
|
@ -37,6 +37,13 @@
|
||||||
#include "MechanicsHelper.hpp"
|
#include "MechanicsHelper.hpp"
|
||||||
#include "LocalPlayer.hpp"
|
#include "LocalPlayer.hpp"
|
||||||
#include "DedicatedPlayer.hpp"
|
#include "DedicatedPlayer.hpp"
|
||||||
|
#include "LocalPlayer.hpp"
|
||||||
|
#include "GUIController.hpp"
|
||||||
|
#include "WorldController.hpp"
|
||||||
|
#include "Main.hpp"
|
||||||
|
#include "PlayerProcessor.hpp"
|
||||||
|
#include "ProcessorInitializer.hpp"
|
||||||
|
#include "WorldProcessor.hpp"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace mwmp;
|
using namespace mwmp;
|
||||||
|
@ -153,6 +160,7 @@ void Networking::connect(const std::string &ip, unsigned short port, std::vector
|
||||||
{
|
{
|
||||||
serverAddr = packet->systemAddress;
|
serverAddr = packet->systemAddress;
|
||||||
PlayerProcessor::SetServerAddr(packet->systemAddress);
|
PlayerProcessor::SetServerAddr(packet->systemAddress);
|
||||||
|
WorldProcessor::SetServerAddr(packet->systemAddress);
|
||||||
connected = true;
|
connected = true;
|
||||||
queue = false;
|
queue = false;
|
||||||
|
|
||||||
|
@ -342,192 +350,8 @@ void Networking::processActorPacket(RakNet::Packet *packet)
|
||||||
|
|
||||||
void Networking::processWorldPacket(RakNet::Packet *packet)
|
void Networking::processWorldPacket(RakNet::Packet *packet)
|
||||||
{
|
{
|
||||||
RakNet::RakNetGUID guid;
|
if (!WorldProcessor::Process(*packet, worldEvent))
|
||||||
RakNet::BitStream bsIn(&packet->data[1], packet->length, false);
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Unhandled WorldPacket with identifier %i has arrived", packet->data[0]);
|
||||||
bsIn.Read(guid);
|
|
||||||
|
|
||||||
DedicatedPlayer *pl = 0;
|
|
||||||
static RakNet::RakNetGUID myGuid = getLocalPlayer()->guid;
|
|
||||||
if (guid != myGuid)
|
|
||||||
pl = PlayerList::getPlayer(guid);
|
|
||||||
|
|
||||||
WorldPacket *myPacket = worldPacketController.GetPacket(packet->data[0]);
|
|
||||||
|
|
||||||
myPacket->setEvent(&worldEvent);
|
|
||||||
myPacket->Packet(&bsIn, false);
|
|
||||||
|
|
||||||
switch (packet->data[0])
|
|
||||||
{
|
|
||||||
case ID_CONTAINER:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Received ID_CONTAINER about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
LOG_APPEND(Log::LOG_VERBOSE, "- action: %i", worldEvent.action);
|
|
||||||
|
|
||||||
// If we've received a request for information, comply with it
|
|
||||||
if (worldEvent.action == mwmp::BaseEvent::REQUEST)
|
|
||||||
worldEvent.sendContainers(ptrCellStore);
|
|
||||||
// Otherwise, edit containers based on the information received
|
|
||||||
else
|
|
||||||
worldEvent.editContainers(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_PLACE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_PLACE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.placeObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_DELETE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_DELETE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.deleteObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_LOCK:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_LOCK about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.lockObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_UNLOCK:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_UNLOCK about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.unlockObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_SCALE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_SCALE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.scaleObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_MOVE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_MOVE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.moveObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_ROTATE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ROTATE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.rotateObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_OBJECT_ANIM_PLAY:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ANIM_PLAY about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.animateObjects(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_DOOR_STATE:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_DOOR_STATE about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.activateDoors(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_SCRIPT_LOCAL_SHORT:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_SHORT about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.setLocalShorts(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_SCRIPT_LOCAL_FLOAT:
|
|
||||||
{
|
|
||||||
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCellStore(worldEvent.cell);
|
|
||||||
|
|
||||||
if (!ptrCellStore) return;
|
|
||||||
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_FLOAT about %s", worldEvent.cell.getDescription().c_str());
|
|
||||||
worldEvent.setLocalFloats(ptrCellStore);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_SCRIPT_MEMBER_SHORT:
|
|
||||||
{
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_MEMBER_SHORT");
|
|
||||||
worldEvent.setMemberShorts();
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_SCRIPT_GLOBAL_SHORT:
|
|
||||||
{
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_GLOBAL_SHORT");
|
|
||||||
worldEvent.setGlobalShorts();
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_MUSIC_PLAY:
|
|
||||||
{
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_MUSIC_PLAY");
|
|
||||||
worldEvent.playMusic();
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ID_VIDEO_PLAY:
|
|
||||||
{
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_VIDEO_PLAY");
|
|
||||||
worldEvent.playVideo();
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "Unhandled WorldPacket with identifier %i has arrived", packet->data[0]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Networking::receiveMessage(RakNet::Packet *packet)
|
void Networking::receiveMessage(RakNet::Packet *packet)
|
||||||
|
|
Loading…
Reference in a new issue