#pragma once #include #include #include #include class Component; enum class eReplicaComponentType : uint32_t; using LWOOBJID = int64_t; namespace dECS { // template // concept IsComponent = std::derived_from; struct WorldData; class World; class Entity; struct IStorage; template class Storage; using WorldPtr = std::shared_ptr; using WeakWorldPtr = std::weak_ptr; class World { public: World(); [[nodiscard]] Entity MakeEntity(); private: WorldPtr m_World; }; class Entity { public: friend Entity World::MakeEntity(); using StorageConstructor = std::function()>; [[nodiscard]] constexpr LWOOBJID Id() const noexcept { return m_Id; } [[maybe_unused]] void* AddComponent(eReplicaComponentType, StorageConstructor); template [[maybe_unused]] C* AddComponent() { return static_cast(AddComponent(C::ComponentType, std::make_unique>)); } [[nodiscard]] const void* GetComponent(eReplicaComponentType) const; [[nodiscard]] void* GetComponent(eReplicaComponentType); template [[nodiscard]] const C* GetComponent() const { return static_cast(GetComponent(C::ComponentType)); } template [[nodiscard]] C* GetComponent() { return static_cast(GetComponent(C::ComponentType)); } private: Entity(const LWOOBJID id, const WeakWorldPtr world) : m_Id{ id } , m_World { world } {} LWOOBJID m_Id; WeakWorldPtr m_World; }; struct IStorage { using RowMap = std::unordered_map; virtual ~IStorage() = default; [[nodiscard]] virtual void* at(size_t) = 0; [[nodiscard]] virtual const void* at(size_t) const = 0; [[nodiscard]] virtual void* emplace_back() = 0; RowMap rowMap; }; template class Storage : public IStorage { public: [[nodiscard]] void* at(const size_t index) override { return static_cast(&m_Vec.at(index)); } [[nodiscard]] const void* at(const size_t index) const override { return static_cast(&m_Vec.at(index)); } [[nodiscard]] void* emplace_back() override { return static_cast(&m_Vec.emplace_back()); } private: std::vector m_Vec; }; }