2017-04-09 09:28:38 +00:00
|
|
|
#ifndef OPENMW_QUESTAPI_HPP
|
|
|
|
#define OPENMW_QUESTAPI_HPP
|
2017-01-24 17:32:25 +00:00
|
|
|
|
|
|
|
#define QUESTAPI \
|
2018-10-02 23:26:47 +00:00
|
|
|
{"ClearJournalChanges", QuestFunctions::ClearJournalChanges},\
|
|
|
|
{"ClearKillChanges", QuestFunctions::ClearKillChanges},\
|
2017-07-07 06:25:48 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"GetJournalChangesSize", QuestFunctions::GetJournalChangesSize},\
|
|
|
|
{"GetKillChangesSize", QuestFunctions::GetKillChangesSize},\
|
2017-01-24 17:32:25 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"AddJournalEntry", QuestFunctions::AddJournalEntry},\
|
|
|
|
{"AddJournalEntryWithTimestamp", QuestFunctions::AddJournalEntryWithTimestamp},\
|
|
|
|
{"AddJournalIndex", QuestFunctions::AddJournalIndex},\
|
|
|
|
{"AddKill", QuestFunctions::AddKill},\
|
2017-01-24 17:32:25 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"SetReputation", QuestFunctions::SetReputation},\
|
2018-01-30 20:55:29 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"GetJournalItemQuest", QuestFunctions::GetJournalItemQuest},\
|
|
|
|
{"GetJournalItemIndex", QuestFunctions::GetJournalItemIndex},\
|
|
|
|
{"GetJournalItemType", QuestFunctions::GetJournalItemType},\
|
|
|
|
{"GetJournalItemActorRefId", QuestFunctions::GetJournalItemActorRefId},\
|
|
|
|
{"GetKillRefId", QuestFunctions::GetKillRefId},\
|
|
|
|
{"GetKillNumber", QuestFunctions::GetKillNumber},\
|
2017-01-24 17:32:25 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"GetReputation", QuestFunctions::GetReputation},\
|
2018-01-30 20:55:29 +00:00
|
|
|
\
|
2018-07-26 01:36:12 +00:00
|
|
|
{"SendJournalChanges", QuestFunctions::SendJournalChanges},\
|
|
|
|
{"SendKillChanges", QuestFunctions::SendKillChanges},\
|
2018-10-02 23:26:47 +00:00
|
|
|
{"SendReputation", QuestFunctions::SendReputation},\
|
|
|
|
\
|
|
|
|
{"InitializeJournalChanges", QuestFunctions::InitializeJournalChanges},\
|
|
|
|
{"InitializeKillChanges", QuestFunctions::InitializeKillChanges}
|
2017-01-24 17:32:25 +00:00
|
|
|
|
|
|
|
class QuestFunctions
|
|
|
|
{
|
|
|
|
public:
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear the last recorded journal changes for a player.
|
|
|
|
*
|
|
|
|
* This is used to initialize the sending of new PlayerJournal packets.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-10-02 23:26:47 +00:00
|
|
|
static void ClearJournalChanges(unsigned short pid) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear the last recorded kill count changes for a player.
|
|
|
|
*
|
2018-07-15 02:34:59 +00:00
|
|
|
* This is used to initialize the sending of new WorldKillCount packets.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-10-02 23:26:47 +00:00
|
|
|
static void ClearKillChanges(unsigned short pid) noexcept;
|
2017-01-24 17:32:25 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the number of indexes in a player's latest journal changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
|
|
|
* \return The number of indexes.
|
|
|
|
*/
|
2017-01-24 17:32:25 +00:00
|
|
|
static unsigned int GetJournalChangesSize(unsigned short pid) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of indexes in a player's latest kill count changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
|
|
|
* \return The number of indexes.
|
|
|
|
*/
|
2017-07-11 04:15:06 +00:00
|
|
|
static unsigned int GetKillChangesSize(unsigned short pid) noexcept;
|
2017-01-24 17:32:25 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
2018-07-26 01:36:12 +00:00
|
|
|
* \brief Add a new journal item of type ENTRY to the journal changes for a player,
|
|
|
|
* with a specific timestamp.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
|
|
|
* \param quest The quest of the journal item.
|
|
|
|
* \param index The quest index of the journal item.
|
|
|
|
* \param actorRefId The actor refId of the journal item.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-06-23 05:12:32 +00:00
|
|
|
static void AddJournalEntry(unsigned short pid, const char* quest, unsigned int index, const char* actorRefId) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
2018-07-26 01:36:12 +00:00
|
|
|
/**
|
|
|
|
* \brief Add a new journal item of type ENTRY to the journal changes for a player,
|
|
|
|
* with a specific timestamp.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
|
|
|
* \param quest The quest of the journal item.
|
|
|
|
* \param index The quest index of the journal item.
|
|
|
|
* \param actorRefId The actor refId of the journal item.
|
|
|
|
* \param The daysPassed for the journal item.
|
|
|
|
* \param The month for the journal item.
|
|
|
|
* \param The day of the month for the journal item.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddJournalEntryWithTimestamp(unsigned short pid, const char* quest, unsigned int index, const char* actorRefId,
|
|
|
|
unsigned int daysPassed, unsigned int month, unsigned int day) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Add a new journal item of type INDEX to the journal changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
|
|
|
* \param quest The quest of the journal item.
|
|
|
|
* \param index The quest index of the journal item.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-01-24 17:32:25 +00:00
|
|
|
static void AddJournalIndex(unsigned short pid, const char* quest, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add a new kill count to the kill count changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
|
|
|
* \param refId The refId of the kill count.
|
|
|
|
* \param number The number of kills in the kill count.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-11 04:15:06 +00:00
|
|
|
static void AddKill(unsigned short pid, const char* refId, int number) noexcept;
|
2017-01-24 17:32:25 +00:00
|
|
|
|
2018-01-30 20:55:29 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the reputation of a certain player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID.
|
|
|
|
* \param value The reputation.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetReputation(unsigned short pid, int value) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the quest at a certain index in a player's latest journal changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the journalItem.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The quest.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static const char *GetJournalItemQuest(unsigned short pid, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the quest index at a certain index in a player's latest journal changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the journalItem.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The quest index.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static int GetJournalItemIndex(unsigned short pid, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the journal item type at a certain index in a player's latest journal changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the journalItem.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The type (0 for ENTRY, 1 for INDEX).
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static int GetJournalItemType(unsigned short pid, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the actor refId at a certain index in a player's latest journal changes.
|
|
|
|
*
|
|
|
|
* Every journal change has an associated actor, which is usually the quest giver.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the journalItem.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The actor refId.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static const char *GetJournalItemActorRefId(unsigned short pid, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the refId at a certain index in a player's latest kill count changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the kill count.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The refId.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static const char *GetKillRefId(unsigned short pid, unsigned int index) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of kills at a certain index in a player's latest kill count changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the kill count.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The number of kills.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static int GetKillNumber(unsigned short pid, unsigned int index) noexcept;
|
2017-01-24 17:32:25 +00:00
|
|
|
|
2018-01-30 20:55:29 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the a certain player's reputation.
|
|
|
|
*
|
|
|
|
* \param pid The player ID.
|
|
|
|
* \return The reputation.
|
|
|
|
*/
|
|
|
|
static int GetReputation(unsigned short pid) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerJournal packet with a player's recorded journal changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose journal changes should be used.
|
2018-07-07 15:29:31 +00:00
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
2018-07-07 17:16:36 +00:00
|
|
|
* \param skipAttachedPlayer Whether the packet should skip being sent to the player attached
|
|
|
|
* to the packet (false by default).
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 17:08:59 +00:00
|
|
|
static void SendJournalChanges(unsigned short pid, bool sendToOtherPlayers, bool skipAttachedPlayer) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
2018-07-15 02:34:59 +00:00
|
|
|
* \brief Send a WorldKillCount packet with a player's recorded kill count changes.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID whose kill count changes should be used.
|
2018-07-07 15:29:31 +00:00
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
2018-07-07 17:16:36 +00:00
|
|
|
* \param skipAttachedPlayer Whether the packet should skip being sent to the player attached
|
|
|
|
* to the packet (false by default).
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 17:08:59 +00:00
|
|
|
static void SendKillChanges(unsigned short pid, bool sendToOtherPlayers, bool skipAttachedPlayer) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
2018-01-30 20:55:29 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerReputation packet with a player's recorded reputation.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose reputation should be used.
|
2018-07-07 15:29:31 +00:00
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
2018-07-07 17:16:36 +00:00
|
|
|
* \param skipAttachedPlayer Whether the packet should skip being sent to the player attached
|
|
|
|
* to the packet (false by default).
|
2018-01-30 20:55:29 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 17:08:59 +00:00
|
|
|
static void SendReputation(unsigned short pid, bool sendToOtherPlayers, bool skipAttachedPlayer) noexcept;
|
2018-01-30 20:55:29 +00:00
|
|
|
|
2018-10-02 23:26:47 +00:00
|
|
|
// All methods below are deprecated versions of methods from above
|
|
|
|
|
|
|
|
static void InitializeJournalChanges(unsigned short pid) noexcept;
|
|
|
|
static void InitializeKillChanges(unsigned short pid) noexcept;
|
|
|
|
|
2017-01-24 17:32:25 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-04-09 09:28:38 +00:00
|
|
|
#endif //OPENMW_QUESTAPI_HPP
|