100 lines
2.8 KiB
C++
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(); |