From 96dbb537ee14f992459a8359a113a78414addf9d Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sun, 25 Apr 2004 14:27:58 +0000 Subject: Initial checkin of a portable framework for writing small GUI puzzle games. [originally from svn r4138] --- malloc.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 malloc.c (limited to 'malloc.c') diff --git a/malloc.c b/malloc.c new file mode 100644 index 0000000..5e11ac0 --- /dev/null +++ b/malloc.c @@ -0,0 +1,52 @@ +/* + * malloc.c: safe wrappers around malloc, realloc, free, strdup + */ + +#include +#include "puzzles.h" + +/* + * smalloc should guarantee to return a useful pointer - Halibut + * can do nothing except die when it's out of memory anyway. + */ +void *smalloc(int size) { + void *p; + p = malloc(size); + if (!p) + fatal("out of memory"); + 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("out of memory"); + return q; +} + +/* + * dupstr is like strdup, but with the never-return-NULL property + * of smalloc (and also reliably defined in all environments :-) + */ +char *dupstr(char *s) { + char *r = smalloc(1+strlen(s)); + strcpy(r,s); + return r; +} -- cgit v1.1