2017-07-11 10:34:09 +00:00
|
|
|
#ifndef OPENMW_MECHANICSAPI_HPP
|
|
|
|
#define OPENMW_MECHANICSAPI_HPP
|
|
|
|
|
|
|
|
#include "../Types.hpp"
|
|
|
|
|
|
|
|
#define MECHANICSAPI \
|
2017-07-15 08:09:28 +00:00
|
|
|
{"IsWerewolf", MechanicsFunctions::IsWerewolf},\
|
|
|
|
\
|
|
|
|
{"SetWerewolfState", MechanicsFunctions::SetWerewolfState},\
|
2017-07-11 10:34:09 +00:00
|
|
|
\
|
2017-07-15 08:09:28 +00:00
|
|
|
{"SendShapeshift", MechanicsFunctions::SendShapeshift},\
|
|
|
|
\
|
|
|
|
{"Jail", MechanicsFunctions::Jail},\
|
2017-07-11 10:34:09 +00:00
|
|
|
{"Resurrect", MechanicsFunctions::Resurrect}
|
|
|
|
|
|
|
|
class MechanicsFunctions
|
|
|
|
{
|
|
|
|
public:
|
2017-07-15 08:09:28 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Check whether a player is a werewolf.
|
|
|
|
*
|
|
|
|
* This is based on the last PlayerShapeshift packet received or sent for that player.
|
|
|
|
*
|
2017-07-25 15:07:09 +00:00
|
|
|
* \param pid The player ID.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The werewolf state.
|
|
|
|
*/
|
2017-07-15 08:09:28 +00:00
|
|
|
static bool IsWerewolf(unsigned short pid) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the werewolf state of a player.
|
|
|
|
*
|
|
|
|
* This changes the werewolf state recorded for that player in the server memory, but
|
|
|
|
* does not by itself send a packet.
|
|
|
|
*
|
2017-07-25 15:07:09 +00:00
|
|
|
* \param pid The player ID.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \param bool The new werewolf state.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-15 08:09:28 +00:00
|
|
|
static void SetWerewolfState(unsigned short pid, bool isWerewolf);
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerShapeshift packet about a player.
|
|
|
|
*
|
|
|
|
* This sends the packet to all players connected to the server. It is currently used
|
|
|
|
* only to communicate werewolf states.
|
|
|
|
*
|
2017-07-25 15:07:09 +00:00
|
|
|
* \param pid The player ID.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-15 08:09:28 +00:00
|
|
|
static void SendShapeshift(unsigned short pid);
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerJail packet about a player.
|
|
|
|
*
|
|
|
|
* This is similar to the player being jailed by a guard, but provides extra parameters for
|
|
|
|
* increased flexibility.
|
|
|
|
*
|
|
|
|
* It is only sent to the player being jailed, as the other players will be informed of the
|
|
|
|
* jailing's actual consequences via other packets sent by the affected client.
|
|
|
|
*
|
2017-07-25 15:07:09 +00:00
|
|
|
* \param pid The player ID.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \param jailDays The number of days to spend jailed, where each day affects one skill point.
|
|
|
|
* \param ignoreJailTeleportation Whether the player being teleported to the nearest jail
|
|
|
|
* marker should be overridden.
|
|
|
|
* \param ignoreJailSkillIncrease Whether the player's Sneak and Security skills should be
|
|
|
|
* prevented from increasing as a result of the jailing,
|
|
|
|
* overriding default behavior.
|
|
|
|
* \param jailProgressText The text that should be displayed while jailed.
|
|
|
|
* \param jailEndText The text that should be displayed once the jailing period is over.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-13 17:13:28 +00:00
|
|
|
static void Jail(unsigned short pid, int jailDays, bool ignoreJailTeleportation = false, bool ignoreJailSkillIncreases = false,
|
|
|
|
const char* jailProgressText = "", const char* jailEndText = "") noexcept;
|
2017-07-11 10:34:09 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerResurrect packet about a player.
|
|
|
|
*
|
|
|
|
* This sends the packet to all players connected to the server.
|
|
|
|
*
|
2017-07-25 15:07:09 +00:00
|
|
|
* \param pid The player ID.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \param type The type of resurrection (0 for REGULAR, 1 for IMPERIAL_SHRINE,
|
|
|
|
* 2 for TRIBUNAL_TEMPLE).
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-11 10:34:09 +00:00
|
|
|
static void Resurrect(unsigned short pid, unsigned int type) noexcept;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif //OPENMW_MECHANICSAPI_HPP
|