Add module configurations
This commit is contained in:
parent
7a7a67cd40
commit
36d3c51eeb
|
|
@ -23,7 +23,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Audio();
|
||||
struct Config {};
|
||||
|
||||
Audio(Config /*config*/);
|
||||
~Audio();
|
||||
|
||||
AudioFormat GetAudioFormat(unsigned int channelCount);
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<>;
|
||||
|
||||
Core();
|
||||
struct Config {};
|
||||
|
||||
Core(Config /*config*/);
|
||||
~Core();
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -19,11 +19,16 @@ namespace Nz
|
|||
template<typename Module, typename... Modules>
|
||||
struct ModuleTuple : ModuleTuple<Module>, ModuleTuple<Modules...>
|
||||
{
|
||||
template<typename... ModuleConfig>
|
||||
ModuleTuple(ModuleConfig&&... configs);
|
||||
};
|
||||
|
||||
template<typename Module>
|
||||
struct ModuleTuple<Module>
|
||||
{
|
||||
template<typename... ModuleConfig>
|
||||
ModuleTuple(ModuleConfig&&... configs);
|
||||
|
||||
Module m;
|
||||
};
|
||||
}
|
||||
|
|
@ -32,7 +37,8 @@ namespace Nz
|
|||
class Modules
|
||||
{
|
||||
public:
|
||||
Modules() = default;
|
||||
template<typename... ModuleConfig>
|
||||
Modules(ModuleConfig&&... configs);
|
||||
~Modules() = default;
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -5,22 +5,65 @@
|
|||
#include <Nazara/Core/Modules.hpp>
|
||||
#include <Nazara/Core/Debug.hpp>
|
||||
|
||||
namespace Nz::Detail
|
||||
namespace Nz
|
||||
{
|
||||
template<>
|
||||
struct BuildDepList<TypeList<>>
|
||||
namespace Detail
|
||||
{
|
||||
using Result = TypeList<>;
|
||||
};
|
||||
template<typename T>
|
||||
struct Pick
|
||||
{
|
||||
template<typename First, typename... Args>
|
||||
static auto Get(First&& first, Args&&... args)
|
||||
{
|
||||
if constexpr (std::is_same_v<T, std::decay_t<First>>)
|
||||
return std::forward<First>(first);
|
||||
else
|
||||
return Get(std::forward<Args>(args)...);
|
||||
}
|
||||
|
||||
template<typename Module, typename... ModuleList>
|
||||
struct BuildDepList<TypeList<Module, ModuleList...>>
|
||||
static auto Get()
|
||||
{
|
||||
return T{};
|
||||
}
|
||||
};
|
||||
|
||||
template<typename Module, typename... Modules>
|
||||
template<typename... ModuleConfig>
|
||||
ModuleTuple<Module, Modules...>::ModuleTuple(ModuleConfig&&... configs) :
|
||||
ModuleTuple<Module>(std::forward<ModuleConfig>(configs)...),
|
||||
ModuleTuple<Modules...>(std::forward<ModuleConfig>(configs)...)
|
||||
{
|
||||
}
|
||||
|
||||
template<typename Module>
|
||||
template<typename... ModuleConfig>
|
||||
ModuleTuple<Module>::ModuleTuple(ModuleConfig&&... configs) :
|
||||
m(Pick<Module::Config>::Get(std::forward<ModuleConfig>(configs)...))
|
||||
{
|
||||
}
|
||||
|
||||
template<>
|
||||
struct BuildDepList<TypeList<>>
|
||||
{
|
||||
using Result = TypeList<>;
|
||||
};
|
||||
|
||||
template<typename Module, typename... ModuleList>
|
||||
struct BuildDepList<TypeList<Module, ModuleList...>>
|
||||
{
|
||||
using ModuleDependencies = typename BuildDepList<typename Module::Dependencies>::Result;
|
||||
using ModuleDependenciesIncModule = TypeListAppend<ModuleDependencies, Module>;
|
||||
using RestDependencies = typename BuildDepList<TypeList<ModuleList...>>::Result;
|
||||
using Result = TypeListConcat<ModuleDependenciesIncModule, RestDependencies>;
|
||||
};
|
||||
}
|
||||
|
||||
template<typename... ModuleList>
|
||||
template<typename... ModuleConfig>
|
||||
Modules<ModuleList...>::Modules(ModuleConfig&&... configs) :
|
||||
m_modules(std::forward<ModuleConfig>(configs)...)
|
||||
{
|
||||
using ModuleDependencies = typename BuildDepList<typename Module::Dependencies>::Result;
|
||||
using ModuleDependenciesIncModule = TypeListAppend<ModuleDependencies, Module>;
|
||||
using RestDependencies = typename BuildDepList<TypeList<ModuleList...>>::Result;
|
||||
using Result = TypeListConcat<ModuleDependenciesIncModule, RestDependencies>;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
#include <Nazara/Core/DebugOff.hpp>
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Network();
|
||||
struct Config {};
|
||||
|
||||
Network(Config /*config*/);
|
||||
~Network();
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Physics2D();
|
||||
struct Config {};
|
||||
|
||||
Physics2D(Config /*config*/);
|
||||
~Physics2D() = default;
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Physics3D();
|
||||
struct Config {};
|
||||
|
||||
Physics3D(Config /*config*/);
|
||||
~Physics3D();
|
||||
|
||||
unsigned int GetMemoryUsed();
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Utility>;
|
||||
|
||||
Platform();
|
||||
struct Config {};
|
||||
|
||||
Platform(Config /*config*/);
|
||||
~Platform();
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -26,7 +26,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Platform, Shader>;
|
||||
|
||||
Renderer();
|
||||
struct Config {};
|
||||
|
||||
Renderer(Config /*config*/);
|
||||
~Renderer();
|
||||
|
||||
inline RendererImpl* GetRendererImpl();
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Shader();
|
||||
struct Config {};
|
||||
|
||||
Shader(Config /*config*/);
|
||||
~Shader() = default;
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -20,7 +20,9 @@ namespace Nz
|
|||
public:
|
||||
using Dependencies = TypeList<Core>;
|
||||
|
||||
Utility();
|
||||
struct Config {};
|
||||
|
||||
Utility(Config /*config*/);
|
||||
~Utility();
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -37,7 +37,9 @@ namespace Ndk
|
|||
using Dependencies = Nz::TypeListConcat<CommonDependencies, ClientDependencies>;
|
||||
#endif
|
||||
|
||||
Sdk();
|
||||
struct Config {};
|
||||
|
||||
Sdk(Config /*config*/);
|
||||
~Sdk();
|
||||
|
||||
private:
|
||||
|
|
|
|||
|
|
@ -23,7 +23,7 @@ namespace Nz
|
|||
* \brief Audio class that represents the module initializer of Audio
|
||||
*/
|
||||
|
||||
Audio::Audio() :
|
||||
Audio::Audio(Config /*config*/) :
|
||||
ModuleBase("Audio", this)
|
||||
{
|
||||
// Initialisation of OpenAL
|
||||
|
|
|
|||
|
|
@ -19,7 +19,7 @@ namespace Nz
|
|||
* \brief Core class that represents the Core module
|
||||
*/
|
||||
|
||||
Core::Core() :
|
||||
Core::Core(Config /*config*/) :
|
||||
ModuleBase("Core", this, ModuleBase::NoLog{})
|
||||
{
|
||||
Log::Initialize();
|
||||
|
|
|
|||
|
|
@ -31,7 +31,7 @@ namespace Nz
|
|||
* \brief Network class that represents the module initializer of Network
|
||||
*/
|
||||
|
||||
Network::Network() :
|
||||
Network::Network(Config /*config*/) :
|
||||
ModuleBase("Network", this)
|
||||
{
|
||||
// Initialize module here
|
||||
|
|
|
|||
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Nz
|
||||
{
|
||||
Physics2D::Physics2D() :
|
||||
Physics2D::Physics2D(Config /*config*/) :
|
||||
ModuleBase("Physics2D", this)
|
||||
{
|
||||
}
|
||||
|
|
|
|||
|
|
@ -13,7 +13,7 @@
|
|||
|
||||
namespace Nz
|
||||
{
|
||||
Physics3D::Physics3D() :
|
||||
Physics3D::Physics3D(Config /*config*/) :
|
||||
ModuleBase("Physics3D", this)
|
||||
{
|
||||
if (!Collider3D::Initialize())
|
||||
|
|
|
|||
|
|
@ -17,7 +17,7 @@ namespace Nz
|
|||
* \brief Platform class that represents the module initializer of Platform
|
||||
*/
|
||||
|
||||
Platform::Platform() :
|
||||
Platform::Platform(Config /*config*/) :
|
||||
ModuleBase("Platform", this)
|
||||
{
|
||||
if (!Window::Initialize())
|
||||
|
|
|
|||
|
|
@ -30,7 +30,7 @@
|
|||
|
||||
namespace Nz
|
||||
{
|
||||
Renderer::Renderer() :
|
||||
Renderer::Renderer(Config /*config*/) :
|
||||
ModuleBase("Renderer", this)
|
||||
{
|
||||
struct RendererImplementations
|
||||
|
|
|
|||
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
namespace Nz
|
||||
{
|
||||
Shader::Shader() :
|
||||
Shader::Shader(Config /*config*/) :
|
||||
ModuleBase("Shader", this)
|
||||
{
|
||||
}
|
||||
|
|
|
|||
|
|
@ -36,7 +36,7 @@ namespace Nz
|
|||
* \brief Utility class that represents the module initializer of Utility
|
||||
*/
|
||||
|
||||
Utility::Utility() :
|
||||
Utility::Utility(Config /*config*/) :
|
||||
ModuleBase("Utility", this)
|
||||
{
|
||||
if (!Animation::Initialize())
|
||||
|
|
|
|||
|
|
@ -32,7 +32,7 @@ namespace Ndk
|
|||
* \brief NDK class that represents the software development kit, a set of tools made to ease the conception of application
|
||||
*/
|
||||
|
||||
Sdk::Sdk() :
|
||||
Sdk::Sdk(Config /*config*/) :
|
||||
ModuleBase("SDK", this)
|
||||
{
|
||||
Nz::ErrorFlags errFlags(Nz::ErrorFlag_ThrowException, true);
|
||||
|
|
|
|||
Loading…
Reference in New Issue