2007-10-07 11:44:02 +00:00
|
|
|
/* Replacements for malloc and strdup with error checking. Too trivial
|
|
|
|
to be worth copyrighting :-). I did that because a lot of code used
|
|
|
|
malloc and strdup without checking for NULL pointer, and I like some
|
|
|
|
message better than a core dump... --marekm
|
|
|
|
|
|
|
|
Yeh, but. Remember that bailing out might leave the system in some
|
|
|
|
bizarre state. You really want to put in error checking, then add
|
|
|
|
some back-out failure recovery code. -- jfh */
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2007-11-10 23:46:11 +00:00
|
|
|
#ident "$Id$"
|
2007-10-07 11:47:01 +00:00
|
|
|
|
2007-10-07 11:44:02 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include "defines.h"
|
2007-10-07 11:45:23 +00:00
|
|
|
char *xmalloc (size_t size)
|
2007-10-07 11:44:02 +00:00
|
|
|
{
|
|
|
|
char *ptr;
|
|
|
|
|
2007-10-07 11:47:22 +00:00
|
|
|
ptr = (char *) malloc (size);
|
2007-10-07 11:44:02 +00:00
|
|
|
if (!ptr && size) {
|
2007-10-07 11:45:23 +00:00
|
|
|
fprintf (stderr, _("malloc(%d) failed\n"), (int) size);
|
|
|
|
exit (13);
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
|
2007-10-07 11:45:23 +00:00
|
|
|
char *xstrdup (const char *str)
|
2007-10-07 11:44:02 +00:00
|
|
|
{
|
2007-10-07 11:45:23 +00:00
|
|
|
return strcpy (xmalloc (strlen (str) + 1), str);
|
2007-10-07 11:44:02 +00:00
|
|
|
}
|