mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 23:53:52 +00:00
41 lines
1.4 KiB
C++
41 lines
1.4 KiB
C++
#ifndef OPENMW_PROCESSORCONTAINER_HPP
|
|
#define OPENMW_PROCESSORCONTAINER_HPP
|
|
|
|
#include "../WorldProcessor.hpp"
|
|
|
|
namespace mwmp
|
|
{
|
|
class ProcessorContainer : public WorldProcessor
|
|
{
|
|
public:
|
|
ProcessorContainer()
|
|
{
|
|
BPP_INIT(ID_CONTAINER)
|
|
}
|
|
|
|
void Do(WorldPacket &packet, Player &player, BaseEvent &event) override
|
|
{
|
|
LOG_MESSAGE_SIMPLE(Log::LOG_INFO, "Received %s from %s", strPacketID.c_str(), player.npc.mName.c_str());
|
|
LOG_APPEND(Log::LOG_INFO, "- action: %i", event.action);
|
|
|
|
// Until we have a timestamp-based system, send packets pertaining to more
|
|
// than one container (i.e. replies to server requests for container contents)
|
|
// only to players who have the container's cell loaded
|
|
if (event.action == BaseEvent::SET && event.worldObjectCount > 1)
|
|
{
|
|
Cell *serverCell = CellController::get()->getCell(&event.cell);
|
|
|
|
if (serverCell != nullptr)
|
|
serverCell->sendToLoaded(&packet, &event);
|
|
}
|
|
else
|
|
packet.Send(true);
|
|
|
|
Script::Call<Script::CallbackIdentity("OnContainer")>(player.getId(), event.cell.getDescription().c_str());
|
|
|
|
LOG_APPEND(Log::LOG_INFO, "- Finished processing ID_CONTAINER");
|
|
}
|
|
};
|
|
}
|
|
|
|
#endif //OPENMW_PROCESSORCONTAINER_HPP
|