2017-04-09 09:28:38 +00:00
|
|
|
#ifndef OPENMW_SPELLAPI_HPP
|
|
|
|
#define OPENMW_SPELLAPI_HPP
|
2016-11-21 18:37:04 +00:00
|
|
|
|
|
|
|
#define SPELLAPI \
|
2017-07-07 06:25:48 +00:00
|
|
|
{"InitializeSpellbookChanges", SpellFunctions::InitializeSpellbookChanges},\
|
2016-11-21 18:37:04 +00:00
|
|
|
\
|
2017-07-07 06:25:48 +00:00
|
|
|
{"GetSpellbookChangesSize", SpellFunctions::GetSpellbookChangesSize},\
|
|
|
|
{"GetSpellbookAction", SpellFunctions::GetSpellbookAction},\
|
2016-11-21 18:37:04 +00:00
|
|
|
\
|
2017-07-07 06:25:48 +00:00
|
|
|
{"AddSpell", SpellFunctions::AddSpell},\
|
|
|
|
{"RemoveSpell", SpellFunctions::RemoveSpell},\
|
2016-11-21 18:37:04 +00:00
|
|
|
\
|
2017-07-07 06:25:48 +00:00
|
|
|
{"GetSpellId", SpellFunctions::GetSpellId},\
|
|
|
|
\
|
|
|
|
{"SendSpellbookChanges", SpellFunctions::SendSpellbookChanges}
|
2016-11-21 18:37:04 +00:00
|
|
|
|
|
|
|
class SpellFunctions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Clear the last recorded spellbook changes for a player.
|
|
|
|
*
|
|
|
|
* This is used to initialize the sending of new PlayerSpellbook packets.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-07 06:25:48 +00:00
|
|
|
static void InitializeSpellbookChanges(unsigned short pid) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the number of indexes in a player's latest spellbook changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \return The number of indexes.
|
|
|
|
*/
|
2017-01-20 10:43:05 +00:00
|
|
|
static unsigned int GetSpellbookChangesSize(unsigned short pid) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the action type used in a player's latest spellbook changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose faction changes should be used.
|
|
|
|
* \return The action type (0 for SET, 1 for ADD, 2 for REMOVE).
|
|
|
|
*/
|
2017-02-16 12:23:27 +00:00
|
|
|
static unsigned int GetSpellbookAction(unsigned short pid) noexcept;
|
2016-11-21 18:37:04 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Prepare the addition of a spell to a player.
|
|
|
|
*
|
|
|
|
* In practice, this changes the action type of the PlayerSpellbook packet to
|
|
|
|
* ADD and adds this spell to it.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param topicId The spellId of the spell.
|
|
|
|
* \return void
|
|
|
|
*/
|
2016-11-21 18:37:04 +00:00
|
|
|
static void AddSpell(unsigned short pid, const char* spellId) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Prepare the removal of a spell from a player.
|
|
|
|
*
|
|
|
|
* In practice, this changes the action type of the PlayerSpellbook packet to
|
|
|
|
* REMOVE and adds this spell to it.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param topicId The spellId of the spell.
|
|
|
|
* \return void
|
|
|
|
*/
|
2016-11-21 18:37:04 +00:00
|
|
|
static void RemoveSpell(unsigned short pid, const char* spellId) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the spellId at a certain index in a player's latest spellbook changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param i The index of the spell.
|
|
|
|
* \return The spellId.
|
|
|
|
*/
|
2016-11-21 18:37:04 +00:00
|
|
|
static const char *GetSpellId(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerSpellbook packet with a player's recorded spellbook changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param toOthers Whether this packet should be sent only to other players or
|
|
|
|
* only to the player it is about.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-07 06:25:48 +00:00
|
|
|
static void SendSpellbookChanges(unsigned short pid, bool toOthers = false) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
2016-11-21 18:37:04 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-04-09 09:28:38 +00:00
|
|
|
#endif //OPENMW_SPELLAPI_HPP
|