xmemdup0: use stdnoreturn.h
[pspp] / lib / xmemdup0.h
1 /* xmemdup0.h -- copy a block of arbitrary bytes, plus a trailing NUL
2
3    Copyright (C) 2008-2011 Free Software Foundation, Inc.
4
5    This program is free software: you can redistribute it and/or modify
6    it under the terms of the GNU General Public License as published by
7    the Free Software Foundation; either version 3 of the License, or
8    (at your option) any later version.
9
10    This program is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13    GNU General Public License for more details.
14
15    You should have received a copy of the GNU General Public License
16    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
17
18 #ifndef XMEMDUP_H_
19 # define XMEMDUP_H_
20
21 # include <stddef.h>
22 # include <stdnoreturn.h>
23
24
25 # ifdef __cplusplus
26 extern "C" {
27 # endif
28
29 /* This function is always triggered when memory is exhausted.
30    It must be defined by the application, either explicitly
31    or by using gnulib's xalloc-die module.  This is the
32    function to call when one wants the program to die because of a
33    memory allocation failure.  */
34 extern noreturn void xalloc_die (void);
35
36 char *xmemdup0 (void const *p, size_t s);
37
38 # ifdef __cplusplus
39 }
40 # endif
41
42 #endif /* !XMEMDUP0_H_ */