Dawn/src/dawnshared/util/memory.hpp
2023-10-18 23:32:04 -05:00

100 lines
2.8 KiB
C++

/**
* Copyright (c) 2022 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#pragma once
#include "dawnsharedlibs.hpp"
#define DAWN_MEMORY_TRACKING 1
static void * memoryCallMalloc(const size_t size) {
return malloc(size);
}
static void * memoryCallCalloc(const size_t num, const size_t size) {
return calloc(num, size);
}
static void memoryCallFree(void *p) {
free(p);
}
static void * memoryCallRealloc(void *p, size_t newSize) {
return realloc(p, newSize);
}
/**
* Allocate some space in memory to use for your needs. Memory allocation may
* change how it functions later on to keep things nice and efficient. For now
* this is just an API forward for malloc.
*
* @param size Size of the array you wish to buffer.
* @return Pointer to the space in memory to use.
*/
void * memoryAllocate(const size_t size);
/**
* Allocate space in memory, where all values are set to 0 (in binary space).
*
* @param count Count of elements to allocate.
* @param size Size of each element to allocate.
* @return Pointer to the space in memory to use.
*/
void * memoryAllocateEmpty(const size_t count, const size_t size);
/**
* Free some previously allocated memory space.
* @param pointer Pointer in memory to free.
*/
void memoryFree(void *pointer);
/**
* Reallocate a part of memory. Reallocation simply creates a new buffer that
* will take all of the existing contents and then free's the original buffer.
*
* @param pointer Pointer to pointer in memory that you wish to re-allocate.
* @param newSize The new size of the buffer.
* @return Pointer to the new buffer.
*/
void * memoryReallocate(void *pointer, size_t newSize);
/**
* Copies data from one buffer to another. Typically used for array operations.
*
* @param source Source pointer.
* @param destination Destination buffer.
* @param size Size in bytes of data to copy.
*/
void memoryCopy(void *source, void *destination, size_t size);
/**
* Compares the data within two memory banks. Shorthand for memcpy.
*
* @param left Left item to compare.
* @param right Right item to compare.
* @param size Count of bytes to compare.
* @return 0 for equal, <0 for left being greater, >0 for right being greater.
*/
int32_t memoryCompare(const void *left, const void *right, const size_t size);
/**
* Fill destination with a repeating set of bytes.
*
* @param dest Destination pointer in memory.
* @param data Data byte to write.
* @param length How many times to write that byte.
*/
void memorySet(void *dest, uint8_t data, size_t length);
/**
* Initializes the memory management system.
*/
void memoryInit();
/**
* Disposes of the memory management system.
*/
void memoryDispose();