From f91811f57de0561cc7c8efb5897a6b62f5c0e0b2 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sat, 30 Jan 1999 21:35:36 +0000 Subject: Initial checkin of skeleton application. About to start reading files [originally from svn r22] --- malloc.c | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 malloc.c (limited to 'malloc.c') diff --git a/malloc.c b/malloc.c new file mode 100644 index 0000000..cf0f2e0 --- /dev/null +++ b/malloc.c @@ -0,0 +1,39 @@ +/* + * malloc.c: safe wrappers around malloc, realloc, free, strdup + */ + +#include +#include "buttress.h" + +/* + * smalloc should guarantee to return a useful pointer - buttress + * can do nothing except die when it's out of memory anyway + */ +void *smalloc(int size) { + void *p = malloc(size); + if (!p) + fatal(err_nomemory); + return p; +} + +/* + * sfree should guaranteeably deal gracefully with freeing NULL + */ +void sfree(void *p) { + if (p) + free(p); +} + +/* + * srealloc should guaranteeably be able to realloc NULL + */ +void *srealloc(void *p, int size) { + void *q; + if (p) + q = realloc(p, size); + else + q = malloc(size); + if (!q) + fatal(err_nomemory); + return p; +} -- cgit v1.1