From 15095f8763f3fd281810086f373c4f39d564729f Mon Sep 17 00:00:00 2001 From: Sebastian Holtermann Date: Mon, 7 Oct 2024 19:09:58 +0200 Subject: [PATCH] Let mem_rmalloc call mem_malloc instead of std::malloc `mem_rmalloc` should use `mem_malloc` instead of `std::malloc` to match the `mem_free` deallocation call. --- mem/mem.h | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/mem/mem.h b/mem/mem.h index e1f54276..53b7d232 100644 --- a/mem/mem.h +++ b/mem/mem.h @@ -76,17 +76,6 @@ #include #include -template static inline T *mem_rmalloc() -{ - static_assert(std::is_trivially_constructible_v && std::is_trivially_destructible_v); - return static_cast(std::malloc(sizeof(T))); -} -template static inline T *mem_rmalloc(std::size_t nelem) -{ - static_assert(std::is_trivially_constructible_v && std::is_trivially_destructible_v); - return static_cast(std::malloc(nelem * sizeof(T))); -} - // Memory management debugging #ifdef MEM_USE_RTL #define mem_malloc(d) malloc(d) // Use this if your going to run BoundsChecker @@ -106,10 +95,10 @@ template static inline T *mem_rmalloc(std::size_t nelem) extern bool Mem_low_memory_mode; extern bool Mem_superlow_memory_mode; // DAJ -// use if you want to manually print out a memory error +// use if you want to manually print out a memory error #define mem_error() mem_error_msg(__FILE__, __LINE__) -// initializes memory library. +// initializes memory library. void mem_Init(); // shutsdown memory @@ -124,7 +113,7 @@ void *mem_malloc_sub(int size, const char *file, int line); // Frees a previously allocated block of memory void mem_free_sub(void *memblock); -// prints out a memory error message +// prints out a memory error message void mem_error_msg(const char *file, int line, int size = -1); char *mem_strdup_sub(const char *src, const char *file, int line); @@ -137,4 +126,16 @@ bool mem_dumpmallocstofile(char *filename); void mem_heapcheck(); +// type aware memory allocation +template static inline T *mem_rmalloc() +{ + static_assert(std::is_trivially_constructible_v && std::is_trivially_destructible_v); + return static_cast(mem_malloc(sizeof(T))); +} +template static inline T *mem_rmalloc(std::size_t nelem) +{ + static_assert(std::is_trivially_constructible_v && std::is_trivially_destructible_v); + return static_cast(mem_malloc(nelem * sizeof(T))); +} + #endif