#ifndef OPENMW_WORLDAPI_HPP #define OPENMW_WORLDAPI_HPP #define WORLDAPI \ {"ReadLastEvent", WorldFunctions::ReadLastEvent},\ {"InitializeEvent", WorldFunctions::InitializeEvent},\ \ {"GetObjectChangesSize", WorldFunctions::GetObjectChangesSize},\ {"GetEventAction", WorldFunctions::GetEventAction},\ {"GetEventContainerSubAction", WorldFunctions::GetEventContainerSubAction},\ \ {"GetObjectRefId", WorldFunctions::GetObjectRefId},\ {"GetObjectRefNumIndex", WorldFunctions::GetObjectRefNumIndex},\ {"GetObjectMpNum", WorldFunctions::GetObjectMpNum},\ {"GetObjectCount", WorldFunctions::GetObjectCount},\ {"GetObjectCharge", WorldFunctions::GetObjectCharge},\ {"GetObjectEnchantmentCharge", WorldFunctions::GetObjectEnchantmentCharge},\ {"GetObjectGoldValue", WorldFunctions::GetObjectGoldValue},\ {"GetObjectScale", WorldFunctions::GetObjectScale},\ {"GetObjectState", WorldFunctions::GetObjectState},\ {"GetObjectDoorState", WorldFunctions::GetObjectDoorState},\ {"GetObjectLockLevel", WorldFunctions::GetObjectLockLevel},\ {"GetObjectPosX", WorldFunctions::GetObjectPosX},\ {"GetObjectPosY", WorldFunctions::GetObjectPosY},\ {"GetObjectPosZ", WorldFunctions::GetObjectPosZ},\ {"GetObjectRotX", WorldFunctions::GetObjectRotX},\ {"GetObjectRotY", WorldFunctions::GetObjectRotY},\ {"GetObjectRotZ", WorldFunctions::GetObjectRotZ},\ \ {"GetContainerChangesSize", WorldFunctions::GetContainerChangesSize},\ {"GetContainerItemRefId", WorldFunctions::GetContainerItemRefId},\ {"GetContainerItemCount", WorldFunctions::GetContainerItemCount},\ {"GetContainerItemCharge", WorldFunctions::GetContainerItemCharge},\ {"GetContainerItemEnchantmentCharge", WorldFunctions::GetContainerItemEnchantmentCharge},\ {"GetContainerItemActionCount", WorldFunctions::GetContainerItemActionCount},\ \ {"SetEventCell", WorldFunctions::SetEventCell},\ {"SetEventAction", WorldFunctions::SetEventAction},\ {"SetEventConsoleCommand", WorldFunctions::SetEventConsoleCommand},\ \ {"SetObjectRefId", WorldFunctions::SetObjectRefId},\ {"SetObjectRefNumIndex", WorldFunctions::SetObjectRefNumIndex},\ {"SetObjectMpNum", WorldFunctions::SetObjectMpNum},\ {"SetObjectCount", WorldFunctions::SetObjectCount},\ {"SetObjectCharge", WorldFunctions::SetObjectCharge},\ {"SetObjectEnchantmentCharge", WorldFunctions::SetObjectEnchantmentCharge},\ {"SetObjectGoldValue", WorldFunctions::SetObjectGoldValue},\ {"SetObjectScale", WorldFunctions::SetObjectScale},\ {"SetObjectState", WorldFunctions::SetObjectState},\ {"SetObjectLockLevel", WorldFunctions::SetObjectLockLevel},\ {"SetObjectDisarmState", WorldFunctions::SetObjectDisarmState},\ {"SetObjectMasterState", WorldFunctions::SetObjectMasterState},\ {"SetObjectPosition", WorldFunctions::SetObjectPosition},\ {"SetObjectRotation", WorldFunctions::SetObjectRotation},\ \ {"SetObjectDoorState", WorldFunctions::SetObjectDoorState},\ {"SetObjectDoorTeleportState", WorldFunctions::SetObjectDoorTeleportState},\ {"SetObjectDoorDestinationCell", WorldFunctions::SetObjectDoorDestinationCell},\ {"SetObjectDoorDestinationPosition", WorldFunctions::SetObjectDoorDestinationPosition},\ {"SetObjectDoorDestinationRotation", WorldFunctions::SetObjectDoorDestinationRotation},\ \ {"SetPlayerAsObject", WorldFunctions::SetPlayerAsObject},\ \ {"SetContainerItemRefId", WorldFunctions::SetContainerItemRefId},\ {"SetContainerItemCount", WorldFunctions::SetContainerItemCount},\ {"SetContainerItemCharge", WorldFunctions::SetContainerItemCharge},\ {"SetContainerItemEnchantmentCharge", WorldFunctions::SetContainerItemEnchantmentCharge},\ \ {"SetReceivedContainerItemActionCount", WorldFunctions::SetReceivedContainerItemActionCount},\ \ {"AddWorldObject", WorldFunctions::AddWorldObject},\ {"AddContainerItem", WorldFunctions::AddContainerItem},\ \ {"SendObjectPlace", WorldFunctions::SendObjectPlace},\ {"SendObjectSpawn", WorldFunctions::SendObjectSpawn},\ {"SendObjectDelete", WorldFunctions::SendObjectDelete},\ {"SendObjectLock", WorldFunctions::SendObjectLock},\ {"SendObjectTrap", WorldFunctions::SendObjectTrap},\ {"SendObjectScale", WorldFunctions::SendObjectScale},\ {"SendObjectState", WorldFunctions::SendObjectState},\ {"SendDoorState", WorldFunctions::SendDoorState},\ {"SendDoorDestination", WorldFunctions::SendDoorDestination},\ {"SendContainer", WorldFunctions::SendContainer},\ {"SendConsoleCommand", WorldFunctions::SendConsoleCommand},\ \ {"SetHour", WorldFunctions::SetHour},\ {"SetMonth", WorldFunctions::SetMonth},\ {"SetDay", WorldFunctions::SetDay} class WorldFunctions { public: /** * \brief Use the last event received by the server as the one being read. * * \return void */ static void ReadLastEvent() noexcept; /** * \brief Clear the data from the last event sent by the server. * * This is used to initialize the sending of new Object packets. * * \param pid The player ID to whom the event should be attached. * \return void */ static void InitializeEvent(unsigned short pid) noexcept; /** * \brief Get the number of indexes in the read event's object changes. * * \return The number of indexes. */ static unsigned int GetObjectChangesSize() noexcept; /** * \brief Get the action type used in the read event. * * \return The action type (0 for SET, 1 for ADD, 2 for REMOVE, 3 for REQUEST). */ static unsigned char GetEventAction() noexcept; /** * \brief Get the container subaction type used in the read event. * * \return The action type (0 for NONE, 1 for DRAG, 2 for DROP, 3 for TAKE_ALL). */ static unsigned char GetEventContainerSubAction() noexcept; /** * \brief Get the refId of the object at a certain index in the read event's object changes. * * \return The refId. */ static const char *GetObjectRefId(unsigned int i) noexcept; /** * \brief Get the refNumIndex of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The refNumIndex. */ static int GetObjectRefNumIndex(unsigned int i) noexcept; /** * \brief Get the mpNum of the object at a certain index in the read event's object changes. * * \param i The index of the object. * \return The mpNum. */ static int GetObjectMpNum(unsigned int i) noexcept; /** * \brief Get the count of the object at a certain index in the read event's object changes. * * \param i The index of the object. * \return The object count. */ static int GetObjectCount(unsigned int i) noexcept; /** * \brief Get the charge of the object at a certain index in the read event's object changes. * * \param i The index of the object. * \return The charge. */ static int GetObjectCharge(unsigned int i) noexcept; /** * \brief Get the enchantment charge of the object at a certain index in the read event's object changes. * * \param i The index of the object. * \return The enchantment charge. */ static double GetObjectEnchantmentCharge(unsigned int i) noexcept; /** * \brief Get the gold value of the object at a certain index in the read event's object * changes. * * This is used solely to get the gold value of gold. It is not used for other objects. * * \param i The index of the object. * \return The gold value. */ static int GetObjectGoldValue(unsigned int i) noexcept; /** * \brief Get the object scale of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The object scale. */ static double GetObjectScale(unsigned int i) noexcept; /** * \brief Get the object state of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The object state. */ static bool GetObjectState(unsigned int i) noexcept; /** * \brief Get the door state of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The door state. */ static int GetObjectDoorState(unsigned int i) noexcept; /** * \brief Get the lock level of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The lock level. */ static int GetObjectLockLevel(unsigned int i) noexcept; /** * \brief Get the X position of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The X position. */ static double GetObjectPosX(unsigned int i) noexcept; /** * \brief Get the Y position of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The Y position. */ static double GetObjectPosY(unsigned int i) noexcept; /** * \brief Get the Z position at a certain index in the read event's object changes. * * \param i The index of the object. * \return The Z position. */ static double GetObjectPosZ(unsigned int i) noexcept; /** * \brief Get the X rotation of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The X rotation. */ static double GetObjectRotX(unsigned int i) noexcept; /** * \brief Get the Y rotation of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The Y rotation. */ static double GetObjectRotY(unsigned int i) noexcept; /** * \brief Get the Z rotation of the object at a certain index in the read event's object * changes. * * \param i The index of the object. * \return The Z rotation. */ static double GetObjectRotZ(unsigned int i) noexcept; /** * \brief Get the number of container item indexes of the object at a certain index in the * read event's object changes. * * \param i The index of the object. * \return The number of container item indexes. */ static unsigned int GetContainerChangesSize(unsigned int objectIndex) noexcept; /** * \brief Get the refId of the container item at a certain itemIndex in the container changes * of the object at a certain objectIndex in the read event's object changes. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \return The refId. */ static const char *GetContainerItemRefId(unsigned int objectIndex, unsigned int itemIndex) noexcept; /** * \brief Get the item count of the container item at a certain itemIndex in the container * changes of the object at a certain objectIndex in the read event's object changes. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \return The item count. */ static int GetContainerItemCount(unsigned int objectIndex, unsigned int itemIndex) noexcept; /** * \brief Get the charge of the container item at a certain itemIndex in the container changes * of the object at a certain objectIndex in the read event's object changes. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \return The charge. */ static int GetContainerItemCharge(unsigned int objectIndex, unsigned int itemIndex) noexcept; /** * \brief Get the enchantment charge of the container item at a certain itemIndex in the container changes * of the object at a certain objectIndex in the read event's object changes. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \return The enchantment charge. */ static double GetContainerItemEnchantmentCharge(unsigned int objectIndex, unsigned int itemIndex) noexcept; /** * \brief Get the action count of the container item at a certain itemIndex in the container * changes of the object at a certain objectIndex in the read event's object changes. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \return The action count. */ static int GetContainerItemActionCount(unsigned int objectIndex, unsigned int itemIndex) noexcept; /** * \brief Set the cell of the temporary event stored on the server. * * The cell is determined to be an exterior cell if it fits the pattern of a number followed * by a comma followed by another number. * * \param cellDescription The description of the cell. * \return void */ static void SetEventCell(const char* cellDescription) noexcept; /** * \brief Set the action type of the temporary event stored on the server. * * \param action The action type (0 for SET, 1 for ADD, 2 for REMOVE, 3 for REQUEST). * \return void */ static void SetEventAction(unsigned char action) noexcept; /** * \brief Set the console command of the temporary event stored on the server. * * When sent, the command will run once on every object added to the event. If no objects * have been added, it will run once without any object reference. * * \param consoleCommand The console command. * \return void */ static void SetEventConsoleCommand(const char* consoleCommand) noexcept; /** * \brief Set the refId of the temporary world object stored on the server. * * \param refId The refId. * \return void */ static void SetObjectRefId(const char* refId) noexcept; /** * \brief Set the refNumIndex of the temporary world object stored on the server. * * Every object loaded from .ESM and .ESP data files has a unique refNumIndex which needs to be * retained to refer to it in packets. * * On the other hand, objects placed or spawned via the server should always have a refNumIndex * of 0. * * \param refNumIndex The refNumIndex. * \return void */ static void SetObjectRefNumIndex(int refNumIndex) noexcept; /** * \brief Set the mpNum of the temporary world object stored on the server. * * Every object placed or spawned via the server is assigned an mpNum by incrementing the last * mpNum stored on the server. Scripts should take care to ensure that mpNums are kept unique * for these objects. * * Objects loaded from .ESM and .ESP data files should always have an mpNum of 0, because they * have unique refNumIndexes instead. * * \param mpNum The mpNum. * \return void */ static void SetObjectMpNum(int mpNum) noexcept; /** * \brief Set the object count of the temporary world object stored on the server. * * This determines the quantity of an object, with the exception of gold. * * \param count The object count. * \return void */ static void SetObjectCount(int count) noexcept; /** * \brief Set the charge of the temporary world object stored on the server. * * Object durabilities are set through this value. * * \param charge The charge. * \return void */ static void SetObjectCharge(int charge) noexcept; /** * \brief Set the enchantment charge of the temporary world object stored on the server. * * Object durabilities are set through this value. * * \param charge The enchantment charge. * \return void */ static void SetObjectEnchantmentCharge(double enchantmentCharge) noexcept; /** * \brief Set the gold value of the temporary world object stored on the server. * * This is used solely to set the gold value for gold. It has no effect on other objects. * * \param goldValue The gold value. * \return void */ static void SetObjectGoldValue(int goldValue) noexcept; /** * \brief Set the scale of the temporary world object stored on the server. * * Objects are smaller or larger than their default size based on their scale. * * \param scale The scale. * \return void */ static void SetObjectScale(double scale) noexcept; /** * \brief Set the object state of the temporary world object stored on the server. * * Objects are enabled or disabled based on their object state. * * \param objectState The object state. * \return void */ static void SetObjectState(bool objectState) noexcept; /** * \brief Set the lock level of the temporary world object stored on the server. * * \param lockLevel The lock level. * \return void */ static void SetObjectLockLevel(int lockLevel) noexcept; /** * \brief Set the disarm state of the temporary world object stored on the server. * * \param disarmState The disarmState. * \return void */ static void SetObjectDisarmState(bool disarmState) noexcept; /** * \brief Set the master state of the temporary world object stored on the server. * * This only affects living actors and determines whether they are followers of another * living actor. * * \param masterState The master state. * \return void */ static void SetObjectMasterState(bool masterState) noexcept; /** * \brief Set the position of the temporary world object stored on the server. * * \param x The X position. * \param y The Y position. * \param z The Z position. * \return void */ static void SetObjectPosition(double x, double y, double z) noexcept; /** * \brief Set the rotation of the temporary world object stored on the server. * * \param x The X rotation. * \param y The Y rotation. * \param z The Z rotation. * \return void */ static void SetObjectRotation(double x, double y, double z) noexcept; /** * \brief Set the door state of the temporary world object stored on the server. * * Doors are open or closed based on their door state. * * \param doorState The door state. * \return void */ static void SetObjectDoorState(int doorState) noexcept; /** * \brief Set the teleport state of the temporary world object stored on the server. * * If a door's teleport state is true, interacting with the door teleports a player to its * destination. If it's false, it opens and closes like a regular door. * * \param teleportState The teleport state. * \return void */ static void SetObjectDoorTeleportState(bool teleportState) noexcept; /** * \brief Set the door destination cell of the temporary world object stored on the server. * * The cell is determined to be an exterior cell if it fits the pattern of a number followed * by a comma followed by another number. * * \param cellDescription The description of the cell. * \return void */ static void SetObjectDoorDestinationCell(const char* cellDescription) noexcept; /** * \brief Set the door destination position of the temporary world object stored on the server. * * \param x The X position. * \param y The Y position. * \param z The Z position. * \return void */ static void SetObjectDoorDestinationPosition(double x, double y, double z) noexcept; /** * \brief Set the door destination rotation of the temporary world object stored on the server. * * Note: Because this sets the rotation a player will have upon using the door, and rotation * on the Y axis has no effect on players, the Y value has been omitted as an argument. * * \param x The X rotation. * \param z The Z rotation. * \return void */ static void SetObjectDoorDestinationRotation(double x, double z) noexcept; /** * \brief Set a player as the object in the temporary world object stored on the server. * Currently only used for ConsoleCommand packets. * * \param pid The pid of the player. * \return void */ static void SetPlayerAsObject(unsigned short pid) noexcept; /** * \brief Set the refId of the temporary container item stored on the server. * * \param refId The refId. * \return void */ static void SetContainerItemRefId(const char* refId) noexcept; /** * \brief Set the item count of the temporary container item stored on the server. * * \param count The item count. * \return void */ static void SetContainerItemCount(int count) noexcept; /** * \brief Set the charge of the temporary container item stored on the server. * * \param charge The charge. * \return void */ static void SetContainerItemCharge(int charge) noexcept; /** * \brief Set the enchantment charge of the temporary container item stored on the server. * * \param charge The enchantment charge. * \return void */ static void SetContainerItemEnchantmentCharge(double enchantmentCharge) noexcept; /** * \brief Set the action count of the container item at a certain itemIndex in the container * changes of the object at a certain objectIndex in the read event's object changes. * * When resending a received Container packet, this allows you to correct the amount of items * removed from a container by a player when it conflicts with what other players have already * taken. * * \param objectIndex The index of the object. * \param itemIndex The index of the container item. * \param actionCount The action count. * \return void */ static void SetReceivedContainerItemActionCount(unsigned int objectIndex, unsigned int itemIndex, int actionCount) noexcept; /** * \brief Add a copy of the server's temporary world object to the server's temporary event. * * In the process, the server's temporary world object will automatically be cleared so a new * one can be set up. * * \return void */ static void AddWorldObject() noexcept; /** * \brief Add a copy of the server's temporary container item to the container changes of the * server's temporary world object. * * In the process, the server's temporary container item will automatically be cleared so a new * one can be set up. * * \return void */ static void AddContainerItem() noexcept; /** * \brief Send an ObjectPlace packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectPlace(bool broadcast = false) noexcept; /** * \brief Send an ObjectSpawn packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectSpawn(bool broadcast = false) noexcept; /** * \brief Send an ObjectDelete packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectDelete(bool broadcast = false) noexcept; /** * \brief Send an ObjectLock packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectLock(bool broadcast = false) noexcept; /** * \brief Send an ObjectTrap packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectTrap(bool broadcast = false) noexcept; /** * \brief Send an ObjectScale packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectScale(bool broadcast = false) noexcept; /** * \brief Send an ObjectState packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendObjectState(bool broadcast = false) noexcept; /** * \brief Send a DoorState packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendDoorState(bool broadcast = false) noexcept; /** * \brief Send a DoorDestination packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendDoorDestination(bool broadcast = false) noexcept; /** * \brief Send a Container packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendContainer(bool broadcast = false, bool useLastReadEvent = false) noexcept; /** * \brief Send a ConsoleCommand packet. * * \param broadcast Whether this packet should be sent only to the player for whom the current * event was initialized or to everyone on the server. * * \return void */ static void SendConsoleCommand(bool broadcast = false) noexcept; /** * \brief Set the game hour for a player and send a GameTime packet to that player. * * \param pid The player ID. * \param hour The hour. * \return void */ static void SetHour(unsigned short pid, double hour) noexcept; /** * \brief Set the game month for a player and send a GameTime packet to that player. * * \param pid The player ID. * \param month The month. * \return void */ static void SetMonth(unsigned short pid, int month) noexcept; /** * \brief Set the game day for a player and send a GameTime packet to that player. * * \param pid The player ID. * \param day The day. * \return void */ static void SetDay(unsigned short pid, int day) noexcept; }; #endif //OPENMW_WORLDAPI_HPP