Implement CRSC Factory

This commit is contained in:
Phillip Stephens 2016-02-17 01:08:38 -08:00
parent f70577dc2b
commit cfee7b61bb
2 changed files with 42 additions and 2 deletions

View File

@ -74,8 +74,39 @@ static const std::vector<FourCC> DecalTypes =
using CPF = CParticleDataFactory; using CPF = CParticleDataFactory;
void CCollisionResponseData::AddParticleSystemToResponse(EWeaponCollisionResponseTypes type, CInputStream &in, CSimplePool *resPool)
{
int i = int(type);
std::vector<TResId> tracker;
tracker.resize(8);
x0[i].first = std::move(CPF::GetChildGeneratorDesc(in, resPool, tracker).m_token);
if (x0[i].first)
x0[i].second = true;
}
bool CCollisionResponseData::CheckAndAddDecalToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool) bool CCollisionResponseData::CheckAndAddDecalToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool)
{ {
int i = 0;
for (const FourCC& type : DecalTypes)
{
if (type == clsId)
{
FourCC cls = CPF::GetClassID(in);
if (cls == SBIG('NONE'))
return true;
TResId id = CPF::GetInt(in);
if (!id)
return true;
x20[i].first = std::move(resPool->GetObj({FOURCC('DPSC'), id}));
if (x0[i].first)
x0[i].second = true;
return true;
}
i++;
}
return false; return false;
} }
@ -101,6 +132,15 @@ bool CCollisionResponseData::CheckAndAddSoundFXToResponse(FourCC clsId, CInputSt
bool CCollisionResponseData::CheckAndAddParticleSystemToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool) bool CCollisionResponseData::CheckAndAddParticleSystemToResponse(FourCC clsId, CInputStream& in, CSimplePool* resPool)
{ {
int i = 0;
for (const FourCC& type : GeneratorTypes)
{
if (type == clsId)
{
AddParticleSystemToResponse(EWeaponCollisionResponseTypes(i), in, resPool);
return true;
}
}
return false; return false;
} }

View File

@ -38,9 +38,9 @@ enum class EWeaponCollisionResponseTypes
class CCollisionResponseData class CCollisionResponseData
{ {
std::vector<TLockedToken<CGenDescription>> x0; std::vector<std::pair<TLockedToken<CGenDescription>, bool>> x0;
std::vector<s32> x10; std::vector<s32> x10;
std::vector<TLockedToken<CDecalDescription>> x20; std::vector<std::pair<TLockedToken<CDecalDescription>, bool>> x20;
float x30_RNGE; float x30_RNGE;
float x34_FOFF; float x34_FOFF;