From c1beec5bb03ded13320e186a165b630a72dcfff5 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Oct 2019 19:15:24 -0400 Subject: [PATCH 1/5] CCollisionResponseData: Organize cpp inclusions Organizes them alphabetically to make for better human reading. --- Runtime/Collision/CCollisionResponseData.cpp | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/Runtime/Collision/CCollisionResponseData.cpp b/Runtime/Collision/CCollisionResponseData.cpp index 2375805ad..89c065e9e 100644 --- a/Runtime/Collision/CCollisionResponseData.cpp +++ b/Runtime/Collision/CCollisionResponseData.cpp @@ -1,12 +1,13 @@ -#include "CCollisionResponseData.hpp" -#include "Particle/CParticleDataFactory.hpp" -#include "Particle/CDecalDescription.hpp" -#include "Particle/CSwooshDescription.hpp" -#include "Particle/CElectricDescription.hpp" -#include "Particle/CGenDescription.hpp" -#include "Graphics/CModel.hpp" -#include "CSimplePool.hpp" -#include "CRandom16.hpp" +#include "Runtime/Collision/CCollisionResponseData.hpp" + +#include "Runtime/CRandom16.hpp" +#include "Runtime/CSimplePool.hpp" +#include "Runtime/Graphics/CModel.hpp" +#include "Runtime/Particle/CDecalDescription.hpp" +#include "Runtime/Particle/CElectricDescription.hpp" +#include "Runtime/Particle/CGenDescription.hpp" +#include "Runtime/Particle/CParticleDataFactory.hpp" +#include "Runtime/Particle/CSwooshDescription.hpp" namespace urde { const EWeaponCollisionResponseTypes CCollisionResponseData::skWorldMaterialTable[32] = { From 3d6708869730167116d8c446ebbee6d972482bb6 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Oct 2019 19:17:53 -0400 Subject: [PATCH 2/5] CCollisionResponseData: Make use of std::array where applicable Allows us to replace some heap allocating file-scope std::vector instances with constexpr std::arrays, eliminating quite a few static constructors. --- Runtime/Collision/CCollisionResponseData.cpp | 84 +++++++++++++------- Runtime/Collision/CCollisionResponseData.hpp | 2 - 2 files changed, 54 insertions(+), 32 deletions(-) diff --git a/Runtime/Collision/CCollisionResponseData.cpp b/Runtime/Collision/CCollisionResponseData.cpp index 89c065e9e..771b29e47 100644 --- a/Runtime/Collision/CCollisionResponseData.cpp +++ b/Runtime/Collision/CCollisionResponseData.cpp @@ -1,5 +1,7 @@ #include "Runtime/Collision/CCollisionResponseData.hpp" +#include + #include "Runtime/CRandom16.hpp" #include "Runtime/CSimplePool.hpp" #include "Runtime/Graphics/CModel.hpp" @@ -10,7 +12,8 @@ #include "Runtime/Particle/CSwooshDescription.hpp" namespace urde { -const EWeaponCollisionResponseTypes CCollisionResponseData::skWorldMaterialTable[32] = { +namespace { +constexpr std::array skWorldMaterialTable{ EWeaponCollisionResponseTypes::Default, EWeaponCollisionResponseTypes::Unknown2, EWeaponCollisionResponseTypes::Metal, EWeaponCollisionResponseTypes::Grass, EWeaponCollisionResponseTypes::Ice, EWeaponCollisionResponseTypes::Goo, @@ -29,9 +32,9 @@ const EWeaponCollisionResponseTypes CCollisionResponseData::skWorldMaterialTable EWeaponCollisionResponseTypes::Default, EWeaponCollisionResponseTypes::Default, }; -const s32 CCollisionResponseData::kInvalidSFX = -1; +constexpr s32 kInvalidSFX = -1; -static const std::vector kWCRTSFXIDs = { +constexpr std::array kWCRTSFXIDs{{ SBIG('NSFX'), SBIG('DSFX'), SBIG('CSFX'), SBIG('MSFX'), SBIG('GRFX'), SBIG('ICFX'), SBIG('GOFX'), SBIG('WSFX'), SBIG('WTFX'), SBIG('2MUD'), SBIG('2LAV'), SBIG('2SAN'), SBIG('2PRJ'), SBIG('DCFX'), SBIG('DSFX'), SBIG('DSHX'), SBIG('DEFX'), SBIG('ESFX'), SBIG('SHFX'), SBIG('BEFX'), SBIG('WWFX'), SBIG('TAFX'), SBIG('GTFX'), SBIG('SPFX'), @@ -44,9 +47,9 @@ static const std::vector kWCRTSFXIDs = { SBIG('GHFX'), SBIG('SHFX'), SBIG('FHFX'), SBIG('HFFX'), SBIG('PHFX'), SBIG('MHFX'), SBIG('HBFX'), SBIG('PBHX'), SBIG('IBHX'), SBIG('6SVA'), SBIG('6RPR'), SBIG('6MTR'), SBIG('6PDS'), SBIG('6FLB'), SBIG('6DRN'), SBIG('6MRE'), SBIG('CHFX'), SBIG('JZHS'), SBIG('6ISE'), SBIG('6BSE'), SBIG('6ATB'), SBIG('6ATA'), -}; +}}; -static const std::vector kWCRTIDs = { +constexpr std::array kWCRTIDs{{ SBIG('NODP'), SBIG('DEFS'), SBIG('CRTS'), SBIG('MTLS'), SBIG('GRAS'), SBIG('ICEE'), SBIG('GOOO'), SBIG('WODS'), SBIG('WATR'), SBIG('1MUD'), SBIG('1LAV'), SBIG('1SAN'), SBIG('1PRJ'), SBIG('DCHR'), SBIG('DCHS'), SBIG('DCSH'), SBIG('DENM'), SBIG('DESP'), SBIG('DESH'), SBIG('BTLE'), SBIG('WASP'), SBIG('TALP'), SBIG('PTGM'), SBIG('SPIR'), @@ -58,33 +61,49 @@ static const std::vector kWCRTIDs = { SBIG('JZSP'), SBIG('3ISE'), SBIG('3BSE'), SBIG('3ATB'), SBIG('3ATA'), SBIG('BTSH'), SBIG('WWSH'), SBIG('TASH'), SBIG('TGSH'), SBIG('SPSH'), SBIG('FPSH'), SBIG('FFSH'), SBIG('PSSH'), SBIG('BMSH'), SBIG('BFSH'), SBIG('PBSH'), SBIG('IBSH'), SBIG('3SVA'), SBIG('3RPR'), SBIG('3MTR'), SBIG('3PDS'), SBIG('3FLB'), SBIG('3DRN'), SBIG('3MRE'), - SBIG('CHSH'), SBIG('JZSH'), SBIG('5ISE'), SBIG('5BSE'), SBIG('5ATB'), SBIG('5ATA')}; + SBIG('CHSH'), SBIG('JZSH'), SBIG('5ISE'), SBIG('5BSE'), SBIG('5ATB'), SBIG('5ATA'), +}}; -static const std::vector kWCRTDecalIDs = {SBIG('NCDL'), SBIG('DDCL'), SBIG('CODL'), SBIG('MEDL'), SBIG('GRDL'), - SBIG('ICDL'), SBIG('GODL'), SBIG('WODL'), SBIG('WTDL'), SBIG('3MUD'), - SBIG('3LAV'), SBIG('3SAN'), SBIG('CHDL'), SBIG('ENDL')}; +constexpr std::array kWCRTDecalIDs{{ + SBIG('NCDL'), + SBIG('DDCL'), + SBIG('CODL'), + SBIG('MEDL'), + SBIG('GRDL'), + SBIG('ICDL'), + SBIG('GODL'), + SBIG('WODL'), + SBIG('WTDL'), + SBIG('3MUD'), + SBIG('3LAV'), + SBIG('3SAN'), + SBIG('CHDL'), + SBIG('ENDL'), +}}; using CPF = CParticleDataFactory; +} // Anonymous namespace void CCollisionResponseData::AddParticleSystemToResponse(EWeaponCollisionResponseTypes type, CInputStream& in, CSimplePool* resPool) { - int i = int(type); - std::vector tracker; - tracker.resize(8); + const auto i = size_t(type); + const std::vector tracker(8); x0_generators[i].emplace(CPF::GetChildGeneratorDesc(in, resPool, tracker).m_token); } bool CCollisionResponseData::CheckAndAddDecalToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool) { - int i = 0; + size_t i = 0; for (const FourCC& type : kWCRTDecalIDs) { if (type == clsId) { - FourCC cls = CPF::GetClassID(in); - if (cls == SBIG('NONE')) + const FourCC cls = CPF::GetClassID(in); + if (cls == SBIG('NONE')) { return true; + } - CAssetId id = u64(in.readUint32Big()); - if (!id.IsValid()) + const CAssetId id{u64(in.readUint32Big())}; + if (!id.IsValid()) { return true; + } x20_decals[i].emplace(resPool->GetObj({FOURCC('DPSC'), id})); return true; @@ -95,12 +114,13 @@ bool CCollisionResponseData::CheckAndAddDecalToResponse(FourCC clsId, CInputStre } bool CCollisionResponseData::CheckAndAddSoundFXToResponse(FourCC clsId, CInputStream& in) { - int i = 0; + size_t i = 0; for (const FourCC& type : kWCRTSFXIDs) { if (type == clsId) { - FourCC cls = CPF::GetClassID(in); - if (cls == SBIG('NONE')) + const FourCC cls = CPF::GetClassID(in); + if (cls == SBIG('NONE')) { return true; + } x10_sfx[i] = CPF::GetInt(in); return true; @@ -112,7 +132,7 @@ bool CCollisionResponseData::CheckAndAddSoundFXToResponse(FourCC clsId, CInputSt } bool CCollisionResponseData::CheckAndAddParticleSystemToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool) { - int i = 0; + size_t i = 0; for (const FourCC& type : kWCRTIDs) { if (type == clsId) { AddParticleSystemToResponse(EWeaponCollisionResponseTypes(i), in, resPool); @@ -165,8 +185,9 @@ CCollisionResponseData::CCollisionResponseData(CInputStream& in, CSimplePool* re const std::optional>& CCollisionResponseData::GetParticleDescription(EWeaponCollisionResponseTypes type) const { - if (x0_generators[u32(type)]) - return x0_generators[u32(type)]; + if (x0_generators[size_t(type)]) { + return x0_generators[size_t(type)]; + } bool foundType = false; if (ResponseTypeIsEnemyNormal(type)) { @@ -180,22 +201,24 @@ CCollisionResponseData::GetParticleDescription(EWeaponCollisionResponseTypes typ foundType = true; } - if (foundType && !x0_generators[u32(type)]) + if (foundType && !x0_generators[size_t(type)]) { type = EWeaponCollisionResponseTypes::EnemyNormal; + } - if (!x0_generators[u32(type)] && type != EWeaponCollisionResponseTypes::None) + if (!x0_generators[size_t(type)] && type != EWeaponCollisionResponseTypes::None) { type = EWeaponCollisionResponseTypes::Default; + } - return x0_generators[u32(type)]; + return x0_generators[size_t(type)]; } const std::optional>& CCollisionResponseData::GetDecalDescription(EWeaponCollisionResponseTypes type) const { - return x20_decals[u32(type)]; + return x20_decals[size_t(type)]; } s32 CCollisionResponseData::GetSoundEffectId(EWeaponCollisionResponseTypes type) const { - if (x10_sfx[u32(type)] == kInvalidSFX) { + if (x10_sfx[size_t(type)] == kInvalidSFX) { if (ResponseTypeIsEnemyNormal(type)) type = EWeaponCollisionResponseTypes::EnemyNormal; else if (ResponseTypeIsEnemySpecial(type)) @@ -206,12 +229,13 @@ s32 CCollisionResponseData::GetSoundEffectId(EWeaponCollisionResponseTypes type) type = EWeaponCollisionResponseTypes::Default; } - return x10_sfx[u32(type)]; + return x10_sfx[size_t(type)]; } EWeaponCollisionResponseTypes CCollisionResponseData::GetWorldCollisionResponseType(s32 id) { - if (id < 0 || id >= 32) + if (id < 0 || size_t(id) >= skWorldMaterialTable.size()) { return EWeaponCollisionResponseTypes::Default; + } return skWorldMaterialTable[id]; } diff --git a/Runtime/Collision/CCollisionResponseData.hpp b/Runtime/Collision/CCollisionResponseData.hpp index c295065a3..84ee88a72 100644 --- a/Runtime/Collision/CCollisionResponseData.hpp +++ b/Runtime/Collision/CCollisionResponseData.hpp @@ -113,8 +113,6 @@ enum class EWeaponCollisionResponseTypes { }; class CCollisionResponseData { - static const EWeaponCollisionResponseTypes skWorldMaterialTable[32]; - static const s32 kInvalidSFX; std::vector>> x0_generators; std::vector x10_sfx; std::vector>> x20_decals; From 9c391f90e35e2fd54cf33293a457e26e74860c13 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Oct 2019 19:34:55 -0400 Subject: [PATCH 3/5] CCollisionResponseData: Join vector initializations into constructor initializer list Generally provides marginally better code generation. We can also fill x10_sfx with the invalid SFX constant at the same time instead of performing a resize and then filling it again. --- Runtime/Collision/CCollisionResponseData.cpp | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/Runtime/Collision/CCollisionResponseData.cpp b/Runtime/Collision/CCollisionResponseData.cpp index 771b29e47..d09b79150 100644 --- a/Runtime/Collision/CCollisionResponseData.cpp +++ b/Runtime/Collision/CCollisionResponseData.cpp @@ -155,13 +155,7 @@ bool CCollisionResponseData::CheckAndAddResourceToResponse(FourCC clsId, CInputS } CCollisionResponseData::CCollisionResponseData(CInputStream& in, CSimplePool* resPool) -: x30_RNGE(50.f), x34_FOFF(0.2f) { - x0_generators.resize(94); - x10_sfx.resize(94); - x20_decals.resize(94); - for (s32& id : x10_sfx) - id = kInvalidSFX; - +: x0_generators(94), x10_sfx(94, kInvalidSFX), x20_decals(94), x30_RNGE(50.f), x34_FOFF(0.2f) { FourCC clsId = CPF::GetClassID(in); if (clsId == UncookedResType()) { CRandom16 rand; From 156c0e8cd05c90abdc88385b76c47b7f63bf392b Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Oct 2019 19:39:47 -0400 Subject: [PATCH 4/5] CCollisionResponseData: Name parameters in function declarations Allows IDEs and other introspection tools to be more useful when indicating parameters in function calls. --- Runtime/Collision/CCollisionResponseData.hpp | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/Runtime/Collision/CCollisionResponseData.hpp b/Runtime/Collision/CCollisionResponseData.hpp index 84ee88a72..92fcd7eb1 100644 --- a/Runtime/Collision/CCollisionResponseData.hpp +++ b/Runtime/Collision/CCollisionResponseData.hpp @@ -127,20 +127,18 @@ class CCollisionResponseData { public: CCollisionResponseData(CInputStream& in, CSimplePool* resPool); - const std::optional>& - GetParticleDescription(EWeaponCollisionResponseTypes) const; - const std::optional>& - GetDecalDescription(EWeaponCollisionResponseTypes type) const; - s32 GetSoundEffectId(EWeaponCollisionResponseTypes) const; - static EWeaponCollisionResponseTypes GetWorldCollisionResponseType(s32); - static bool ResponseTypeIsEnemyShielded(EWeaponCollisionResponseTypes); - static bool ResponseTypeIsEnemyNormal(EWeaponCollisionResponseTypes); - static bool ResponseTypeIsEnemySpecial(EWeaponCollisionResponseTypes); + const std::optional>& GetParticleDescription(EWeaponCollisionResponseTypes type) const; + const std::optional>& GetDecalDescription(EWeaponCollisionResponseTypes type) const; + s32 GetSoundEffectId(EWeaponCollisionResponseTypes type) const; + static EWeaponCollisionResponseTypes GetWorldCollisionResponseType(s32 id); + static bool ResponseTypeIsEnemyShielded(EWeaponCollisionResponseTypes type); + static bool ResponseTypeIsEnemyNormal(EWeaponCollisionResponseTypes type); + static bool ResponseTypeIsEnemySpecial(EWeaponCollisionResponseTypes type); float GetAudibleRange() const { return x30_RNGE; } float GetAudibleFallOff() const { return x34_FOFF; } static FourCC UncookedResType(); }; CFactoryFnReturn FCollisionResponseDataFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms, - CObjectReference*); + CObjectReference* selfRef); } // namespace urde From fff7b90c851e173591d29ef945efe5352355ca62 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Oct 2019 19:43:21 -0400 Subject: [PATCH 5/5] CCollisionResponseData: In-class initialize primitives Avoids needing to give them their own entry within the constructor initializer list. --- Runtime/Collision/CCollisionResponseData.cpp | 2 +- Runtime/Collision/CCollisionResponseData.hpp | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Runtime/Collision/CCollisionResponseData.cpp b/Runtime/Collision/CCollisionResponseData.cpp index d09b79150..20b25204b 100644 --- a/Runtime/Collision/CCollisionResponseData.cpp +++ b/Runtime/Collision/CCollisionResponseData.cpp @@ -155,7 +155,7 @@ bool CCollisionResponseData::CheckAndAddResourceToResponse(FourCC clsId, CInputS } CCollisionResponseData::CCollisionResponseData(CInputStream& in, CSimplePool* resPool) -: x0_generators(94), x10_sfx(94, kInvalidSFX), x20_decals(94), x30_RNGE(50.f), x34_FOFF(0.2f) { +: x0_generators(94), x10_sfx(94, kInvalidSFX), x20_decals(94) { FourCC clsId = CPF::GetClassID(in); if (clsId == UncookedResType()) { CRandom16 rand; diff --git a/Runtime/Collision/CCollisionResponseData.hpp b/Runtime/Collision/CCollisionResponseData.hpp index 92fcd7eb1..36ce52ddc 100644 --- a/Runtime/Collision/CCollisionResponseData.hpp +++ b/Runtime/Collision/CCollisionResponseData.hpp @@ -116,8 +116,8 @@ class CCollisionResponseData { std::vector>> x0_generators; std::vector x10_sfx; std::vector>> x20_decals; - float x30_RNGE; - float x34_FOFF; + float x30_RNGE = 50.0f; + float x34_FOFF = 0.2f; void AddParticleSystemToResponse(EWeaponCollisionResponseTypes type, CInputStream& in, CSimplePool* resPool); bool CheckAndAddDecalToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool);