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},\
|
2017-07-20 14:58:00 +00:00
|
|
|
{"GetSpellbookChangesAction", SpellFunctions::GetSpellbookChangesAction},\
|
2016-11-21 18:37:04 +00:00
|
|
|
\
|
2017-07-20 14:58:00 +00:00
|
|
|
{"SetSpellbookChangesAction", SpellFunctions::SetSpellbookChangesAction},\
|
2017-07-07 06:25:48 +00:00
|
|
|
{"AddSpell", SpellFunctions::AddSpell},\
|
2017-07-30 17:45:47 +00:00
|
|
|
{"AddCustomSpell", SpellFunctions::AddCustomSpell},\
|
|
|
|
{"AddCustomSpellData", SpellFunctions::AddCustomSpellData},\
|
|
|
|
{"AddCustomSpellEffect", SpellFunctions::AddCustomSpellEffect},\
|
2016-11-21 18:37:04 +00:00
|
|
|
\
|
2017-07-07 06:25:48 +00:00
|
|
|
{"GetSpellId", SpellFunctions::GetSpellId},\
|
2017-07-30 17:45:47 +00:00
|
|
|
{"GetSpellName", SpellFunctions::GetSpellName},\
|
|
|
|
{"GetSpellType", SpellFunctions::GetSpellType},\
|
|
|
|
{"GetSpellCost", SpellFunctions::GetSpellCost},\
|
|
|
|
{"GetSpellFlags", SpellFunctions::GetSpellFlags},\
|
|
|
|
{"GetSpellEffectCount", SpellFunctions::GetSpellEffectCount},\
|
|
|
|
{"GetSpellEffectId", SpellFunctions::GetSpellEffectId},\
|
|
|
|
{"GetSpellEffectSkill", SpellFunctions::GetSpellEffectSkill},\
|
|
|
|
{"GetSpellEffectAttribute", SpellFunctions::GetSpellEffectAttribute},\
|
|
|
|
{"GetSpellEffectRange", SpellFunctions::GetSpellEffectRange},\
|
|
|
|
{"GetSpellEffectArea", SpellFunctions::GetSpellEffectArea},\
|
|
|
|
{"GetSpellEffectDuration", SpellFunctions::GetSpellEffectDuration},\
|
|
|
|
{"GetSpellEffectMagnMin", SpellFunctions::GetSpellEffectMagnMin},\
|
|
|
|
{"GetSpellEffectMagnMax", SpellFunctions::GetSpellEffectMagnMax},\
|
2017-07-07 06:25:48 +00:00
|
|
|
\
|
|
|
|
{"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-07-20 14:58:00 +00:00
|
|
|
static unsigned int GetSpellbookChangesAction(unsigned short pid) noexcept;
|
2016-11-21 18:37:04 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
2017-07-20 14:58:00 +00:00
|
|
|
* \brief Set the action type in a player's spellbook changes.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
2017-07-20 14:58:00 +00:00
|
|
|
* \param action The action (0 for SET, 1 for ADD, 2 for REMOVE).
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-20 14:58:00 +00:00
|
|
|
static void SetSpellbookChangesAction(unsigned short pid, unsigned char action) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
2017-07-20 14:58:00 +00:00
|
|
|
* \brief Add a new spell to the spellbook changes for a player.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
2017-07-30 17:45:47 +00:00
|
|
|
* \param spellId The spellId of the spell.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-20 14:58:00 +00:00
|
|
|
static void AddSpell(unsigned short pid, const char* spellId) noexcept;
|
2016-11-21 18:37:04 +00:00
|
|
|
|
2017-07-30 17:45:47 +00:00
|
|
|
/**
|
|
|
|
* \brief Add a new custom spell to the spellbook changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param spellId The spellId of the spell.
|
|
|
|
* \param spellName The name of the spell.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddCustomSpell(unsigned short pid, const char* spellId, const char* spellName) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add custom spell data to the spellbook changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param spellId The spellId of the spell.
|
|
|
|
* \param type The type of the spell.
|
|
|
|
* \param cost The cost of the spell.
|
|
|
|
* \param flags The flags of the spell.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddCustomSpellData(unsigned short pid, const char* spellId, int type, int cost, int flags) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add custom spell effect to the spellbook changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose spellbook changes should be used.
|
|
|
|
* \param spellId The spellId of the spell.
|
|
|
|
* \param effectId The effectId of the spell effect.
|
|
|
|
* \param mSkill The skill affected by the spell effect.
|
|
|
|
* \param mAttribute The attribute affected by the spell effect.
|
|
|
|
* \param mRange The range of the spell effect.
|
|
|
|
* \param mArea The area of the spell effect.
|
|
|
|
* \param mDuration The duration of the spell effect.
|
|
|
|
* \param mMagnMin The minimum magnitude of the spell effect.
|
|
|
|
* \param mMagnMax The maximum magnitude of the spell effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddCustomSpellEffect(unsigned short pid, const char* spellId, short effectId, signed char mSkill, signed char mAttribute, int mRange, int mArea, int mDuration, int mMagnMin, int mMagnMax) 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-30 17:45:47 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the name of the spell 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 spell name.
|
|
|
|
*/
|
|
|
|
static const char *GetSpellName(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the type of the spell 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 spell type.
|
|
|
|
*/
|
|
|
|
static int GetSpellType(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the cost of the spell 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 spell cost.
|
|
|
|
*/
|
|
|
|
static int GetSpellCost(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the flags of the spell 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 spell flags.
|
|
|
|
*/
|
|
|
|
static int GetSpellFlags(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of effects on the spell 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 spell effect count.
|
|
|
|
*/
|
|
|
|
static unsigned int GetSpellEffectCount(unsigned short pid, unsigned int i) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the effectId of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The effectId.
|
|
|
|
*/
|
|
|
|
static short GetSpellEffectId(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the affected skill of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The affected skill.
|
|
|
|
*/
|
|
|
|
static signed char GetSpellEffectSkill(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the affected attribute of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The affected attribute.
|
|
|
|
*/
|
|
|
|
static signed char GetSpellEffectAttribute(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the range of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The range.
|
|
|
|
*/
|
|
|
|
static int GetSpellEffectRange(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the area of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The area.
|
|
|
|
*/
|
|
|
|
static int GetSpellEffectArea(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the duration of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The duration.
|
|
|
|
*/
|
|
|
|
static int GetSpellEffectDuration(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the minimum magnitude of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The minimum magnitude.
|
|
|
|
*/
|
|
|
|
static int GetSpellEffectMagnMin(unsigned short pid, unsigned int i, unsigned int j) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the maximum magnitude of the effect at a certain index in the spell at another 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.
|
|
|
|
* \param j The index of the effect.
|
|
|
|
* \return The maximum magnitude.
|
|
|
|
*/
|
|
|
|
static int GetSpellEffectMagnMax(unsigned short pid, unsigned int i, unsigned int j) 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
|