From a8be6aa8dd980bcce64b55d042e4558b5a91798f Mon Sep 17 00:00:00 2001 From: mashumafi Date: Sun, 29 Jan 2023 23:29:31 -0500 Subject: [PATCH] Move allocator to after memdelete --- include/godot_cpp/core/memory.hpp | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/include/godot_cpp/core/memory.hpp b/include/godot_cpp/core/memory.hpp index d17e05ef..25f87ec5 100644 --- a/include/godot_cpp/core/memory.hpp +++ b/include/godot_cpp/core/memory.hpp @@ -92,20 +92,6 @@ struct Comparator { _ALWAYS_INLINE_ bool operator()(const T &p_a, const T &p_b) const { return (p_a < p_b); } }; -class DefaultAllocator { -public: - _ALWAYS_INLINE_ static void *alloc(size_t p_memory) { return Memory::alloc_static(p_memory); } - _ALWAYS_INLINE_ static void free(void *p_ptr) { Memory::free_static(p_ptr); } -}; - -template -class DefaultTypedAllocator { -public: - template - _ALWAYS_INLINE_ T *new_allocation(const Args &&...p_args) { return memnew(T(p_args...)); } - _ALWAYS_INLINE_ void delete_allocation(T *p_allocation) { memdelete(p_allocation); } -}; - template void memdelete(T *p_class, typename std::enable_if>::type * = nullptr) { if (!std::is_trivially_destructible::value) { @@ -129,6 +115,20 @@ void memdelete_allocator(T *p_class) { A::free(p_class); } +class DefaultAllocator { +public: + _ALWAYS_INLINE_ static void *alloc(size_t p_memory) { return Memory::alloc_static(p_memory); } + _ALWAYS_INLINE_ static void free(void *p_ptr) { Memory::free_static(p_ptr); } +}; + +template +class DefaultTypedAllocator { +public: + template + _ALWAYS_INLINE_ T *new_allocation(const Args &&...p_args) { return memnew(T(p_args...)); } + _ALWAYS_INLINE_ void delete_allocation(T *p_allocation) { memdelete(p_allocation); } +}; + #define memnew_arr(m_class, m_count) memnew_arr_template(m_count) template