DynaMix  1.3.7
A new take on polymorphism in C++
dynamix::internal::default_allocator Class Reference

#include <allocators.hpp>

Public Member Functions

virtual char * alloc_mixin_data (size_t count, const object *obj) override
 
virtual void dealloc_mixin_data (char *ptr, size_t count, const object *obj) override
 
virtual std::pair< char *, size_t > alloc_mixin (const basic_mixin_type_info &info, const object *obj) override
 
virtual void dealloc_mixin (char *ptr, size_t mixin_offset, const basic_mixin_type_info &info, const object *obj) override
 
virtual void construct_mixin (const basic_mixin_type_info &info, void *ptr)
 
virtual bool copy_construct_mixin (const basic_mixin_type_info &info, void *ptr, const void *source)
 
virtual void destroy_mixin (const basic_mixin_type_info &info, void *ptr) noexcept
 
bool has_allocated () const
 

Static Public Member Functions

static size_t mem_size_for_mixin (size_t mixin_size, size_t mixin_alignment)
 
static size_t mixin_offset (const char *buffer, size_t mixin_alignment)
 

Static Public Attributes

static constexpr size_t mixin_data_size = sizeof(internal::mixin_data_in_object)
 

Protected Attributes

std::atomic< bool > _has_allocated
 

Detailed Description

The default allocator.

Used internally by the library, where no custom allocators are provided.

Member Function Documentation

virtual char* dynamix::internal::default_allocator::alloc_mixin_data ( size_t  count,
const object obj 
)
overridevirtual

Pure virtual. Should return a valid pointer to an array with the size of count mixin_data_in_object instances.

Use the static constant mixin_data_size to get the size of a single mixin_data_in_object

Example:
char* my_allocator::alloc_mixin_data(size_t count, const object*)
{
return new char[count * mixin_data_size];
}

Implements dynamix::domain_allocator.

virtual void dynamix::internal::default_allocator::dealloc_mixin_data ( char *  ptr,
size_t  count,
const object obj 
)
overridevirtual

Pure virtual. Should free the memory that has been obtained via a call to alloc_mixin_data. The number of elements to dealocate will correspond to the number of elements used to allocated the buffer

Implements dynamix::domain_allocator.

virtual std::pair<char*, size_t> dynamix::internal::default_allocator::alloc_mixin ( const basic_mixin_type_info info,
const object obj 
)
overridevirtual

Pure virtual. Returns a buffer of memory and the offset of the mixin within it (according to the alignment) BUT IN SUCH A WAY AS TO ALLOW A POINTER TO BE PLACED IN FRONT

You may use mem_size_for_mixin and mixin_offset if you're not sure what to do.

Example:
std::pair<char*, size_t> your_allocator::alloc_mixin(const basic_mixin_type_info& info, const object*)
{
size_t mem_size = mem_size_for_mixin(info.size, info.alignment);
auto buffer = new char[mem_size];
return make_pair(buffer, mixin_offset(buffer, info.alignment));
}

Implements dynamix::mixin_allocator.

virtual void dynamix::internal::default_allocator::dealloc_mixin ( char *  ptr,
size_t  mixin_offset,
const basic_mixin_type_info info,
const object obj 
)
overridevirtual

Pure virtual. Should free the memory that has been obtained via a call to alloc_mixin. The library will call the method with the same mixin type info which was used to allocate it previously and also with the offset which was returned by the allocation.

Implements dynamix::mixin_allocator.

size_t dynamix::mixin_allocator::mem_size_for_mixin ( size_t  mixin_size,
size_t  mixin_alignment 
)
inlinestaticinherited

Calculates appropriate size for a mixin buffer so as to satisfy the requirements of mixin size and alignment AND leave a room for its owning object in front.

You may use it in your overrides of alloc_mixin to determine the appropriate memory size.

size_t dynamix::mixin_allocator::mixin_offset ( const char *  buffer,
size_t  mixin_alignment 
)
inlinestaticinherited

Calculates the appropriate offset of the mixin in the buffer so as to satisfy the requirements of its alignment AND leave a room for its owning object in front.

You may use it in your overrides of alloc_mixin to determine the correct mixin_offset.

virtual void dynamix::mixin_allocator::construct_mixin ( const basic_mixin_type_info info,
void *  ptr 
)
virtualinherited

Virtual function, which constructs a mixin within a memory buffer. The default implementation calls the default constructor.

virtual bool dynamix::mixin_allocator::copy_construct_mixin ( const basic_mixin_type_info info,
void *  ptr,
const void *  source 
)
virtualinherited

Virtual function, which copy-constructs a mixin within a memory buffer, from a given source. Should return false if the copy-construction failed. The default implementation calls the default copy constructor and returns false if none exists.

virtual void dynamix::mixin_allocator::destroy_mixin ( const basic_mixin_type_info info,
void *  ptr 
)
virtualnoexceptinherited

Virtual function, which destroys a mixin from a given buffer. The default implementation calls the destructor.

Member Data Documentation

constexpr size_t dynamix::domain_allocator::mixin_data_size = sizeof(internal::mixin_data_in_object)
staticinherited

Size of mixin_data_in_object

Use this to determine how many bytes you'll allocate for single mixin data in alloc_mixin_data


The documentation for this class was generated from the following file: