More factory stubs

This commit is contained in:
Phillip Stephens 2016-02-10 14:54:47 -08:00
parent 69f32a4706
commit ebcc986b13
14 changed files with 150 additions and 14 deletions

View File

@ -0,0 +1,12 @@
#include "CDecalDataFactory.hpp"
#include "CDecalDescription.hpp"
#include "CSimplePool.hpp"
namespace Retro
{
std::unique_ptr<IObj> FDealDataFactory(const SObjectTag &tag, CInputStream &in, const CVParamTransfer &vparms)
{
CSimplePool* sp = static_cast<CSimplePool*>(static_cast<TObjOwnerParam<IObjectStore*>*>(vparms.GetObj())->GetParam());
return TToken<CDecalDescription>::GetIObjObjectFor(std::unique_ptr<CDecalDescription>(CDecalDataFactory::GetGeneratorDesc(in, sp)));
}
}

View File

@ -1,4 +1,25 @@
#ifndef __RETRO_CDECALDATAFACTORY_HPP__ #ifndef __RETRO_CDECALDATAFACTORY_HPP__
#define __RETRO_CDECALDATAFACTORY_HPP__ #define __RETRO_CDECALDATAFACTORY_HPP__
#include "RetroTypes.hpp"
#include "IObj.hpp"
#include "CToken.hpp"
#include "IOStreams.hpp"
namespace Retro
{
class CDecalDescription;
class CSimplePool;
class CDecalDataFactory
{
public:
static CDecalDescription* GetGeneratorDesc(CInputStream& in,CSimplePool* resPool);
static CDecalDescription* CreateGeneratorDescription(CInputStream& in, CSimplePool* resPool);
static bool CreateDPSM(CDecalDescription* desc,CInputStream& in,CSimplePool* resPool);
};
std::unique_ptr<IObj> FDealDataFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms);
}
#endif // __RETRO_CDECALDATAFACTORY_HPP__ #endif // __RETRO_CDECALDATAFACTORY_HPP__

View File

@ -1,4 +1,11 @@
#ifndef __RETRO_CDECALDESCRIPTION_HPP__ #ifndef __RETRO_CDECALDESCRIPTION_HPP__
#define __RETRO_CDECALDESCRIPTION_HPP__ #define __RETRO_CDECALDESCRIPTION_HPP__
namespace Retro
{
class CDecalDescription
{
};
}
#endif // __RETRO_CDECALDESCRIPTION_HPP__ #endif // __RETRO_CDECALDESCRIPTION_HPP__

View File

@ -1,4 +1,11 @@
#ifndef __RETRO_CELECTRICDESCRIPTION_HPP__ #ifndef __RETRO_CELECTRICDESCRIPTION_HPP__
#define __RETRO_CELECTRICDESCRIPTION_HPP__ #define __RETRO_CELECTRICDESCRIPTION_HPP__
namespace Retro
{
namespace CElectricDescription
{
}
}
#endif // __RETRO_CELECTRICDESCRIPTION_HPP__ #endif // __RETRO_CELECTRICDESCRIPTION_HPP__

View File

