/** @file IAllocator_Xfer.hpp * * @author Roland Conybeare, Dec 2025 **/ #pragma once #include "AAllocator.hpp" namespace xo { namespace mm { /** @class IAllocator_Xfer * * @tparam DRepr target representation * @tparam IAllocator_DRepr typed interface for @p DRepr * * Adapts typed allocator implementation @p IAllocator_DRepr * to type-erased @ref AAllocator interface **/ template struct IAllocator_Xfer : public AAllocator { /** @defgroup mm-allocator-xfer-types **/ ///@{ // parallel interface to AAllocator, with specific data type using Impl = IAllocator_DRepr; using size_type = AAllocator::size_type; using value_type = AAllocator::value_type; using typeseq = AAllocator::typeseq; ///@} /** @defgroup mm-allocator-xfer-methods IAllocator_Xfer methods **/ ///@{ static const DRepr & _dcast(Copaque d) { return *(const DRepr *)d; } static DRepr & _dcast(Opaque d) { return *(DRepr *)d; } // from AAllocator // builtin methods /** return typeseq for @tparam DRepr **/ typeseq _typeseq() const noexcept override { return s_typeseq; } /** invoke native c++ dtor **/ void _drop(Opaque d) const noexcept override { _dcast(d).~DRepr(); } // const methods std::string_view name(Copaque d) const noexcept override { return I::name(_dcast(d)); } size_type reserved(Copaque d) const noexcept override { return I::reserved(_dcast(d)); } size_type size(Copaque d) const noexcept override { return I::size(_dcast(d)); } size_type committed(Copaque d) const noexcept override { return I::committed(_dcast(d)); } size_type available(Copaque d) const noexcept override { return I::available(_dcast(d)); } size_type allocated(Copaque d) const noexcept override { return I::allocated(_dcast(d)); } bool contains(Copaque d, const void * p) const noexcept override { return I::contains(_dcast(d), p); } void visit_pools(Copaque d, const MemorySizeVisitor & fn) const override { I::visit_pools(_dcast(d), fn); } AllocError last_error(Copaque d) const noexcept override { return I::last_error(_dcast(d)); } AllocInfo alloc_info(Copaque d, value_type mem) const noexcept override { return I::alloc_info(_dcast(d), mem); } range_type alloc_range(Copaque d, DArena & mm) const noexcept override { return I::alloc_range(_dcast(d), mm); } // non-const methods bool expand(Opaque d, std::size_t z) const noexcept override { return I::expand(_dcast(d), z); } value_type alloc(Opaque d, typeseq t, std::size_t z) const override { return I::alloc(_dcast(d), t, z); } value_type super_alloc(Opaque d, typeseq t, std::size_t z) const override { return I::super_alloc(_dcast(d), t, z); } value_type sub_alloc(Opaque d, std::size_t z, bool complete_flag) const override { return I::sub_alloc(_dcast(d), z, complete_flag); } value_type alloc_copy(Opaque d, value_type src) const override { return I::alloc_copy(_dcast(d), src); } void clear(Opaque d) const override { return I::clear(_dcast(d)); } ///@} private: using I = Impl; public: static xo::facet::typeseq s_typeseq; static bool _valid; }; template xo::facet::typeseq IAllocator_Xfer::s_typeseq = facet::typeseq::id(); template bool IAllocator_Xfer::_valid = facet::valid_facet_implementation(); } /*namespace mm*/ } /*namespace xo*/ /* end IAllocator_Xfer.hpp */