11 #ifndef LIBPMEMOBJ_CPP_MAKE_PERSISTENT_ATOMIC_HPP
12 #define LIBPMEMOBJ_CPP_MAKE_PERSISTENT_ATOMIC_HPP
22 #include <libpmemobj/atomic_base.h>
48 template <
typename T,
typename... Args>
54 auto arg_pack = std::forward_as_tuple(std::forward<Args>(args)...);
55 auto ret = pmemobj_xalloc(
58 &detail::obj_constructor<T, decltype(arg_pack), Args...>,
59 static_cast<void *
>(&arg_pack));
62 throw std::bad_alloc();
80 template <
typename T,
typename... Args>
81 typename std::enable_if<!detail::is_first_arg_same<allocation_flag_atomic,
82 Args...>::value>::type
88 std::forward<Args>(args)...);
101 template <
typename T>
110 pmemobj_free(ptr.raw_ptr());
allocation_flag - defines flags which can be passed to make_persistent
Compile time type check for make_persistent.
PMEMoid * raw_ptr() noexcept
Get pointer to PMEMoid encapsulated by this object.
Definition: persistent_ptr_base.hpp:164
Persistent pointer class.
Definition: persistent_ptr.hpp:152
The non-template pool base class.
Definition: pool.hpp:50
PMEMobjpool * handle() noexcept
Gets the C style handle to the pool.
Definition: pool.hpp:394
PMEMobj pool class.
Definition: pool.hpp:482
Commonly used functionality.
Implementation details of atomic allocation and construction.
Atomic persistent_ptr allocation functions for arrays.
void delete_persistent_atomic(typename detail::pp_if_array< T >::type &ptr, std::size_t)
Atomically deallocate an array of objects.
Definition: make_persistent_array_atomic.hpp:106
void make_persistent_atomic(pool_base &pool, typename detail::pp_if_array< T >::type &ptr, std::size_t N, allocation_flag_atomic flag=allocation_flag_atomic::none())
Atomically allocate an array of objects.
Definition: make_persistent_array_atomic.hpp:46
Persistent memory namespace.
Definition: allocation_flag.hpp:15
Type of flag which can be passed to make_persistent_atomic.
Definition: allocation_flag.hpp:94
static allocation_flag_atomic none()
Do not change allocator behaviour.
Definition: allocation_flag.hpp:115
Helper functionality for handling variadic templates.