@ -15,7 +15,9 @@ add_library(RuntimeCommonParticle
CWeaponDescription.hpp CWeaponDescription.cpp CWeaponDescription.hpp CWeaponDescription.cpp
CDecalDataFactory.hpp CDecalDataFactory.cpp CDecalDataFactory.hpp CDecalDataFactory.cpp
CElementGen.hpp CElementGen.cpp CElementGen.hpp CElementGen.cpp
CParticleSwooshDataFactory.hpp CParticleSwooshDataFactory.cpp
CParticleSwoosh.hpp CParticleSwoosh.cpp CParticleSwoosh.hpp CParticleSwoosh.cpp
CParticleElectricDataFactory.hpp CParticleElectricDataFactory.cpp
CParticleElectric.hpp CParticleElectric.cpp CParticleElectric.hpp CParticleElectric.cpp
CDecalManager.hpp CDecalManager.cpp CDecalManager.hpp CDecalManager.cpp
CSpawnSystemKeyframeData.hpp CSpawnSystemKeyframeData.cpp CSpawnSystemKeyframeData.hpp CSpawnSystemKeyframeData.cpp

View File

@ -48,6 +48,10 @@ struct SElectricGeneratorDesc
class CParticleDataFactory class CParticleDataFactory
{ {
friend class CDecalDataFactory;
friend class CParticleElectricDataFactory;
friend class CParticleSwooshDataFactory;
static SParticleModel GetModel(CInputStream& in, CSimplePool* resPool); static SParticleModel GetModel(CInputStream& in, CSimplePool* resPool);
static SChildGeneratorDesc GetChildGeneratorDesc(TResId res, CSimplePool* resPool, const std::vector<TResId>& tracker); static SChildGeneratorDesc GetChildGeneratorDesc(TResId res, CSimplePool* resPool, const std::vector<TResId>& tracker);
static SChildGeneratorDesc GetChildGeneratorDesc(CInputStream& in, CSimplePool* resPool, const std::vector<TResId>& tracker); static SChildGeneratorDesc GetChildGeneratorDesc(CInputStream& in, CSimplePool* resPool, const std::vector<TResId>& tracker);
@ -65,7 +69,6 @@ class CParticleDataFactory
static int32_t GetInt(CInputStream& in); static int32_t GetInt(CInputStream& in);
static bool GetBool(CInputStream& in); static bool GetBool(CInputStream& in);
static FourCC GetClassID(CInputStream& in); static FourCC GetClassID(CInputStream& in);
public: public:
static CGenDescription* GetGeneratorDesc(CInputStream& in, CSimplePool* resPool); static CGenDescription* GetGeneratorDesc(CInputStream& in, CSimplePool* resPool);
static CGenDescription* CreateGeneratorDescription(CInputStream& in, std::vector<TResId>& tracker, static CGenDescription* CreateGeneratorDescription(CInputStream& in, std::vector<TResId>& tracker,

View File

@ -1,7 +1,7 @@
#ifndef __RETRO_CPARTICLEELECTRIC_HPP__ #ifndef __RETRO_CPARTICLEELECTRIC_HPP__
#define __RETRO_CPARTICLEELECTRIC_HPP__ #define __RETRO_CPARTICLEELECTRIC_HPP__
#include "CParticleGen.hpp" #include "CElementGen.hpp"
namespace Retro namespace Retro
{ {

View File

@ -0,0 +1,24 @@
#include "CParticleElectricDataFactory.hpp"
#include "CElectricDescription.hpp"
#include "CSimplePool.hpp"
namespace Retro
{
CElectricDescription* CParticleElectricDataFactory::GetGeneratorDesc(CInputStream &in, CSimplePool *resPool)
{
return CreateElectricDescription(in, resPool);
}
CElectricDescription* CParticleElectricDataFactory::CreateElectricDescription(CInputStream &in, CSimplePool *resPool)
{
return nullptr;
}
std::unique_ptr<Retro::IObj> FParticleElecrticFactory(const Retro::SObjectTag &tag, Retro::CInputStream &in, const Retro::CVParamTransfer &vparms)
{
CSimplePool* sp = static_cast<CSimplePool*>(static_cast<TObjOwnerParam<IObjectStore*>*>(vparms.GetObj())->GetParam());
return TToken<CElectricDescription>::GetIObjObjectFor(std::unique_ptr<CElectricDescription>(CParticleElectricDataFactory::GetGeneratorDesc(in, sp)));
}
}

View File

@ -0,0 +1,26 @@
#ifndef __RETRO_CPARTICLEELECTRICDATAFACTORY_HPP__
#define __RETRO_CPARTICLEELECTRICDATAFACTORY_HPP__
#include "RetroTypes.hpp"
#include "IObj.hpp"
#include "CToken.hpp"
#include "IOStreams.hpp"
namespace Retro
{
class CElectricDescription;
class CSimplePool;
class CParticleElectricDataFactory
{
public:
static CElectricDescription* GetGeneratorDesc(CInputStream& in, CSimplePool* resPool);
static CElectricDescription* CreateElectricDescription(CInputStream& in, CSimplePool* resPool);
static bool CreateELSM(CElectricDescription* desc, CInputStream& in, CSimplePool* resPool) { return false; }
static bool LoadELSMTokens(CElectricDescription* desc);
};
std::unique_ptr<IObj> FParticleElectricDataFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms);
}
#endif // __RETRO_CPARTICLEELECTRICDATAFACTORY_HPP__

View File

@ -1,7 +1,7 @@
#ifndef __RETRO_CPARTICLESWOOSH_HPP__ #ifndef __RETRO_CPARTICLESWOOSH_HPP__
#define __RETRO_CPARTICLESWOOSH_HPP__ #define __RETRO_CPARTICLESWOOSH_HPP__
#include "CParticleGen.hpp" #include "CElementGen.hpp"
namespace Retro namespace Retro
{ {

View File

@ -0,0 +1,14 @@
#include "CParticleSwooshDataFactory.hpp"
#include "CSwooshDescription.hpp"
#include "CSimplePool.hpp"
namespace Retro
{
std::unique_ptr<Retro::IObj> FParticleSwooshDataFactory(const SObjectTag &tag, CInputStream &in, const CVParamTransfer &vparms)
{
CSimplePool* sp = static_cast<CSimplePool*>(static_cast<TObjOwnerParam<IObjectStore*>*>(vparms.GetObj())->GetParam());
return TToken<CSwooshDescription>::GetIObjObjectFor(std::unique_ptr<CSwooshDescription>(CParticleSwooshDataFactory::GetGeneratorDesc(in, sp)));
}
}

View File

@ -0,0 +1,24 @@
#ifndef __RETRO_CPARTICLESWOOSHDATAFACTORY_HPP__
#define __RETRO_CPARTICLESWOOSHDATAFACTORY_HPP__
#include "RetroTypes.hpp"
#include "IObj.hpp"
#include "CToken.hpp"
#include "IOStreams.hpp"
namespace Retro
{
class CSwooshDescription;
class CSimplePool;
class CParticleSwooshDataFactory
{
public:
static CSwooshDescription* GetGeneratorDesc(CInputStream& in, CSimplePool* resPool);
static CSwooshDescription* CreateGeneratorDescription(CInputStream& resPool, CSimplePool* resPool);
static bool CreateWPSM(CSwooshDescription* desc, CInputStream& in, CSimplePool* resPool);
};
std::unique_ptr<IObj> FParticleSwooshDataFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms);
}
#endif // __RETRO_CPARTICLESWOOSHDATAFACTORY_HPP__

View File

@ -1,4 +1,11 @@
#ifndef __RETRO_CSWOOSHDESCRIPTION_HPP__ #ifndef __RETRO_CSWOOSHDESCRIPTION_HPP__
#define __RETRO_CSWOOSHDESCRIPTION_HPP__ #define __RETRO_CSWOOSHDESCRIPTION_HPP__
namespace Retro
{
namespace CSwooshDescription
{
}
}
#endif // __RETRO_CSWOOSHDESCRIPTION_HPP__ #endif // __RETRO_CSWOOSHDESCRIPTION_HPP__

View File

@ -67,17 +67,6 @@ using TAreaId = u32;
} }
template <typename T>
T GetAverageValue(const T* v, int count)
{
u32 unk = count * sizeof(T);
}
template <typename T, int Count>
class TReservedAverage
{
};
namespace std namespace std
{ {
template<> template<>