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/ContiguousContainer.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/ContiguousContainer.h')
-rw-r--r-- | mwe/ecs-memory-efficient/inc/ContiguousContainer.h | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/mwe/ecs-memory-efficient/inc/ContiguousContainer.h b/mwe/ecs-memory-efficient/inc/ContiguousContainer.h new file mode 100644 index 0000000..dd0321e --- /dev/null +++ b/mwe/ecs-memory-efficient/inc/ContiguousContainer.h @@ -0,0 +1,34 @@ +#pragma once + +#include <cstdlib> // For malloc and free +#include <new> // For placement new +#include <utility> // For std::move and std::forward +#include <stdexcept> // For std::bad_alloc +#include <vector> // For returning references + +template<typename T> +class ContiguousContainer { +public: + ContiguousContainer(); + ~ContiguousContainer(); + + // Use perfect forwarding for pushBack + template<typename... Args> + void pushBack(Args&&... args); + + void popBack(); + T& operator[](size_t index); + size_t getSize() const; + + // Function to return references to all stored objects + std::vector<std::reference_wrapper<T>> getAllReferences(); + +private: + T* mData; + size_t mSize; + size_t mCapacity; + + void resize(size_t new_capacity); // Resize function to allocate more space +}; + +#include "ContiguousContainer.hpp" |