|
|
@ -733,188 +733,187 @@ void Networking::processWorldPacket(RakNet::Packet *packet)
|
|
|
|
pl = Players::getPlayer(guid);
|
|
|
|
pl = Players::getPlayer(guid);
|
|
|
|
|
|
|
|
|
|
|
|
WorldPacket *myPacket = worldController.GetPacket(packet->data[0]);
|
|
|
|
WorldPacket *myPacket = worldController.GetPacket(packet->data[0]);
|
|
|
|
WorldEvent *event = new WorldEvent(guid);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
myPacket->Packet(&bsIn, event, false);
|
|
|
|
myPacket->Packet(&bsIn, &worldEvent, false);
|
|
|
|
|
|
|
|
|
|
|
|
switch (packet->data[0])
|
|
|
|
switch (packet->data[0])
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case ID_CONTAINER:
|
|
|
|
case ID_CONTAINER:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Received ID_CONTAINER about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Received ID_CONTAINER about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
LOG_APPEND(Log::LOG_VERBOSE, "- action: %i", event->action);
|
|
|
|
LOG_APPEND(Log::LOG_VERBOSE, "- action: %i", worldEvent.action);
|
|
|
|
|
|
|
|
|
|
|
|
// If we've received a request for information, comply with it
|
|
|
|
// If we've received a request for information, comply with it
|
|
|
|
if (event->action == mwmp::BaseEvent::REQUEST)
|
|
|
|
if (worldEvent.action == mwmp::BaseEvent::REQUEST)
|
|
|
|
event->sendContainers(ptrCellStore);
|
|
|
|
worldEvent.sendContainers(ptrCellStore);
|
|
|
|
// Otherwise, edit containers based on the information received
|
|
|
|
// Otherwise, edit containers based on the information received
|
|
|
|
else
|
|
|
|
else
|
|
|
|
event->editContainers(ptrCellStore);
|
|
|
|
worldEvent.editContainers(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_PLACE:
|
|
|
|
case ID_OBJECT_PLACE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_PLACE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_PLACE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->placeObjects(ptrCellStore);
|
|
|
|
worldEvent.placeObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_DELETE:
|
|
|
|
case ID_OBJECT_DELETE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_DELETE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_DELETE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->deleteObjects(ptrCellStore);
|
|
|
|
worldEvent.deleteObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_LOCK:
|
|
|
|
case ID_OBJECT_LOCK:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_LOCK about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_LOCK about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->lockObjects(ptrCellStore);
|
|
|
|
worldEvent.lockObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_UNLOCK:
|
|
|
|
case ID_OBJECT_UNLOCK:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_UNLOCK about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_UNLOCK about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->unlockObjects(ptrCellStore);
|
|
|
|
worldEvent.unlockObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_SCALE:
|
|
|
|
case ID_OBJECT_SCALE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_SCALE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_SCALE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->scaleObjects(ptrCellStore);
|
|
|
|
worldEvent.scaleObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_MOVE:
|
|
|
|
case ID_OBJECT_MOVE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_MOVE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_MOVE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->moveObjects(ptrCellStore);
|
|
|
|
worldEvent.moveObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_ROTATE:
|
|
|
|
case ID_OBJECT_ROTATE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ROTATE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ROTATE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->rotateObjects(ptrCellStore);
|
|
|
|
worldEvent.rotateObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_OBJECT_ANIM_PLAY:
|
|
|
|
case ID_OBJECT_ANIM_PLAY:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ANIM_PLAY about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_OBJECT_ANIM_PLAY about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->animateObjects(ptrCellStore);
|
|
|
|
worldEvent.animateObjects(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_DOOR_STATE:
|
|
|
|
case ID_DOOR_STATE:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_DOOR_STATE about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_DOOR_STATE about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->activateDoors(ptrCellStore);
|
|
|
|
worldEvent.activateDoors(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_SCRIPT_LOCAL_SHORT:
|
|
|
|
case ID_SCRIPT_LOCAL_SHORT:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_SHORT about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_SHORT about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->setLocalShorts(ptrCellStore);
|
|
|
|
worldEvent.setLocalShorts(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_SCRIPT_LOCAL_FLOAT:
|
|
|
|
case ID_SCRIPT_LOCAL_FLOAT:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(event->cell);
|
|
|
|
MWWorld::CellStore *ptrCellStore = Main::get().getWorldController()->getCell(worldEvent.cell);
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
if (!ptrCellStore) return;
|
|
|
|
|
|
|
|
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_FLOAT about %s",
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_LOCAL_FLOAT about %s",
|
|
|
|
event->cell.getDescription().c_str());
|
|
|
|
worldEvent.cell.getDescription().c_str());
|
|
|
|
event->setLocalFloats(ptrCellStore);
|
|
|
|
worldEvent.setLocalFloats(ptrCellStore);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_SCRIPT_MEMBER_SHORT:
|
|
|
|
case ID_SCRIPT_MEMBER_SHORT:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_MEMBER_SHORT");
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_MEMBER_SHORT");
|
|
|
|
event->setMemberShorts();
|
|
|
|
worldEvent.setMemberShorts();
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_SCRIPT_GLOBAL_SHORT:
|
|
|
|
case ID_SCRIPT_GLOBAL_SHORT:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_GLOBAL_SHORT");
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_SCRIPT_GLOBAL_SHORT");
|
|
|
|
event->setGlobalShorts();
|
|
|
|
worldEvent.setGlobalShorts();
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_MUSIC_PLAY:
|
|
|
|
case ID_MUSIC_PLAY:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_MUSIC_PLAY");
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_MUSIC_PLAY");
|
|
|
|
event->playMusic();
|
|
|
|
worldEvent.playMusic();
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ID_VIDEO_PLAY:
|
|
|
|
case ID_VIDEO_PLAY:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_VIDEO_PLAY");
|
|
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_WARN, "Received ID_VIDEO_PLAY");
|
|
|
|
event->playVideo();
|
|
|
|
worldEvent.playVideo();
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -954,9 +953,12 @@ LocalPlayer *Networking::getLocalPlayer()
|
|
|
|
return mwmp::Main::get().getLocalPlayer();
|
|
|
|
return mwmp::Main::get().getLocalPlayer();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
WorldEvent *Networking::createWorldEvent()
|
|
|
|
WorldEvent *Networking::resetWorldEvent()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return new WorldEvent(getLocalPlayer()->guid);
|
|
|
|
worldEvent.cell.blank();
|
|
|
|
|
|
|
|
worldEvent.objectChanges.objects.clear();
|
|
|
|
|
|
|
|
worldEvent.guid = getLocalPlayer()->guid;
|
|
|
|
|
|
|
|
return &worldEvent;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool Networking::isDedicatedPlayer(const MWWorld::Ptr &ptr)
|
|
|
|
bool Networking::isDedicatedPlayer(const MWWorld::Ptr &ptr)
|
|
|
|