replaced old panic module by newer error handling module
[libfirm] / ir / adt / xmalloc.c
1 /*
2  * Project:     libFIRM
3  * File name:   ir/adt/xmalloc.c
4  * Purpose:     Xmalloc --- never failing wrappers for malloc() & friends.
5  * Author:      Markus Armbruster
6  * Modified by:
7  * Created:     1999 by getting from fiasco
8  * CVS-ID:      $Id$
9  * Copyright:   (c) 1995, 1996 Markus Armbruster
10  * Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
11  */
12
13 /* @@@ ToDo: replace this file with the one from liberty.
14    [reimplement xstrdup, ... ] */
15
16 #ifdef HAVE_CONFIG_H
17 # include "config.h"
18 #endif
19
20 #ifdef HAVE_ALLOCA_H
21 # include <alloca.h>
22 #endif
23 #ifdef HAVE_MALLOC_H
24 # include <malloc.h>
25 #endif
26 #ifdef HAVE_STRING_H
27 # include <string.h>
28 #endif
29 #ifdef HAVE_STDLIB_H
30 # include <stdlib.h>
31 #endif
32
33 #include "xmalloc.h"
34 #include "error.h"
35
36 static NORETURN xnomem(void) {
37   panic("out of memory");
38 }
39
40 void *xmalloc(size_t size) {
41   void *res = malloc(size);
42
43   if (!res) xnomem();
44   return res;
45 }
46
47 void *xcalloc(size_t num, size_t size) {
48   void *res = calloc(num, size);
49
50   if (!res) xnomem();
51   return res;
52 }
53
54 void *xrealloc(void *ptr, size_t size) {
55   /* ANSI blesses realloc (0, x) but SunOS chokes on it */
56   void *res = ptr ? realloc (ptr, size) : malloc (size);
57
58   if (!res) xnomem();
59   return res;
60 }
61
62 char *xstrdup(const char *str) {
63   size_t len = strlen (str) + 1;
64   return memcpy((xmalloc) (len), str, len);
65 }