diff options
author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-17 17:07:55 +0200 |
---|---|---|
committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-17 17:07:55 +0200 |
commit | e0fab8139a4dd8a33e54cb7fdea85d2bd3feaeb9 (patch) | |
tree | d7cc1a2583899d4557e54a2b33dee342f0405a2e /mwe/ecs-memory-efficient/inc/ComponentManager.h | |
parent | d21afe5b33b4cb3f5cf1917f4d15f402de41a032 (diff) | |
parent | d9889e4501c1f3ebd649b81816e80d1b40d14c87 (diff) |
Merge branch 'max/POC-ECS-memory-efficient' of github.com:lonkaars/crepe
Diffstat (limited to 'mwe/ecs-memory-efficient/inc/ComponentManager.h')
-rw-r--r-- | mwe/ecs-memory-efficient/inc/ComponentManager.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/mwe/ecs-memory-efficient/inc/ComponentManager.h b/mwe/ecs-memory-efficient/inc/ComponentManager.h new file mode 100644 index 0000000..066795a --- /dev/null +++ b/mwe/ecs-memory-efficient/inc/ComponentManager.h @@ -0,0 +1,36 @@ +#pragma once + +#include "Components.h" +#include "ContiguousContainer.h" + +class ComponentManager { +public: + static ComponentManager& GetInstance(); //Singleton + + ComponentManager(const ComponentManager&) = delete; //Singleton + ComponentManager(ComponentManager&&) = delete; //Singleton + ComponentManager& operator=(const ComponentManager&) = delete; //Singleton + ComponentManager& operator=(ComponentManager&&) = delete; //Singleton + + template<typename... Args> + void addSpriteComponent(Args&&... args); + template<typename... Args> + void addRigidbodyComponent(Args&&... args); + template<typename... Args> + void addColiderComponent(Args&&... args); + + std::vector<std::reference_wrapper<Sprite>> getAllSpriteReferences(); + std::vector<std::reference_wrapper<Rigidbody>> getAllRigidbodyReferences(); + std::vector<std::reference_wrapper<Colider>> getAllColiderReferences(); + +private: + static ComponentManager mInstance; //Singleton + + ComponentManager(); //Singleton + + ContiguousContainer<Sprite> mSpriteContainer; + ContiguousContainer<Rigidbody> mRigidbodyContainer; + ContiguousContainer<Colider> mColiderContainer; +}; + +#include "ComponentManager.hpp" |