diff options
author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-10 07:04:27 +0200 |
---|---|---|
committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-10 07:04:27 +0200 |
commit | 29fb4bda4872bdfe33a2416a239fb62fc0238167 (patch) | |
tree | 367f8b32fc843b481b42dff54adfd0939afeb0b7 /src/crepe/ComponentManager.cpp | |
parent | 08d0b07c19edfe8c81dfe4e21c0d4c1ef128b628 (diff) | |
parent | dcfb674ccdf48a7fd78c98644e5b3b826c399206 (diff) |
merge `loek/scripts` into `master`
Diffstat (limited to 'src/crepe/ComponentManager.cpp')
-rw-r--r-- | src/crepe/ComponentManager.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/src/crepe/ComponentManager.cpp b/src/crepe/ComponentManager.cpp new file mode 100644 index 0000000..9a3fec7 --- /dev/null +++ b/src/crepe/ComponentManager.cpp @@ -0,0 +1,24 @@ +#include "ComponentManager.h" + +using namespace crepe; + +ComponentManager & ComponentManager::get_instance() { + static ComponentManager instance; + return instance; +} + +void ComponentManager::delete_all_components_of_id(uint32_t id) { + // Loop through all the types (in the unordered_map<>) + for (auto & [type, componentArray] : components) { + // Make sure that the id (that we are looking for) is within the boundaries of the vector<> + if (id < componentArray.size()) { + // Clear the components at this specific id + componentArray[id].clear(); + } + } +} + +void ComponentManager::delete_all_components() { + // Clear the whole unordered_map<> + components.clear(); +} |