summaryrefslogtreecommitdiff
path: root/new/alloc_windows.c
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2015-04-15 18:49:45 -0400
committerPietro Gagliardi <[email protected]>2015-04-15 18:49:45 -0400
commit518a5ddbf15d50a254c732a80d5907ef8878abe0 (patch)
tree48cf259f98994e4570e65c389fcd9824272884ad /new/alloc_windows.c
parent50ae3ca045e7f5f5744043df0a4506e2f6930bb1 (diff)
Split all OS backends into their own folders.
Diffstat (limited to 'new/alloc_windows.c')
-rw-r--r--new/alloc_windows.c49
1 files changed, 0 insertions, 49 deletions
diff --git a/new/alloc_windows.c b/new/alloc_windows.c
deleted file mode 100644
index 147c90d..0000000
--- a/new/alloc_windows.c
+++ /dev/null
@@ -1,49 +0,0 @@
-// 4 december 2014
-#include "uipriv_windows.h"
-
-// wrappers for allocator of choice
-// panics on memory exhausted, undefined on heap corruption or other unreliably-detected malady (see http://stackoverflow.com/questions/28761680/is-there-a-windows-api-memory-allocator-deallocator-i-can-use-that-will-just-giv)
-// new memory is set to zero
-// passing NULL to tableRealloc() acts like tableAlloc()
-// passing NULL to tableFree() is a no-op
-
-void *uiAlloc(size_t size, const char *type)
-{
- void *out;
-
- out = malloc(size);
- if (out == NULL) {
- fprintf(stderr, "memory exhausted in uiAlloc() allocating %s\n", type);
- abort();
- }
- ZeroMemory(out, size);
- if (options.debugLogAllocations)
- fprintf(stderr, "%p alloc %s\n", out, type);
- return out;
-}
-
-void *uiRealloc(void *p, size_t size, const char *type)
-{
- void *out;
-
- if (p == NULL)
- return uiAlloc(size, type);
- out = realloc(p, size);
- if (out == NULL) {
- fprintf(stderr, "memory exhausted in uiRealloc() reallocating %s\n", type);
- abort();
- }
- // TODO zero the extra memory
- if (options.debugLogAllocations)
- fprintf(stderr, "%p realloc %p\n", p, out);
- return out;
-}
-
-void uiFree(void *p)
-{
- if (p == NULL)
- return;
- free(p);
- if (options.debugLogAllocations)
- fprintf(stderr, "%p free\n", p);
-}