28 std::is_trivially_destructible_v<T>;
42 std::destroy_n(
ptr, n);
47 std::uninitialized_default_construct_n(
ptr, n);
52 std::copy_n(src, n, dst);
57 std::uninitialized_copy_n(src, n, dst);
60template<
typename From,
typename To>
63 std::uninitialized_copy_n(src, n, dst);
68 std::copy_n(std::make_move_iterator(src), n, dst);
73 std::uninitialized_copy_n(std::make_move_iterator(src), n, dst);
90 std::fill_n(dst, n, value);
95 std::uninitialized_fill_n(dst, n, value);
113template<
typename T>
using destruct_ptr = std::unique_ptr<T, DestructValueAtAddress<T>>;
121 struct alignas(Alignment) Sized {
123 std::byte buffer_[Size > 0 ? Size : 1];
126 using BufferType = std::conditional_t<Size == 0, Empty, Sized>;
135 operator const void *()
const
159 static constexpr size_t get_size()
161 if constexpr (Size == 0) {
165 return sizeof(
T) *
size_t(Size);
170 static constexpr size_t get_alignment()
172 if constexpr (Size == 0) {
185 return static_cast<T *
>(buffer_.ptr());
188 operator const T *()
const
190 return static_cast<const T *
>(buffer_.ptr());
195 return *
static_cast<T *
>(buffer_.ptr());
200 return *
static_cast<const T *
>(buffer_.ptr());
205 return static_cast<T *
>(buffer_.ptr());
210 return static_cast<const T *
>(buffer_.ptr());
215 return *
static_cast<T *
>(buffer_.ptr());
220 return *
static_cast<const T *
>(buffer_.ptr());
230template<
size_t ReservedSize = 64,
size_t ReservedAlignment = 64>
234 char reserved_buffer_[(ReservedSize > 0) ? ReservedSize : 1];
242 if (size <= ReservedSize && alignment <= ReservedAlignment) {
243 buffer_ = reserved_buffer_;
251 if (buffer_ != reserved_buffer_) {
287template<
typename From,
typename To>
289 std::is_pointer_v<From> && std::is_pointer_v<To>;
297template<
typename From,
typename To>
300 std::is_pointer_v<From> && std::is_pointer_v<To> &&
302 std::is_same_v<From, To> ||
304 std::is_same_v<const std::remove_pointer_t<From>, std::remove_pointer_t<To>> ||
306 (!std::is_const_v<std::remove_pointer_t<From>> && std::is_same_v<To, void *>) ||
308 std::is_same_v<To, const void *>);
313template<
typename T,
typename... Args>
322 return (
int64_t(element_size) < 100) ? 4 : 0;
336 Container container_copy{src};
337 dst = std::move(container_copy);
346template<
typename Container>
348 std::is_nothrow_move_constructible_v<Container>)
355 if constexpr (std::is_nothrow_move_constructible_v<Container>) {
356 new (&dst) Container(std::move(src));
360 new (&dst) Container(std::move(src));
375 if (old_value != new_value) {
376 old_value = std::move(new_value);
397#define BLI_SCOPED_DEFER_NAME1(a, b) a##b
398#define BLI_SCOPED_DEFER_NAME2(a, b) BLI_SCOPED_DEFER_NAME1(a, b)
399#define BLI_SCOPED_DEFER_NAME(a) BLI_SCOPED_DEFER_NAME2(_scoped_defer_##a##_, __LINE__)
407#define BLI_SCOPED_DEFER(function_to_defer) \
408 auto BLI_SCOPED_DEFER_NAME(func) = (function_to_defer); \
409 blender::detail::ScopedDeferHelper<decltype(BLI_SCOPED_DEFER_NAME(func))> \
410 BLI_SCOPED_DEFER_NAME(helper){std::move(BLI_SCOPED_DEFER_NAME(func))};
#define BLI_NO_UNIQUE_ADDRESS
Read Guarded memory(de)allocation.
DynamicStackBuffer & operator=(const DynamicStackBuffer &other)=delete
DynamicStackBuffer & operator=(DynamicStackBuffer &&other)=delete
DynamicStackBuffer(const DynamicStackBuffer &other)=delete
DynamicStackBuffer(const int64_t size, const int64_t alignment)
DynamicStackBuffer(DynamicStackBuffer &&other)=delete
const T & operator*() const
void * MEM_mallocN_aligned(size_t len, size_t alignment, const char *str)
void MEM_freeN(void *vmemh)
constexpr bool is_same_any_v
void default_construct_n(T *ptr, int64_t n)
void initialized_relocate_n(T *src, int64_t n, T *dst)
std::unique_ptr< T, DestructValueAtAddress< T > > destruct_ptr
bool assign_if_different(T &old_value, T new_value)
void initialized_fill_n(T *dst, int64_t n, const T &value)
void initialized_move_n(T *src, int64_t n, T *dst)
Container & copy_assign_container(Container &dst, const Container &src)
constexpr bool is_convertible_pointer_v
constexpr bool is_trivially_move_constructible_extended_v
Container & move_assign_container(Container &dst, Container &&src) noexcept(std::is_nothrow_move_constructible_v< Container >)
constexpr int64_t default_inline_buffer_capacity(size_t element_size)
constexpr bool is_trivially_destructible_extended_v
void uninitialized_fill_n(T *dst, int64_t n, const T &value)
void uninitialized_relocate_n(T *src, int64_t n, T *dst)
void initialized_copy_n(const T *src, int64_t n, T *dst)
void uninitialized_convert_n(const From *src, int64_t n, To *dst)
constexpr bool is_trivially_copy_constructible_extended_v
void destruct_n(T *ptr, int64_t n)
constexpr bool is_span_convertible_pointer_v
void uninitialized_copy_n(const T *src, int64_t n, T *dst)
constexpr bool is_trivial_extended_v
void uninitialized_move_n(T *src, int64_t n, T *dst)
DestructValueAtAddress()=default
DestructValueAtAddress(const U &)