Bump to m4 1.4.19
[platform/upstream/m4.git] / lib / stddef.in.h
1 /* A substitute for POSIX 2008 <stddef.h>, for platforms that have issues.
2
3    Copyright (C) 2009-2021 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, or (at your option)
8    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 <https://www.gnu.org/licenses/>.  */
17
18 /* Written by Eric Blake.  */
19
20 /*
21  * POSIX 2008 <stddef.h> for platforms that have issues.
22  * <https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/stddef.h.html>
23  */
24
25 #if __GNUC__ >= 3
26 @PRAGMA_SYSTEM_HEADER@
27 #endif
28 @PRAGMA_COLUMNS@
29
30 #if defined __need_wchar_t || defined __need_size_t  \
31   || defined __need_ptrdiff_t || defined __need_NULL \
32   || defined __need_wint_t
33 /* Special invocation convention inside gcc header files.  In
34    particular, gcc provides a version of <stddef.h> that blindly
35    redefines NULL even when __need_wint_t was defined, even though
36    wint_t is not normally provided by <stddef.h>.  Hence, we must
37    remember if special invocation has ever been used to obtain wint_t,
38    in which case we need to clean up NULL yet again.  */
39
40 # if !(defined _@GUARD_PREFIX@_STDDEF_H && defined _GL_STDDEF_WINT_T)
41 #  ifdef __need_wint_t
42 #   define _GL_STDDEF_WINT_T
43 #  endif
44 #  @INCLUDE_NEXT@ @NEXT_STDDEF_H@
45    /* On TinyCC, make sure that the macros that indicate the special invocation
46       convention get undefined.  */
47 #  undef __need_wchar_t
48 #  undef __need_size_t
49 #  undef __need_ptrdiff_t
50 #  undef __need_NULL
51 #  undef __need_wint_t
52 # endif
53
54 #else
55 /* Normal invocation convention.  */
56
57 # ifndef _@GUARD_PREFIX@_STDDEF_H
58
59 /* On AIX 7.2, with xlc in 64-bit mode, <stddef.h> defines max_align_t to a
60    type with alignment 4, but 'long' has alignment 8.  */
61 #  if defined _AIX && defined __LP64__
62 #   if !GNULIB_defined_max_align_t
63 #    ifdef _MAX_ALIGN_T
64 /* /usr/include/stddef.h has already defined max_align_t.  Override it.  */
65 typedef long rpl_max_align_t;
66 #     define max_align_t rpl_max_align_t
67 #    else
68 /* Prevent /usr/include/stddef.h from defining max_align_t.  */
69 typedef long max_align_t;
70 #     define _MAX_ALIGN_T
71 #    endif
72 #    define GNULIB_defined_max_align_t 1
73 #   endif
74 #  endif
75
76 /* The include_next requires a split double-inclusion guard.  */
77
78 #  @INCLUDE_NEXT@ @NEXT_STDDEF_H@
79
80 /* On NetBSD 5.0, the definition of NULL lacks proper parentheses.  */
81 #  if (@REPLACE_NULL@ \
82        && (!defined _@GUARD_PREFIX@_STDDEF_H || defined _GL_STDDEF_WINT_T))
83 #   undef NULL
84 #   ifdef __cplusplus
85    /* ISO C++ says that the macro NULL must expand to an integer constant
86       expression, hence '((void *) 0)' is not allowed in C++.  */
87 #    if __GNUG__ >= 3
88     /* GNU C++ has a __null macro that behaves like an integer ('int' or
89        'long') but has the same size as a pointer.  Use that, to avoid
90        warnings.  */
91 #     define NULL __null
92 #    else
93 #     define NULL 0L
94 #    endif
95 #   else
96 #    define NULL ((void *) 0)
97 #   endif
98 #  endif
99
100 #  ifndef _@GUARD_PREFIX@_STDDEF_H
101 #   define _@GUARD_PREFIX@_STDDEF_H
102
103 /* Some platforms lack wchar_t.  */
104 #if !@HAVE_WCHAR_T@
105 # define wchar_t int
106 #endif
107
108 /* Some platforms lack max_align_t.  The check for _GCC_MAX_ALIGN_T is
109    a hack in case the configure-time test was done with g++ even though
110    we are currently compiling with gcc.
111    On MSVC, max_align_t is defined only in C++ mode, after <cstddef> was
112    included.  Its definition is good since it has an alignment of 8 (on x86
113    and x86_64).
114    Similarly on OS/2 kLIBC.  */
115 #if (defined _MSC_VER || (defined __KLIBC__ && !defined __LIBCN__)) \
116     && defined __cplusplus
117 # include <cstddef>
118 #else
119 # if ! (@HAVE_MAX_ALIGN_T@ || (defined _GCC_MAX_ALIGN_T && !defined __clang__))
120 #  if !GNULIB_defined_max_align_t
121 /* On the x86, the maximum storage alignment of double, long, etc. is 4,
122    but GCC's C11 ABI for x86 says that max_align_t has an alignment of 8,
123    and the C11 standard allows this.  Work around this problem by
124    using __alignof__ (which returns 8 for double) rather than _Alignof
125    (which returns 4), and align each union member accordingly.  */
126 #   if defined __GNUC__ || (__clang_major__ >= 4)
127 #    define _GL_STDDEF_ALIGNAS(type) \
128        __attribute__ ((__aligned__ (__alignof__ (type))))
129 #   else
130 #    define _GL_STDDEF_ALIGNAS(type) /* */
131 #   endif
132 typedef union
133 {
134   char *__p _GL_STDDEF_ALIGNAS (char *);
135   double __d _GL_STDDEF_ALIGNAS (double);
136   long double __ld _GL_STDDEF_ALIGNAS (long double);
137   long int __i _GL_STDDEF_ALIGNAS (long int);
138 } rpl_max_align_t;
139 #   define max_align_t rpl_max_align_t
140 #   define GNULIB_defined_max_align_t 1
141 #  endif
142 # endif
143 #endif
144
145 #  endif /* _@GUARD_PREFIX@_STDDEF_H */
146 # endif /* _@GUARD_PREFIX@_STDDEF_H */
147 #endif /* __need_XXX */