Merge commit 'stable/20110609'
[gnulib.git] / 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
23
24 # ifdef __cplusplus
25 extern "C" {
26 # endif
27
28 # if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 8)
29 #  define _GL_ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
30 # else
31 #  define _GL_ATTRIBUTE_NORETURN /* empty */
32 # endif
33
34 /* This function is always triggered when memory is exhausted.
35    It must be defined by the application, either explicitly
36    or by using gnulib's xalloc-die module.  This is the
37    function to call when one wants the program to die because of a
38    memory allocation failure.  */
39 extern void xalloc_die (void) _GL_ATTRIBUTE_NORETURN;
40
41 char *xmemdup0 (void const *p, size_t s);
42
43 # ifdef __cplusplus
44 }
45 # endif
46
47 #endif /* !XMEMDUP0_H_ */