[has_globals]
module dlmalloc

__global global = new(get_system_allocator())

/// malloc allocates `size` bytes.
///
/// Returns a null pointer if allocation fails. Returns a valid pointer
/// otherwise.
[unsafe]
pub fn malloc(size usize) voidptr {
	unsafe {
		return global.malloc(size)
	}
}

// free deallocates a `ptr`.
[unsafe]
pub fn free(ptr voidptr) {
	unsafe {
		global.free_(ptr)
	}
}

// Same as `malloc`, except if the allocation succeeds it's guaranteed to
// point to `size` bytes of zeros.
[unsafe]
pub fn calloc(size usize) voidptr {
	unsafe {
		return global.calloc(size)
	}
}

// realloc reallocates `ptr`, a previous allocation with `old_size` and
// to have `new_size`.
//
//
// Returns a null pointer if the memory couldn't be reallocated, but `ptr`
// is still valid. Returns a valid pointer and frees `ptr` if the request
// is satisfied.
[unsafe]
pub fn realloc(ptr voidptr, oldsize usize, newsize usize) voidptr {
	unsafe {
		_ := oldsize

		return global.realloc(ptr, newsize)
	}
}

// memalign allocates `size` bytes with `align` align.
//
//
// Returns a null pointer if allocation fails. Returns a valid pointer otherwise.
[unsafe]
pub fn memalign(size usize, align usize) voidptr {
	unsafe {
		if align <= malloc_alignment() {
			return global.malloc(size)
		} else {
			return global.memalign(align, size)
		}
	}
}