[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
#ifndef OPENMW_RECORDSDYNAMICAPI_HPP
|
|
|
|
#define OPENMW_RECORDSDYNAMICAPI_HPP
|
|
|
|
|
|
|
|
#include "../Types.hpp"
|
|
|
|
|
|
|
|
#define RECORDSDYNAMICAPI \
|
|
|
|
{"ClearRecords", RecordsDynamicFunctions::ClearRecords},\
|
|
|
|
\
|
|
|
|
{"GetRecordType", RecordsDynamicFunctions::GetRecordType},\
|
|
|
|
{"GetRecordCount", RecordsDynamicFunctions::GetRecordCount},\
|
|
|
|
{"GetRecordEffectCount", RecordsDynamicFunctions::GetRecordEffectCount},\
|
|
|
|
\
|
|
|
|
{"GetRecordId", RecordsDynamicFunctions::GetRecordId},\
|
|
|
|
{"GetRecordBaseId", RecordsDynamicFunctions::GetRecordBaseId},\
|
|
|
|
\
|
|
|
|
{"GetRecordSubtype", RecordsDynamicFunctions::GetRecordSubtype},\
|
|
|
|
{"GetRecordName", RecordsDynamicFunctions::GetRecordName},\
|
|
|
|
{"GetRecordModel", RecordsDynamicFunctions::GetRecordModel},\
|
|
|
|
{"GetRecordIcon", RecordsDynamicFunctions::GetRecordIcon},\
|
|
|
|
{"GetRecordScript", RecordsDynamicFunctions::GetRecordScript},\
|
|
|
|
{"GetRecordEnchantmentId", RecordsDynamicFunctions::GetRecordEnchantmentId},\
|
|
|
|
{"GetRecordEnchantmentCharge", RecordsDynamicFunctions::GetRecordEnchantmentCharge},\
|
|
|
|
\
|
|
|
|
{"GetRecordAutoCalc", RecordsDynamicFunctions::GetRecordAutoCalc},\
|
|
|
|
{"GetRecordCharge", RecordsDynamicFunctions::GetRecordCharge},\
|
|
|
|
{"GetRecordCost", RecordsDynamicFunctions::GetRecordCost},\
|
|
|
|
{"GetRecordFlags", RecordsDynamicFunctions::GetRecordFlags},\
|
|
|
|
{"GetRecordValue", RecordsDynamicFunctions::GetRecordValue},\
|
|
|
|
{"GetRecordWeight", RecordsDynamicFunctions::GetRecordWeight},\
|
2020-02-22 19:21:30 +00:00
|
|
|
{"GetRecordQuantity", RecordsDynamicFunctions::GetRecordQuantity},\
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
\
|
|
|
|
{"GetRecordEffectId", RecordsDynamicFunctions::GetRecordEffectId},\
|
|
|
|
{"GetRecordEffectAttribute", RecordsDynamicFunctions::GetRecordEffectAttribute},\
|
|
|
|
{"GetRecordEffectSkill", RecordsDynamicFunctions::GetRecordEffectSkill},\
|
|
|
|
{"GetRecordEffectRangeType", RecordsDynamicFunctions::GetRecordEffectRangeType},\
|
|
|
|
{"GetRecordEffectArea", RecordsDynamicFunctions::GetRecordEffectArea},\
|
|
|
|
{"GetRecordEffectDuration", RecordsDynamicFunctions::GetRecordEffectDuration},\
|
|
|
|
{"GetRecordEffectMagnitudeMax", RecordsDynamicFunctions::GetRecordEffectMagnitudeMax},\
|
|
|
|
{"GetRecordEffectMagnitudeMin", RecordsDynamicFunctions::GetRecordEffectMagnitudeMin},\
|
|
|
|
\
|
|
|
|
{"SetRecordType", RecordsDynamicFunctions::SetRecordType},\
|
|
|
|
\
|
|
|
|
{"SetRecordId", RecordsDynamicFunctions::SetRecordId},\
|
|
|
|
{"SetRecordBaseId", RecordsDynamicFunctions::SetRecordBaseId},\
|
|
|
|
{"SetRecordInventoryBaseId", RecordsDynamicFunctions::SetRecordInventoryBaseId},\
|
|
|
|
\
|
|
|
|
{"SetRecordSubtype", RecordsDynamicFunctions::SetRecordSubtype},\
|
|
|
|
{"SetRecordName", RecordsDynamicFunctions::SetRecordName},\
|
|
|
|
{"SetRecordModel", RecordsDynamicFunctions::SetRecordModel},\
|
|
|
|
{"SetRecordIcon", RecordsDynamicFunctions::SetRecordIcon},\
|
|
|
|
{"SetRecordScript", RecordsDynamicFunctions::SetRecordScript},\
|
|
|
|
{"SetRecordEnchantmentId", RecordsDynamicFunctions::SetRecordEnchantmentId},\
|
|
|
|
{"SetRecordEnchantmentCharge", RecordsDynamicFunctions::SetRecordEnchantmentCharge},\
|
|
|
|
\
|
|
|
|
{"SetRecordAutoCalc", RecordsDynamicFunctions::SetRecordAutoCalc},\
|
|
|
|
{"SetRecordCharge", RecordsDynamicFunctions::SetRecordCharge},\
|
|
|
|
{"SetRecordCost", RecordsDynamicFunctions::SetRecordCost},\
|
|
|
|
{"SetRecordFlags", RecordsDynamicFunctions::SetRecordFlags},\
|
|
|
|
{"SetRecordValue", RecordsDynamicFunctions::SetRecordValue},\
|
|
|
|
{"SetRecordWeight", RecordsDynamicFunctions::SetRecordWeight},\
|
2019-08-04 14:53:18 +00:00
|
|
|
{"SetRecordQuality", RecordsDynamicFunctions::SetRecordQuality},\
|
|
|
|
{"SetRecordUses", RecordsDynamicFunctions::SetRecordUses},\
|
2019-08-14 18:10:53 +00:00
|
|
|
{"SetRecordTime", RecordsDynamicFunctions::SetRecordTime},\
|
|
|
|
{"SetRecordRadius", RecordsDynamicFunctions::SetRecordRadius},\
|
|
|
|
{"SetRecordColor", RecordsDynamicFunctions::SetRecordColor},\
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
\
|
|
|
|
{"SetRecordArmorRating", RecordsDynamicFunctions::SetRecordArmorRating},\
|
|
|
|
{"SetRecordHealth", RecordsDynamicFunctions::SetRecordHealth},\
|
|
|
|
\
|
|
|
|
{"SetRecordDamageChop", RecordsDynamicFunctions::SetRecordDamageChop},\
|
|
|
|
{"SetRecordDamageSlash", RecordsDynamicFunctions::SetRecordDamageSlash},\
|
|
|
|
{"SetRecordDamageThrust", RecordsDynamicFunctions::SetRecordDamageThrust},\
|
|
|
|
{"SetRecordReach", RecordsDynamicFunctions::SetRecordReach},\
|
|
|
|
{"SetRecordSpeed", RecordsDynamicFunctions::SetRecordSpeed},\
|
|
|
|
\
|
|
|
|
{"SetRecordKeyState", RecordsDynamicFunctions::SetRecordKeyState},\
|
|
|
|
{"SetRecordScrollState", RecordsDynamicFunctions::SetRecordScrollState},\
|
|
|
|
{"SetRecordSkillId", RecordsDynamicFunctions::SetRecordSkillId},\
|
|
|
|
{"SetRecordText", RecordsDynamicFunctions::SetRecordText},\
|
|
|
|
\
|
|
|
|
{"SetRecordHair", RecordsDynamicFunctions::SetRecordHair},\
|
|
|
|
{"SetRecordHead", RecordsDynamicFunctions::SetRecordHead},\
|
|
|
|
{"SetRecordGender", RecordsDynamicFunctions::SetRecordGender},\
|
|
|
|
{"SetRecordRace", RecordsDynamicFunctions::SetRecordRace},\
|
|
|
|
{"SetRecordClass", RecordsDynamicFunctions::SetRecordClass},\
|
|
|
|
{"SetRecordFaction", RecordsDynamicFunctions::SetRecordFaction},\
|
|
|
|
\
|
2019-11-10 07:20:45 +00:00
|
|
|
{"SetRecordScale", RecordsDynamicFunctions::SetRecordScale},\
|
|
|
|
{"SetRecordBloodType", RecordsDynamicFunctions::SetRecordBloodType},\
|
2019-11-29 12:06:17 +00:00
|
|
|
{"SetRecordVampireState", RecordsDynamicFunctions::SetRecordVampireState},\
|
2019-11-10 07:20:45 +00:00
|
|
|
\
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
{"SetRecordLevel", RecordsDynamicFunctions::SetRecordLevel},\
|
2018-08-05 08:00:25 +00:00
|
|
|
{"SetRecordMagicka", RecordsDynamicFunctions::SetRecordMagicka},\
|
|
|
|
{"SetRecordFatigue", RecordsDynamicFunctions::SetRecordFatigue},\
|
2019-08-07 07:44:07 +00:00
|
|
|
\
|
2021-05-25 11:55:12 +00:00
|
|
|
{"SetRecordSoulValue", RecordsDynamicFunctions::SetRecordSoulValue},\
|
|
|
|
\
|
2018-08-11 15:57:36 +00:00
|
|
|
{"SetRecordAIFight", RecordsDynamicFunctions::SetRecordAIFight},\
|
2019-08-07 08:21:22 +00:00
|
|
|
{"SetRecordAIFlee", RecordsDynamicFunctions::SetRecordAIFlee},\
|
|
|
|
{"SetRecordAIAlarm", RecordsDynamicFunctions::SetRecordAIAlarm},\
|
2019-08-07 07:44:07 +00:00
|
|
|
{"SetRecordAIServices", RecordsDynamicFunctions::SetRecordAIServices},\
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
\
|
2019-08-14 18:10:53 +00:00
|
|
|
{"SetRecordSound", RecordsDynamicFunctions::SetRecordSound},\
|
2020-12-21 17:42:18 +00:00
|
|
|
{"SetRecordVolume", RecordsDynamicFunctions::SetRecordVolume},\
|
2020-03-15 18:17:00 +00:00
|
|
|
{"SetRecordMinRange", RecordsDynamicFunctions::SetRecordMinRange},\
|
|
|
|
{"SetRecordMaxRange", RecordsDynamicFunctions::SetRecordMaxRange},\
|
2019-07-27 00:45:50 +00:00
|
|
|
{"SetRecordOpenSound", RecordsDynamicFunctions::SetRecordOpenSound},\
|
|
|
|
{"SetRecordCloseSound", RecordsDynamicFunctions::SetRecordCloseSound},\
|
|
|
|
\
|
2019-11-09 19:34:09 +00:00
|
|
|
{"SetRecordScriptText", RecordsDynamicFunctions::SetRecordScriptText},\
|
2021-07-18 09:36:07 +00:00
|
|
|
{"SetRecordIntegerVariable", RecordsDynamicFunctions::SetRecordIntegerVariable},\
|
|
|
|
{"SetRecordFloatVariable", RecordsDynamicFunctions::SetRecordFloatVariable},\
|
|
|
|
{"SetRecordStringVariable", RecordsDynamicFunctions::SetRecordStringVariable},\
|
2019-11-09 19:34:09 +00:00
|
|
|
\
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
{"SetRecordIdByIndex", RecordsDynamicFunctions::SetRecordIdByIndex},\
|
|
|
|
{"SetRecordEnchantmentIdByIndex", RecordsDynamicFunctions::SetRecordEnchantmentIdByIndex},\
|
|
|
|
\
|
|
|
|
{"SetRecordEffectId", RecordsDynamicFunctions::SetRecordEffectId},\
|
|
|
|
{"SetRecordEffectAttribute", RecordsDynamicFunctions::SetRecordEffectAttribute},\
|
|
|
|
{"SetRecordEffectSkill", RecordsDynamicFunctions::SetRecordEffectSkill},\
|
|
|
|
{"SetRecordEffectRangeType", RecordsDynamicFunctions::SetRecordEffectRangeType},\
|
|
|
|
{"SetRecordEffectArea", RecordsDynamicFunctions::SetRecordEffectArea},\
|
|
|
|
{"SetRecordEffectDuration", RecordsDynamicFunctions::SetRecordEffectDuration},\
|
|
|
|
{"SetRecordEffectMagnitudeMax", RecordsDynamicFunctions::SetRecordEffectMagnitudeMax},\
|
|
|
|
{"SetRecordEffectMagnitudeMin", RecordsDynamicFunctions::SetRecordEffectMagnitudeMin},\
|
|
|
|
\
|
|
|
|
{"SetRecordBodyPartType", RecordsDynamicFunctions::SetRecordBodyPartType},\
|
|
|
|
{"SetRecordBodyPartIdForMale", RecordsDynamicFunctions::SetRecordBodyPartIdForMale},\
|
|
|
|
{"SetRecordBodyPartIdForFemale", RecordsDynamicFunctions::SetRecordBodyPartIdForFemale},\
|
|
|
|
\
|
|
|
|
{"SetRecordInventoryItemId", RecordsDynamicFunctions::SetRecordInventoryItemId},\
|
|
|
|
{"SetRecordInventoryItemCount", RecordsDynamicFunctions::SetRecordInventoryItemCount},\
|
|
|
|
\
|
|
|
|
{"AddRecord", RecordsDynamicFunctions::AddRecord},\
|
|
|
|
{"AddRecordEffect", RecordsDynamicFunctions::AddRecordEffect},\
|
|
|
|
{"AddRecordBodyPart", RecordsDynamicFunctions::AddRecordBodyPart},\
|
|
|
|
{"AddRecordInventoryItem", RecordsDynamicFunctions::AddRecordInventoryItem},\
|
|
|
|
\
|
|
|
|
{"SendRecordDynamic", RecordsDynamicFunctions::SendRecordDynamic}
|
|
|
|
|
|
|
|
class RecordsDynamicFunctions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear the data from the records stored on the server.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void ClearRecords() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the type of records in the read worldstate's dynamic records.
|
|
|
|
*
|
|
|
|
* \return The type of records (0 for SPELL, 1 for POTION, 2 for ENCHANTMENT,
|
|
|
|
* 3 for NPC).
|
|
|
|
*/
|
|
|
|
static unsigned short GetRecordType() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of records in the read worldstate's dynamic records.
|
|
|
|
*
|
|
|
|
* \return The number of records.
|
|
|
|
*/
|
|
|
|
static unsigned int GetRecordCount() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of effects for the record at a certain index in the read
|
|
|
|
* worldstate's current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \return The number of effects.
|
|
|
|
*/
|
|
|
|
static unsigned int GetRecordEffectCount(unsigned int recordIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the id of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The id of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordId(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the base id (i.e. the id this record should inherit default
|
|
|
|
* values from) of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The base id of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordBaseId(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the subtype of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The type of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordSubtype(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the name of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The name of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordName(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the model of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The model of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordModel(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the icon of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The icon of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordIcon(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the script of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The script of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordScript(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the enchantment id of the record at a certain index in the read
|
|
|
|
* worldstate's dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The enchantment id of the record.
|
|
|
|
*/
|
|
|
|
static const char *GetRecordEnchantmentId(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the enchantment charge of the record at a certain index in
|
|
|
|
* the read worldstate's dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The enchantment charge of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordEnchantmentCharge(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the auto-calculation flag value of the record at a certain index in
|
|
|
|
* the read worldstate's dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The auto-calculation flag value of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordAutoCalc(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the charge of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The charge of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordCharge(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the cost of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The cost of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordCost(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the flags of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The flags of the spell as an integer.
|
|
|
|
*/
|
|
|
|
static int GetRecordFlags(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the value of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The value of the record.
|
|
|
|
*/
|
|
|
|
static int GetRecordValue(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the weight of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The weight of the record.
|
|
|
|
*/
|
|
|
|
static double GetRecordWeight(unsigned int index) noexcept;
|
|
|
|
|
2020-02-22 19:21:30 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the quantity of the record at a certain index in the read worldstate's
|
|
|
|
* dynamic records of the current type.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \return The brewed count of the record.
|
|
|
|
*/
|
|
|
|
static unsigned int GetRecordQuantity(unsigned int index) noexcept;
|
|
|
|
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the ID of the effect at a certain index in the read worldstate's
|
|
|
|
* current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The ID of the effect.
|
|
|
|
*/
|
|
|
|
static unsigned int GetRecordEffectId(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the ID of the attribute modified by the effect at a certain index in the
|
|
|
|
* read worldstate's current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The attribute ID for the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectAttribute(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the ID of the skill modified by the effect at a certain index in the
|
|
|
|
* read worldstate's current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The skill ID for the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectSkill(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the range type of the effect at a certain index in the read worldstate's
|
|
|
|
* current records (0 for self, 1 for touch, 2 for target).
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The range of the effect.
|
|
|
|
*/
|
|
|
|
static unsigned int GetRecordEffectRangeType(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the area of the effect at a certain index in the read worldstate's current
|
|
|
|
* records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The area of the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectArea(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the duration of the effect at a certain index in the read worldstate's current
|
|
|
|
* records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The duration of the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectDuration(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the maximum magnitude of the effect at a certain index in the read
|
|
|
|
* worldstate's current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The maximum magnitude of the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectMagnitudeMax(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the minimum magnitude of the effect at a certain index in the read
|
|
|
|
* worldstate's current records.
|
|
|
|
*
|
|
|
|
* \param recordIndex The index of the record.
|
|
|
|
* \param effectIndex The index of the effect.
|
|
|
|
* \return The minimum magnitude of the effect.
|
|
|
|
*/
|
|
|
|
static int GetRecordEffectMagnitudeMin(unsigned int recordIndex, unsigned int effectIndex) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set which type of temporary records stored on the server should have
|
|
|
|
* their data changed via setter functions.
|
|
|
|
*
|
|
|
|
* \param type The type of records.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordType(unsigned int type) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the id of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param id The id of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordId(const char* id) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the base id (i.e. the id this record should inherit default
|
|
|
|
* values from) of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param baseId The baseId of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordBaseId(const char* baseId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the inventory base id (i.e. the id this record should inherit
|
|
|
|
* its inventory contents from) of the temporary record stored on the server for
|
|
|
|
* the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param inventoryBaseId The inventoryBaseId of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordInventoryBaseId(const char* inventoryBaseId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the subtype of the temporary record stored on the server for
|
|
|
|
* the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param type The spell type.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordSubtype(unsigned int subtype) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the name of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param name The name of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordName(const char* name) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the model of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param model The model of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordModel(const char* model) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the icon of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param icon The icon of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordIcon(const char* icon) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the script of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param script The script of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordScript(const char* script) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the enchantment id of the temporary record stored on the server
|
|
|
|
* for the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param enchantmentId The enchantment id of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEnchantmentId(const char* enchantmentId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the enchantment charge of the temporary record stored on the server
|
|
|
|
* for the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param enchantmentCharge The enchantmentCharge of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEnchantmentCharge(int enchantmentCharge) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the auto-calculation flag value of the temporary record stored
|
|
|
|
* on the server for the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param autoCalc The auto-calculation flag value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordAutoCalc(int autoCalc) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the charge of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param charge The charge of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordCharge(int charge) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the cost of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param cost The cost of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordCost(int cost) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the flags of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param flags The flags of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordFlags(int flags) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param value The value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordValue(int value) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the weight of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param weight The weight of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordWeight(double weight) noexcept;
|
|
|
|
|
2019-08-04 14:53:18 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the item quality of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param weight The weight of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordQuality(double quality) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the number of uses of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param uses The number of uses of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordUses(int uses) noexcept;
|
|
|
|
|
2019-08-14 18:10:53 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the time of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param time The time of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordTime(int time) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the radius of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param uses The radius of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordRadius(int radius) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the color of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param color The color of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordColor(unsigned int red, unsigned int green, unsigned int blue) noexcept;
|
|
|
|
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the armor rating of the temporary record stored on the server
|
|
|
|
* for the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param armorRating The armor rating of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordArmorRating(int armorRating) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the health of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param health The health of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordHealth(int health) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the chop damage of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param minDamage The minimum damage of the record.
|
|
|
|
* \param maxDamage The maximum damage of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordDamageChop(unsigned int minDamage, unsigned int maxDamage) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the slash damage of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param minDamage The minimum damage of the record.
|
|
|
|
* \param maxDamage The maximum damage of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordDamageSlash(unsigned int minDamage, unsigned int maxDamage) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the thrust damage of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param minDamage The minimum damage of the record.
|
|
|
|
* \param maxDamage The maximum damage of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordDamageThrust(unsigned int minDamage, unsigned int maxDamage) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the reach of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param reach The reach of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordReach(double reach) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the speed of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param speed The speed of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordSpeed(double speed) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set whether the temporary record stored on the server for the
|
|
|
|
* currently specified record type is a key.
|
|
|
|
*
|
|
|
|
* Note: This is only applicable to Miscellaneous records.
|
|
|
|
*
|
|
|
|
* \param keyState Whether the record is a key.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordKeyState(bool keyState) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set whether the temporary record stored on the server for the
|
|
|
|
* currently specified record type is a scroll.
|
|
|
|
*
|
|
|
|
* Note: This is only applicable to Book records.
|
|
|
|
*
|
|
|
|
* \param scrollState Whether the record is a scroll.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordScrollState(bool scrollState) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the skill ID of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param skillId The skill ID of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordSkillId(int skillId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the text of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param text The text of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordText(const char* text) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the hair of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param hair The hair of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordHair(const char* hair) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the head of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param hair The head of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordHead(const char* head) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the gender of the temporary record stored on the server for the
|
|
|
|
* currently specified record type (0 for female, 1 for male).
|
|
|
|
*
|
|
|
|
* \param hair The race of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordGender(unsigned int gender) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the race of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param hair The race of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordRace(const char* race) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the character class of the temporary record stored on the server
|
|
|
|
* for the currently specified record type.
|
|
|
|
*
|
|
|
|
* \param hair The character class of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordClass(const char* charClass) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the faction of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param faction The faction of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordFaction(const char* faction) noexcept;
|
|
|
|
|
2019-11-10 07:20:45 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the scale of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param scale The scale of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordScale(double scale) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the blood type of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param bloodType The blood type of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordBloodType(int bloodType) noexcept;
|
|
|
|
|
2019-11-29 12:06:17 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the vampire state of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param vampireState The vampire state of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordVampireState(bool vampireState) noexcept;
|
|
|
|
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the level of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
2018-08-05 08:00:25 +00:00
|
|
|
* \param level The level of the record.
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordLevel(int level) noexcept;
|
|
|
|
|
2018-08-05 08:00:25 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the magicka of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param magicka The magicka of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordMagicka(int magicka) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the fatigue of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param fatigue The fatigue of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordFatigue(int fatigue) noexcept;
|
|
|
|
|
2021-05-25 11:55:12 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the soul value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param soulValue The soul value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordSoulValue(int soulValue) noexcept;
|
|
|
|
|
2018-08-05 08:00:25 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the AI fight value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param aiFight The AI fight value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-08-11 15:57:36 +00:00
|
|
|
static void SetRecordAIFight(int aiFight) noexcept;
|
2018-08-05 08:00:25 +00:00
|
|
|
|
2019-08-07 08:21:22 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the AI flee value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param aiFlee The AI flee value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordAIFlee(int aiFlee) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the AI alarm value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param aiAlarm The AI alarm value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordAIAlarm(int aiAlarm) noexcept;
|
|
|
|
|
2019-08-07 07:44:07 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the AI services value of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param aiServices The AI services value of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordAIServices(int aiServices) noexcept;
|
|
|
|
|
2019-08-14 18:10:53 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the sound of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param sound The sound of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordSound(const char* sound) noexcept;
|
|
|
|
|
2020-03-15 18:17:00 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the volume of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param volume The volume of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordVolume(double volume) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the minimum range of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param volume The minimum range of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordMinRange(double minRange) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the maximum range of the temporary record stored on the server for the currently
|
|
|
|
* specified record type.
|
|
|
|
*
|
|
|
|
* \param volume The maximum range of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordMaxRange(double maxRange) noexcept;
|
|
|
|
|
2019-07-27 00:45:50 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the opening sound of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param sound The opening sound of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordOpenSound(const char* sound) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the closing sound of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param sound The closing sound of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordCloseSound(const char* sound) noexcept;
|
|
|
|
|
2019-11-09 19:34:09 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the script text of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
2021-07-18 09:36:07 +00:00
|
|
|
* \param scriptText The script text of the record.
|
2019-11-09 19:34:09 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordScriptText(const char* scriptText) noexcept;
|
|
|
|
|
2021-07-18 09:36:07 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the integer variable of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param intVar The integer variable of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordIntegerVariable(int intVar) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the float variable of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param floatVar The float variable of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordFloatVariable(double floatVar) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the string variable of the temporary record stored on the server for the
|
|
|
|
* currently specified record type.
|
|
|
|
*
|
|
|
|
* \param stringVar The string variable of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordStringVariable(const char* stringVar) noexcept;
|
|
|
|
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the id of the record at a certain index in the records stored on the server.
|
|
|
|
*
|
|
|
|
* When resending a received RecordsDynamic packet, this allows you to set the server-generated
|
|
|
|
* id of a record without having to clear and recreate the packet.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \param id The id of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordIdByIndex(unsigned int index, const char* id) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the enchantment id of the record at a certain index in the records stored on
|
|
|
|
* the server.
|
|
|
|
*
|
|
|
|
* When resending a received RecordsDynamic packet, this allows you to set the server-generated
|
|
|
|
* enchantment id of a record without having to clear and recreate the packet.
|
|
|
|
*
|
|
|
|
* \param index The index of the record.
|
|
|
|
* \param enchantmentId The enchantment id of the record.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEnchantmentIdByIndex(unsigned int index, const char* enchantmentId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the ID of the temporary effect stored on the server.
|
|
|
|
*
|
|
|
|
* \param effectId The ID of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectId(unsigned int effectId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the ID of the attribute modified by the temporary effect stored on
|
|
|
|
* the server.
|
|
|
|
*
|
|
|
|
* \param attributeId The ID of the attribute.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectAttribute(int attributeId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the ID of the skill modified by the temporary effect stored on the
|
|
|
|
* server.
|
|
|
|
*
|
|
|
|
* \param skillId The ID of the skill.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectSkill(int skillId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the range type of the temporary effect stored on the server (0 for
|
|
|
|
* self, 1 for touch, 2 for target).
|
|
|
|
*
|
|
|
|
* \param rangeType The range type of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectRangeType(unsigned int rangeType) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the area of the temporary effect stored on the server.
|
|
|
|
*
|
|
|
|
* \param area The area of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectArea(int area) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the duration of the temporary effect stored on the server.
|
|
|
|
*
|
|
|
|
* \param duration The duration of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectDuration(int duration) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the maximum magnitude of the temporary effect stored on the server.
|
|
|
|
*
|
|
|
|
* \param magnitudeMax The maximum magnitude of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectMagnitudeMax(int magnitudeMax) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the minimum magnitude of the temporary effect stored on the server.
|
|
|
|
*
|
|
|
|
* \param magnitudeMin The minimum magnitude of the effect.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordEffectMagnitudeMin(int magnitudeMin) noexcept;
|
|
|
|
|
|
|
|
/**
|
2019-11-29 12:06:17 +00:00
|
|
|
* \brief Set the body part type of the temporary body part stored on the server
|
|
|
|
* (which then needs to be added to ARMOR or CLOTHING records) or set the body part
|
|
|
|
* type of the current record if it's a BODYPART.
|
[General] Implement RecordDynamic packet, part 1
Spell, potion, enchantment, creature, NPC, armor, book, clothing, miscellaneous and weapon record data can now be sent in a RecordDynamic packet. Additionally, the packets include data related to associated magical effects (for spells, potions and enchantments), data related to default inventory contents (for creatures and NPCs) and data related to body parts affected (for armor and clothing).
The server now has associated script functions for setting most of the details of the above, with the main exception being individual creature and NPC stats.
Records can either be created entirely from scratch or can use an existing record (set via the baseId variable) as a starting point for their values. In the latter case, only the values that are specifically set override the starting values. Creature and NPC records also have an inventoryBaseId that can be used on top of the baseId to base their inventories on another existing record.
The client's RecordHelper class has been heavily expanded to allow for the above mentioned functionality.
When players create spells, potions and enchantments as part of regular gameplay, they send RecordDynamic packets that provide the server with the complete details of the records that should be created. When they create enchantments, they also provide the server with armor, book, clothing and weapon records corresponding to the items they've enchanted.
This functionality added by this packet was originally supposed to be exclusive to the rewrite, but I've gone ahead and tried to provide it for the pre-rewrite in a way that can mostly be reused for the rewrite.
2018-07-30 07:56:26 +00:00
|
|
|
*
|
|
|
|
* \param partType The type of the body part.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordBodyPartType(unsigned int partType) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the id of the male version of the temporary body part stored on the
|
|
|
|
* server.
|
|
|
|
*
|
|
|
|
* \param partId The id of the body part.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordBodyPartIdForMale(const char* partId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the id of the female version of the temporary body part stored on the
|
|
|
|
* server.
|
|
|
|
*
|
|
|
|
* \param partId The id of the body part.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordBodyPartIdForFemale(const char* partId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the id of the of the temporary inventory item stored on the server.
|
|
|
|
*
|
|
|
|
* \param partId The id of the inventory item.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordInventoryItemId(const char* itemId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the count of the of the temporary inventory item stored on the server.
|
|
|
|
*
|
|
|
|
* \param count The count of the inventory item.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetRecordInventoryItemCount(unsigned int count) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add a copy of the server's temporary record of the current specified
|
|
|
|
* type to the stored records.
|
|
|
|
*
|
|
|
|
* In the process, the server's temporary record will automatically be cleared
|
|
|
|
* so a new one can be set up.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddRecord() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add a copy of the server's temporary effect to the temporary record
|
|
|
|
* of the current specified type.
|
|
|
|
*
|
|
|
|
* In the process, the server's temporary effect will automatically be cleared
|
|
|
|
* so a new one can be set up.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddRecordEffect() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add a copy of the server's temporary body part to the temporary record
|
|
|
|
* of the current specified type.
|
|
|
|
*
|
|
|
|
* In the process, the server's temporary body part will automatically be cleared
|
|
|
|
* so a new one can be set up.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddRecordBodyPart() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Add a copy of the server's temporary inventory item to the temporary record
|
|
|
|
* of the current specified type.
|
|
|
|
*
|
|
|
|
* In the process, the server's temporary inventory item will automatically be cleared
|
|
|
|
* so a new one can be set up.
|
|
|
|
*
|
|
|
|
* Note: Any items added this way will be ignored if the record already has a valid
|
|
|
|
* inventoryBaseId.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddRecordInventoryItem() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Send a RecordDynamic packet with the current specified record type.
|
|
|
|
*
|
|
|
|
* \param pid The player ID attached to the packet.
|
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
|
|
|
* \param skipAttachedPlayer Whether the packet should skip being sent to the player attached
|
|
|
|
* to the packet (false by default).
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SendRecordDynamic(unsigned short pid, bool sendToOtherPlayers, bool skipAttachedPlayer) noexcept;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif //OPENMW_RECORDSDYNAMICAPI_HPP
|