From ed6d284a28327eea434f65a9de669c6acda95bfb Mon Sep 17 00:00:00 2001 From: DavidJCobb <831497+DavidJCobb@users.noreply.github.com> Date: Wed, 16 Oct 2024 22:16:08 +0200 Subject: [PATCH 1/2] Update TESObjectWEAP.h --- include/RE/T/TESObjectWEAP.h | 140 +++++++++++++++++------------------ 1 file changed, 67 insertions(+), 73 deletions(-) diff --git a/include/RE/T/TESObjectWEAP.h b/include/RE/T/TESObjectWEAP.h index 60db63baf..71284bec7 100644 --- a/include/RE/T/TESObjectWEAP.h +++ b/include/RE/T/TESObjectWEAP.h @@ -39,25 +39,19 @@ namespace RE kPeriodicSawtooth = 3 }; - struct WeaponTypes + enum class WEAPON_TYPE { - enum WEAPON_TYPE : std::uint32_t - { - kHandToHandMelee = 0, - kOneHandSword = 1, - kOneHandDagger = 2, - kOneHandAxe = 3, - kOneHandMace = 4, - kTwoHandSword = 5, - kTwoHandAxe = 6, - kBow = 7, - kStaff = 8, - kCrossbow = 9, - - kTotal = 10 - }; + kHandToHandMelee = 0, + kOneHandSword = 1, + kOneHandDagger = 2, + kOneHandAxe = 3, + kOneHandMace = 4, + kTwoHandSword = 5, + kTwoHandAxe = 6, + kBow = 7, + kStaff = 8, + kCrossbow = 9 }; - using WEAPON_TYPE = WeaponTypes::WEAPON_TYPE; class TESObjectWEAP : public TESBoundObject, // 000 @@ -79,7 +73,6 @@ namespace RE { public: inline static constexpr auto RTTI = RTTI_TESObjectWEAP; - inline static constexpr auto VTABLE = VTABLE_TESObjectWEAP; inline static constexpr auto FORMTYPE = FormType::Weapon; struct RecordFlags @@ -87,6 +80,7 @@ namespace RE enum RecordFlag : std::uint32_t { kNonPlayable = 1 << 2, + kHasInheritedFromTemplate = 1 << 3, // cleared on load; set by relevant processing in InitItemImpl kDeleted = 1 << 5, kIgnored = 1 << 12 }; @@ -96,15 +90,15 @@ namespace RE { public: // members - float sightFOV; // 00 - float unk04; // 04 - float firingRumbleLeftMotorStrength; // 08 - float firingRumbleRightMotorStrength; // 0C - float firingRumbleDuration; // 10 - REX::EnumSet rumblePattern; // 14 - std::int8_t numProjectiles; // 18 - std::uint8_t pad19; // 19 - std::uint16_t pad1A; // 1A + float sightFOV; // 00 + float fireRate; // 04 - Fallout leftover? + float firingRumbleLeftMotorStrength; // 08 + float firingRumbleRightMotorStrength; // 0C + float firingRumbleDuration; // 10 + float attackShotsPerSec; // 14 - Fallout leftover? + std::int8_t numProjectiles; // 18 + std::uint8_t pad19; // 19 + std::uint16_t pad1A; // 1A }; static_assert(sizeof(RangedData) == 0x1C); @@ -120,6 +114,7 @@ namespace RE kMinorCrime = 1 << 4, kRangeFixed = 1 << 5, kNotUsedInNormalCombat = 1 << 6, + kOverridesConditionDamage = 1 << 7, kDontUse3rdPersonISAnim = 1 << 8, // unused kBurstShot = 1 << 9, kRumbleAlternate = 1 << 10, @@ -164,24 +159,24 @@ namespace RE }; // members - RangedData* rangedData; // 00 - float speed; // 08 - float reach; // 0C - float minRange; // 10 - float maxRange; // 14 - float animationAttackMult; // 18 - float unk1C; // 1C - float staggerValue; // 20 - REX::EnumSet hitBehavior; // 24 - REX::EnumSet skill; // 28 - REX::EnumSet resistance; // 2C - REX::EnumSet flags2; // 30 - std::uint8_t baseVATSToHitChance; // 32 - REX::EnumSet attackAnimation; // 33 - REX::EnumSet embeddedWeaponAV; // 34 - unused - REX::EnumSet animationType; // 35 - REX::EnumSet flags; // 36 - std::uint8_t unk37; // 37 + RangedData* rangedData; // 00 + float speed; // 08 + float reach; // 0C + float minRange; // 10 + float maxRange; // 14 + float animationAttackMult; // 18 + float damageToWeaponMult; // 1C - used in (unused?) condition calculations if Flag2::kOverridesConditionDamage is set + float staggerValue; // 20 + stl::enumeration hitBehavior; // 24 + stl::enumeration skill; // 28 + stl::enumeration resistance; // 2C + stl::enumeration flags2; // 30 + std::uint8_t baseVATSToHitChance; // 32 + stl::enumeration attackAnimation; // 33 + stl::enumeration embeddedWeaponAV; // 34 - unused + stl::enumeration animationType; // 35 + stl::enumeration flags; // 36 + std::uint8_t unk37; // 37 }; static_assert(sizeof(Data) == 0x38); @@ -195,24 +190,24 @@ namespace RE }; // members - float prcntMult; // 00 - std::uint32_t pad04; // 04 - SpellItem* effect; // 08 - std::uint16_t damage; // 10 - REX::EnumSet flags; // 12 - std::uint8_t pad13; // 13 - std::uint32_t pad14; // 14 + float prcntMult; // 00 + std::uint32_t pad04; // 04 + SpellItem* effect; // 08 + std::uint16_t damage; // 10 + stl::enumeration flags; // 12 + std::uint8_t pad13; // 13 + std::uint32_t pad14; // 14 }; static_assert(sizeof(CriticalData) == 0x18); - struct Unk1B8 + struct ScopeArt { public: // members - TESModel unk00; // 00 - TESEffectShader* unk28; // 28 + TESModel unk00; // 00 - MOD3 and friends + TESEffectShader* unk28; // 28 - EIDT }; - static_assert(sizeof(Unk1B8) == 0x30); + static_assert(sizeof(ScopeArt) == 0x30); ~TESObjectWEAP() override; // 00 @@ -236,7 +231,6 @@ namespace RE [[nodiscard]] float GetMinRange() const; [[nodiscard]] float GetMaxRange() const; [[nodiscard]] std::uint16_t GetCritDamage() const; - NiAVObject* GetFireNode(NiAVObject* a_root) const; void GetNodeName(char* a_dstBuff) const; [[nodiscard]] WEAPON_TYPE GetWeaponType() const; [[nodiscard]] bool IsBound() const; @@ -254,22 +248,22 @@ namespace RE [[nodiscard]] bool IsCrossbow() const; // members - Data weaponData; // 168 - DNAM - CriticalData criticalData; // 1A0 - CRDT - Unk1B8* unk1B8; // 1B8 - BGSSoundDescriptorForm* attackSound; // 1C0 - SNAM - BGSSoundDescriptorForm* attackSound2D; // 1C8 - XNAM - BGSSoundDescriptorForm* attackLoopSound; // 1D0 - NAM7 - BGSSoundDescriptorForm* attackFailSound; // 1D8 - TNAM - BGSSoundDescriptorForm* idleSound; // 1E0 - UNAM - BGSSoundDescriptorForm* equipSound; // 1E8 - NAM9 - BGSSoundDescriptorForm* unequipSound; // 1F0 - NAM8 - BGSImpactDataSet* impactDataSet; // 1F8 - TESObjectSTAT* firstPersonModelObject; // 200 - WNAM - TESObjectWEAP* templateWeapon; // 208 - CNAM - BSFixedString embeddedNode; // 210 - REX::EnumSet soundLevel; // 218 - VNAM - std::uint32_t pad21C; // 21C + Data weaponData; // 168 - DNAM + CriticalData criticalData; // 1A0 - CRDT + ScopeArt* scopeArt; // 1B8 + BGSSoundDescriptorForm* attackSound; // 1C0 - SNAM + BGSSoundDescriptorForm* attackSound2D; // 1C8 - XNAM + BGSSoundDescriptorForm* attackLoopSound; // 1D0 - NAM7 + BGSSoundDescriptorForm* attackFailSound; // 1D8 - TNAM + BGSSoundDescriptorForm* idleSound; // 1E0 - UNAM + BGSSoundDescriptorForm* equipSound; // 1E8 - NAM9 + BGSSoundDescriptorForm* unequipSound; // 1F0 - NAM8 + BGSImpactDataSet* impactDataSet; // 1F8 + TESObjectSTAT* firstPersonModelObject; // 200 - WNAM + TESObjectWEAP* templateWeapon; // 208 - CNAM + BSFixedString embeddedNode; // 210 + stl::enumeration soundLevel; // 218 - VNAM + std::uint32_t pad21C; // 21C }; static_assert(sizeof(TESObjectWEAP) == 0x220); } From 80cfc8a6a69ce8742ee4c8a10000b628947baab8 Mon Sep 17 00:00:00 2001 From: DavidJCobb <831497+DavidJCobb@users.noreply.github.com> Date: Wed, 16 Oct 2024 22:38:46 +0200 Subject: [PATCH 2/2] Update TESObjectWEAP.h fixed GitHub Desktop shenanigans, hopefully --- include/RE/T/TESObjectWEAP.h | 112 +++++++++++++++++++---------------- 1 file changed, 60 insertions(+), 52 deletions(-) diff --git a/include/RE/T/TESObjectWEAP.h b/include/RE/T/TESObjectWEAP.h index 71284bec7..ec3079622 100644 --- a/include/RE/T/TESObjectWEAP.h +++ b/include/RE/T/TESObjectWEAP.h @@ -39,19 +39,25 @@ namespace RE kPeriodicSawtooth = 3 }; - enum class WEAPON_TYPE + struct WeaponTypes { - kHandToHandMelee = 0, - kOneHandSword = 1, - kOneHandDagger = 2, - kOneHandAxe = 3, - kOneHandMace = 4, - kTwoHandSword = 5, - kTwoHandAxe = 6, - kBow = 7, - kStaff = 8, - kCrossbow = 9 + enum WEAPON_TYPE : std::uint32_t + { + kHandToHandMelee = 0, + kOneHandSword = 1, + kOneHandDagger = 2, + kOneHandAxe = 3, + kOneHandMace = 4, + kTwoHandSword = 5, + kTwoHandAxe = 6, + kBow = 7, + kStaff = 8, + kCrossbow = 9, + + kTotal = 10 + }; }; + using WEAPON_TYPE = WeaponTypes::WEAPON_TYPE; class TESObjectWEAP : public TESBoundObject, // 000 @@ -73,6 +79,7 @@ namespace RE { public: inline static constexpr auto RTTI = RTTI_TESObjectWEAP; + inline static constexpr auto VTABLE = VTABLE_TESObjectWEAP; inline static constexpr auto FORMTYPE = FormType::Weapon; struct RecordFlags @@ -159,24 +166,24 @@ namespace RE }; // members - RangedData* rangedData; // 00 - float speed; // 08 - float reach; // 0C - float minRange; // 10 - float maxRange; // 14 - float animationAttackMult; // 18 - float damageToWeaponMult; // 1C - used in (unused?) condition calculations if Flag2::kOverridesConditionDamage is set - float staggerValue; // 20 - stl::enumeration hitBehavior; // 24 - stl::enumeration skill; // 28 - stl::enumeration resistance; // 2C - stl::enumeration flags2; // 30 - std::uint8_t baseVATSToHitChance; // 32 - stl::enumeration attackAnimation; // 33 - stl::enumeration embeddedWeaponAV; // 34 - unused - stl::enumeration animationType; // 35 - stl::enumeration flags; // 36 - std::uint8_t unk37; // 37 + RangedData* rangedData; // 00 + float speed; // 08 + float reach; // 0C + float minRange; // 10 + float maxRange; // 14 + float animationAttackMult; // 18 + float damageToWeaponMult; // 1C - used in (unused?) condition calculations if Flag2::kOverridesConditionDamage is set + float staggerValue; // 20 + REX::EnumSet hitBehavior; // 24 + REX::EnumSet skill; // 28 + REX::EnumSet resistance; // 2C + REX::EnumSet flags2; // 30 + std::uint8_t baseVATSToHitChance; // 32 + REX::EnumSet attackAnimation; // 33 + REX::EnumSet embeddedWeaponAV; // 34 - unused + REX::EnumSet animationType; // 35 + REX::EnumSet flags; // 36 + std::uint8_t unk37; // 37 }; static_assert(sizeof(Data) == 0x38); @@ -190,13 +197,13 @@ namespace RE }; // members - float prcntMult; // 00 - std::uint32_t pad04; // 04 - SpellItem* effect; // 08 - std::uint16_t damage; // 10 - stl::enumeration flags; // 12 - std::uint8_t pad13; // 13 - std::uint32_t pad14; // 14 + float prcntMult; // 00 + std::uint32_t pad04; // 04 + SpellItem* effect; // 08 + std::uint16_t damage; // 10 + REX::EnumSet flags; // 12 + std::uint8_t pad13; // 13 + std::uint32_t pad14; // 14 }; static_assert(sizeof(CriticalData) == 0x18); @@ -231,6 +238,7 @@ namespace RE [[nodiscard]] float GetMinRange() const; [[nodiscard]] float GetMaxRange() const; [[nodiscard]] std::uint16_t GetCritDamage() const; + NiAVObject* GetFireNode(NiAVObject* a_root) const; void GetNodeName(char* a_dstBuff) const; [[nodiscard]] WEAPON_TYPE GetWeaponType() const; [[nodiscard]] bool IsBound() const; @@ -248,22 +256,22 @@ namespace RE [[nodiscard]] bool IsCrossbow() const; // members - Data weaponData; // 168 - DNAM - CriticalData criticalData; // 1A0 - CRDT - ScopeArt* scopeArt; // 1B8 - BGSSoundDescriptorForm* attackSound; // 1C0 - SNAM - BGSSoundDescriptorForm* attackSound2D; // 1C8 - XNAM - BGSSoundDescriptorForm* attackLoopSound; // 1D0 - NAM7 - BGSSoundDescriptorForm* attackFailSound; // 1D8 - TNAM - BGSSoundDescriptorForm* idleSound; // 1E0 - UNAM - BGSSoundDescriptorForm* equipSound; // 1E8 - NAM9 - BGSSoundDescriptorForm* unequipSound; // 1F0 - NAM8 - BGSImpactDataSet* impactDataSet; // 1F8 - TESObjectSTAT* firstPersonModelObject; // 200 - WNAM - TESObjectWEAP* templateWeapon; // 208 - CNAM - BSFixedString embeddedNode; // 210 - stl::enumeration soundLevel; // 218 - VNAM - std::uint32_t pad21C; // 21C + Data weaponData; // 168 - DNAM + CriticalData criticalData; // 1A0 - CRDT + ScopeArt* scopeArt; // 1B8 + BGSSoundDescriptorForm* attackSound; // 1C0 - SNAM + BGSSoundDescriptorForm* attackSound2D; // 1C8 - XNAM + BGSSoundDescriptorForm* attackLoopSound; // 1D0 - NAM7 + BGSSoundDescriptorForm* attackFailSound; // 1D8 - TNAM + BGSSoundDescriptorForm* idleSound; // 1E0 - UNAM + BGSSoundDescriptorForm* equipSound; // 1E8 - NAM9 + BGSSoundDescriptorForm* unequipSound; // 1F0 - NAM8 + BGSImpactDataSet* impactDataSet; // 1F8 + TESObjectSTAT* firstPersonModelObject; // 200 - WNAM + TESObjectWEAP* templateWeapon; // 208 - CNAM + BSFixedString embeddedNode; // 210 + REX::EnumSet soundLevel; // 218 - VNAM + std::uint32_t pad21C; // 21C }; static_assert(sizeof(TESObjectWEAP) == 0x220); }