/** @file RAllocator.hpp * * @author Roland Conybeare, Dec 2025 **/ #pragma once #include "Allocator_basic.hpp" // omits RAllocator_aux #include "AllocIterator.hpp" #include #include namespace xo { namespace mm { /** @class RAllocator **/ template struct RAllocator : public Object { private: using O = Object; public: using ObjectType = Object; using DataPtr = Object::DataPtr; using typeseq = xo::facet::typeseq; using size_type = std::size_t; using value_type = std::byte *; using range_type = AAllocator::range_type; RAllocator() {} RAllocator(Object::DataPtr data) : Object{std::move(data)} {} RAllocator(const AAllocator * iface, void * data) requires std::is_same_v : Object(iface, data) {} template void * alloc_for(size_type n = sizeof(T)) noexcept { return O::iface()->alloc(O::data(), typeseq::id(), n); } template void * alloc_copy_for(const T * src) noexcept { return O::iface()->alloc_copy(O::data(), (std::byte*)const_cast(src)); } template T * std_copy_for(T * src) noexcept { void * mem = this->alloc_copy_for(src); if (mem) { return new (mem) T(std::move(*src)); } return nullptr; } bool _has_null_vptr() const noexcept { return O::iface()->_has_null_vptr(); } typeseq _typeseq() const noexcept { return O::iface()->_typeseq(); } void _drop() const noexcept { O::iface()->_drop(O::data()); } std::string_view name() const noexcept { return O::iface()->name(O::data()); } size_type reserved() const noexcept { return O::iface()->reserved(O::data()); } size_type size() const noexcept { return O::iface()->size(O::data()); } size_type committed() const noexcept { return O::iface()->committed(O::data()); } size_type available() const noexcept { return O::iface()->available(O::data()); } size_type allocated() const noexcept { return O::iface()->allocated(O::data()); } void visit_pools(const MemorySizeVisitor & fn) const { O::iface()->visit_pools(O::data(), fn); } bool contains(const void * p) const noexcept { return O::iface()->contains(O::data(), p); } AllocError last_error() const noexcept { return O::iface()->last_error(O::data()); } AllocInfo alloc_info(value_type mem) const noexcept { return O::iface()->alloc_info(O::data(), mem); } range_type alloc_range(DArena & mm) const noexcept { return O::iface()->alloc_range(O::data(), mm); } bool expand(size_type z) { return O::iface()->expand(O::data(), z); } value_type alloc(typeseq t, size_type z) noexcept { return O::iface()->alloc(O::data(), t, z); } value_type super_alloc(typeseq t, size_type z) noexcept { return O::iface()->super_alloc(O::data(), t, z); } value_type sub_alloc(size_type z, bool complete_flag) noexcept { return O::iface()->sub_alloc(O::data(), z, complete_flag); } value_type alloc_copy(value_type src) noexcept { return O::iface()->alloc_copy(O::data(), src); } void clear() { O::iface()->clear(O::data()); } void barrier_assign_aux(void * parent, AGCObject * lhs_iface, void ** lhs_data, AGCObject * rhs_iface, void * rhs_data) noexcept { O::iface()->barrier_assign_aux(O::data(), parent, lhs_iface, lhs_data, rhs_iface, rhs_data); } // see [RAllocator_aux.hpp] for implementation. void barrier_assign(void * parent, obj * p_lhs, obj rhs) noexcept; // Need _drepr suffix to distinguish from .barrier_assign() // see [RAllocator_aux.hpp] for implementation template void barrier_assign_drepr(void * parent, DRepr ** lhs_data, DRepr * rhs_data); static bool _valid; }; template bool RAllocator::_valid = facet::valid_object_router(); } namespace facet { template struct RoutingFor { using RoutingType = xo::mm::RAllocator; }; } } /* end RAllocator.hpp */