1 | # gnulib-common.m4 serial 74
|
---|
2 | dnl Copyright (C) 2007-2022 Free Software Foundation, Inc.
|
---|
3 | dnl This file is free software; the Free Software Foundation
|
---|
4 | dnl gives unlimited permission to copy and/or distribute it,
|
---|
5 | dnl with or without modifications, as long as this notice is preserved.
|
---|
6 |
|
---|
7 | AC_PREREQ([2.62])
|
---|
8 |
|
---|
9 | # gl_COMMON
|
---|
10 | # is expanded unconditionally through gnulib-tool magic.
|
---|
11 | AC_DEFUN([gl_COMMON], [
|
---|
12 | dnl Use AC_REQUIRE here, so that the code is expanded once only.
|
---|
13 | AC_REQUIRE([gl_00GNULIB])
|
---|
14 | AC_REQUIRE([gl_COMMON_BODY])
|
---|
15 | AC_REQUIRE([gl_ZZGNULIB])
|
---|
16 | ])
|
---|
17 | AC_DEFUN([gl_COMMON_BODY], [
|
---|
18 | AH_VERBATIM([_GL_GNUC_PREREQ],
|
---|
19 | [/* True if the compiler says it groks GNU C version MAJOR.MINOR. */
|
---|
20 | #if defined __GNUC__ && defined __GNUC_MINOR__
|
---|
21 | # define _GL_GNUC_PREREQ(major, minor) \
|
---|
22 | ((major) < __GNUC__ + ((minor) <= __GNUC_MINOR__))
|
---|
23 | #else
|
---|
24 | # define _GL_GNUC_PREREQ(major, minor) 0
|
---|
25 | #endif
|
---|
26 | ])
|
---|
27 | AH_VERBATIM([_Noreturn],
|
---|
28 | [/* The _Noreturn keyword of C11. */
|
---|
29 | #ifndef _Noreturn
|
---|
30 | # if (defined __cplusplus \
|
---|
31 | && ((201103 <= __cplusplus && !(__GNUC__ == 4 && __GNUC_MINOR__ == 7)) \
|
---|
32 | || (defined _MSC_VER && 1900 <= _MSC_VER)) \
|
---|
33 | && 0)
|
---|
34 | /* [[noreturn]] is not practically usable, because with it the syntax
|
---|
35 | extern _Noreturn void func (...);
|
---|
36 | would not be valid; such a declaration would only be valid with 'extern'
|
---|
37 | and '_Noreturn' swapped, or without the 'extern' keyword. However, some
|
---|
38 | AIX system header files and several gnulib header files use precisely
|
---|
39 | this syntax with 'extern'. */
|
---|
40 | # define _Noreturn [[noreturn]]
|
---|
41 | # elif ((!defined __cplusplus || defined __clang__) \
|
---|
42 | && (201112 <= (defined __STDC_VERSION__ ? __STDC_VERSION__ : 0) \
|
---|
43 | || (!defined __STRICT_ANSI__ \
|
---|
44 | && (_GL_GNUC_PREREQ (4, 7) \
|
---|
45 | || (defined __apple_build_version__ \
|
---|
46 | ? 6000000 <= __apple_build_version__ \
|
---|
47 | : 3 < __clang_major__ + (5 <= __clang_minor__))))))
|
---|
48 | /* _Noreturn works as-is. */
|
---|
49 | # elif _GL_GNUC_PREREQ (2, 8) || defined __clang__ || 0x5110 <= __SUNPRO_C
|
---|
50 | # define _Noreturn __attribute__ ((__noreturn__))
|
---|
51 | # elif 1200 <= (defined _MSC_VER ? _MSC_VER : 0)
|
---|
52 | # define _Noreturn __declspec (noreturn)
|
---|
53 | # else
|
---|
54 | # define _Noreturn
|
---|
55 | # endif
|
---|
56 | #endif
|
---|
57 | ])
|
---|
58 | AH_VERBATIM([isoc99_inline],
|
---|
59 | [/* Work around a bug in Apple GCC 4.0.1 build 5465: In C99 mode, it supports
|
---|
60 | the ISO C 99 semantics of 'extern inline' (unlike the GNU C semantics of
|
---|
61 | earlier versions), but does not display it by setting __GNUC_STDC_INLINE__.
|
---|
62 | __APPLE__ && __MACH__ test for Mac OS X.
|
---|
63 | __APPLE_CC__ tests for the Apple compiler and its version.
|
---|
64 | __STDC_VERSION__ tests for the C99 mode. */
|
---|
65 | #if defined __APPLE__ && defined __MACH__ && __APPLE_CC__ >= 5465 && !defined __cplusplus && __STDC_VERSION__ >= 199901L && !defined __GNUC_STDC_INLINE__
|
---|
66 | # define __GNUC_STDC_INLINE__ 1
|
---|
67 | #endif])
|
---|
68 | AH_VERBATIM([attribute],
|
---|
69 | [/* Attributes. */
|
---|
70 | #if (defined __has_attribute \
|
---|
71 | && (!defined __clang_minor__ \
|
---|
72 | || (defined __apple_build_version__ \
|
---|
73 | ? 6000000 <= __apple_build_version__ \
|
---|
74 | : 3 < __clang_major__ + (5 <= __clang_minor__))))
|
---|
75 | # define _GL_HAS_ATTRIBUTE(attr) __has_attribute (__##attr##__)
|
---|
76 | #else
|
---|
77 | # define _GL_HAS_ATTRIBUTE(attr) _GL_ATTR_##attr
|
---|
78 | # define _GL_ATTR_alloc_size _GL_GNUC_PREREQ (4, 3)
|
---|
79 | # define _GL_ATTR_always_inline _GL_GNUC_PREREQ (3, 2)
|
---|
80 | # define _GL_ATTR_artificial _GL_GNUC_PREREQ (4, 3)
|
---|
81 | # define _GL_ATTR_cold _GL_GNUC_PREREQ (4, 3)
|
---|
82 | # define _GL_ATTR_const _GL_GNUC_PREREQ (2, 95)
|
---|
83 | # define _GL_ATTR_deprecated _GL_GNUC_PREREQ (3, 1)
|
---|
84 | # define _GL_ATTR_diagnose_if 0
|
---|
85 | # define _GL_ATTR_error _GL_GNUC_PREREQ (4, 3)
|
---|
86 | # define _GL_ATTR_externally_visible _GL_GNUC_PREREQ (4, 1)
|
---|
87 | # define _GL_ATTR_fallthrough _GL_GNUC_PREREQ (7, 0)
|
---|
88 | # define _GL_ATTR_format _GL_GNUC_PREREQ (2, 7)
|
---|
89 | # define _GL_ATTR_leaf _GL_GNUC_PREREQ (4, 6)
|
---|
90 | # define _GL_ATTR_malloc _GL_GNUC_PREREQ (3, 0)
|
---|
91 | # ifdef _ICC
|
---|
92 | # define _GL_ATTR_may_alias 0
|
---|
93 | # else
|
---|
94 | # define _GL_ATTR_may_alias _GL_GNUC_PREREQ (3, 3)
|
---|
95 | # endif
|
---|
96 | # define _GL_ATTR_noinline _GL_GNUC_PREREQ (3, 1)
|
---|
97 | # define _GL_ATTR_nonnull _GL_GNUC_PREREQ (3, 3)
|
---|
98 | # define _GL_ATTR_nonstring _GL_GNUC_PREREQ (8, 0)
|
---|
99 | # define _GL_ATTR_nothrow _GL_GNUC_PREREQ (3, 3)
|
---|
100 | # define _GL_ATTR_packed _GL_GNUC_PREREQ (2, 7)
|
---|
101 | # define _GL_ATTR_pure _GL_GNUC_PREREQ (2, 96)
|
---|
102 | # define _GL_ATTR_returns_nonnull _GL_GNUC_PREREQ (4, 9)
|
---|
103 | # define _GL_ATTR_sentinel _GL_GNUC_PREREQ (4, 0)
|
---|
104 | # define _GL_ATTR_unused _GL_GNUC_PREREQ (2, 7)
|
---|
105 | # define _GL_ATTR_warn_unused_result _GL_GNUC_PREREQ (3, 4)
|
---|
106 | #endif
|
---|
107 |
|
---|
108 | #ifdef __has_c_attribute
|
---|
109 | # if ((defined __STDC_VERSION__ ? __STDC_VERSION__ : 0) <= 201710 \
|
---|
110 | && _GL_GNUC_PREREQ (4, 6))
|
---|
111 | # pragma GCC diagnostic ignored "-Wpedantic"
|
---|
112 | # endif
|
---|
113 | # define _GL_HAS_C_ATTRIBUTE(attr) __has_c_attribute (__##attr##__)
|
---|
114 | #else
|
---|
115 | # define _GL_HAS_C_ATTRIBUTE(attr) 0
|
---|
116 | #endif
|
---|
117 |
|
---|
118 | ]dnl There is no _GL_ATTRIBUTE_ALIGNED; use stdalign's alignas instead.
|
---|
119 | [
|
---|
120 | /* _GL_ATTRIBUTE_ALLOC_SIZE ((N)) declares that the Nth argument of the function
|
---|
121 | is the size of the returned memory block.
|
---|
122 | _GL_ATTRIBUTE_ALLOC_SIZE ((M, N)) declares that the Mth argument multiplied
|
---|
123 | by the Nth argument of the function is the size of the returned memory block.
|
---|
124 | */
|
---|
125 | /* Applies to: function, pointer to function, function types. */
|
---|
126 | #if _GL_HAS_ATTRIBUTE (alloc_size)
|
---|
127 | # define _GL_ATTRIBUTE_ALLOC_SIZE(args) __attribute__ ((__alloc_size__ args))
|
---|
128 | #else
|
---|
129 | # define _GL_ATTRIBUTE_ALLOC_SIZE(args)
|
---|
130 | #endif
|
---|
131 |
|
---|
132 | /* _GL_ATTRIBUTE_ALWAYS_INLINE tells that the compiler should always inline the
|
---|
133 | function and report an error if it cannot do so. */
|
---|
134 | /* Applies to: function. */
|
---|
135 | #if _GL_HAS_ATTRIBUTE (always_inline)
|
---|
136 | # define _GL_ATTRIBUTE_ALWAYS_INLINE __attribute__ ((__always_inline__))
|
---|
137 | #else
|
---|
138 | # define _GL_ATTRIBUTE_ALWAYS_INLINE
|
---|
139 | #endif
|
---|
140 |
|
---|
141 | /* _GL_ATTRIBUTE_ARTIFICIAL declares that the function is not important to show
|
---|
142 | in stack traces when debugging. The compiler should omit the function from
|
---|
143 | stack traces. */
|
---|
144 | /* Applies to: function. */
|
---|
145 | #if _GL_HAS_ATTRIBUTE (artificial)
|
---|
146 | # define _GL_ATTRIBUTE_ARTIFICIAL __attribute__ ((__artificial__))
|
---|
147 | #else
|
---|
148 | # define _GL_ATTRIBUTE_ARTIFICIAL
|
---|
149 | #endif
|
---|
150 |
|
---|
151 | /* _GL_ATTRIBUTE_COLD declares that the function is rarely executed. */
|
---|
152 | /* Applies to: functions. */
|
---|
153 | /* Avoid __attribute__ ((cold)) on MinGW; see thread starting at
|
---|
154 | <https://lists.gnu.org/r/emacs-devel/2019-04/msg01152.html>.
|
---|
155 | Also, Oracle Studio 12.6 requires 'cold' not '__cold__'. */
|
---|
156 | #if _GL_HAS_ATTRIBUTE (cold) && !defined __MINGW32__
|
---|
157 | # ifndef __SUNPRO_C
|
---|
158 | # define _GL_ATTRIBUTE_COLD __attribute__ ((__cold__))
|
---|
159 | # else
|
---|
160 | # define _GL_ATTRIBUTE_COLD __attribute__ ((cold))
|
---|
161 | # endif
|
---|
162 | #else
|
---|
163 | # define _GL_ATTRIBUTE_COLD
|
---|
164 | #endif
|
---|
165 |
|
---|
166 | /* _GL_ATTRIBUTE_CONST declares that it is OK for a compiler to omit duplicate
|
---|
167 | calls to the function with the same arguments.
|
---|
168 | This attribute is safe for a function that neither depends on nor affects
|
---|
169 | observable state, and always returns exactly once - e.g., does not loop
|
---|
170 | forever, and does not call longjmp.
|
---|
171 | (This attribute is stricter than _GL_ATTRIBUTE_PURE.) */
|
---|
172 | /* Applies to: functions. */
|
---|
173 | #if _GL_HAS_ATTRIBUTE (const)
|
---|
174 | # define _GL_ATTRIBUTE_CONST __attribute__ ((__const__))
|
---|
175 | #else
|
---|
176 | # define _GL_ATTRIBUTE_CONST
|
---|
177 | #endif
|
---|
178 |
|
---|
179 | /* _GL_ATTRIBUTE_DEALLOC (F, I) declares that the function returns pointers
|
---|
180 | that can be freed by passing them as the Ith argument to the
|
---|
181 | function F.
|
---|
182 | _GL_ATTRIBUTE_DEALLOC_FREE declares that the function returns pointers that
|
---|
183 | can be freed via 'free'; it can be used only after declaring 'free'. */
|
---|
184 | /* Applies to: functions. Cannot be used on inline functions. */
|
---|
185 | #if _GL_GNUC_PREREQ (11, 0)
|
---|
186 | # define _GL_ATTRIBUTE_DEALLOC(f, i) __attribute__ ((__malloc__ (f, i)))
|
---|
187 | #else
|
---|
188 | # define _GL_ATTRIBUTE_DEALLOC(f, i)
|
---|
189 | #endif
|
---|
190 | /* If gnulib's <string.h> or <wchar.h> has already defined this macro, continue
|
---|
191 | to use this earlier definition, since <stdlib.h> may not have been included
|
---|
192 | yet. */
|
---|
193 | #ifndef _GL_ATTRIBUTE_DEALLOC_FREE
|
---|
194 | # define _GL_ATTRIBUTE_DEALLOC_FREE _GL_ATTRIBUTE_DEALLOC (free, 1)
|
---|
195 | #endif
|
---|
196 |
|
---|
197 | /* _GL_ATTRIBUTE_DEPRECATED: Declares that an entity is deprecated.
|
---|
198 | The compiler may warn if the entity is used. */
|
---|
199 | /* Applies to:
|
---|
200 | - function, variable,
|
---|
201 | - struct, union, struct/union member,
|
---|
202 | - enumeration, enumeration item,
|
---|
203 | - typedef,
|
---|
204 | in C++ also: namespace, class, template specialization. */
|
---|
205 | #if _GL_HAS_C_ATTRIBUTE (deprecated)
|
---|
206 | # define _GL_ATTRIBUTE_DEPRECATED [[__deprecated__]]
|
---|
207 | #elif _GL_HAS_ATTRIBUTE (deprecated)
|
---|
208 | # define _GL_ATTRIBUTE_DEPRECATED __attribute__ ((__deprecated__))
|
---|
209 | #else
|
---|
210 | # define _GL_ATTRIBUTE_DEPRECATED
|
---|
211 | #endif
|
---|
212 |
|
---|
213 | /* _GL_ATTRIBUTE_ERROR(msg) requests an error if a function is called and
|
---|
214 | the function call is not optimized away.
|
---|
215 | _GL_ATTRIBUTE_WARNING(msg) requests a warning if a function is called and
|
---|
216 | the function call is not optimized away. */
|
---|
217 | /* Applies to: functions. */
|
---|
218 | #if _GL_HAS_ATTRIBUTE (error)
|
---|
219 | # define _GL_ATTRIBUTE_ERROR(msg) __attribute__ ((__error__ (msg)))
|
---|
220 | # define _GL_ATTRIBUTE_WARNING(msg) __attribute__ ((__warning__ (msg)))
|
---|
221 | #elif _GL_HAS_ATTRIBUTE (diagnose_if)
|
---|
222 | # define _GL_ATTRIBUTE_ERROR(msg) __attribute__ ((__diagnose_if__ (1, msg, "error")))
|
---|
223 | # define _GL_ATTRIBUTE_WARNING(msg) __attribute__ ((__diagnose_if__ (1, msg, "warning")))
|
---|
224 | #else
|
---|
225 | # define _GL_ATTRIBUTE_ERROR(msg)
|
---|
226 | # define _GL_ATTRIBUTE_WARNING(msg)
|
---|
227 | #endif
|
---|
228 |
|
---|
229 | /* _GL_ATTRIBUTE_EXTERNALLY_VISIBLE declares that the entity should remain
|
---|
230 | visible to debuggers etc., even with '-fwhole-program'. */
|
---|
231 | /* Applies to: functions, variables. */
|
---|
232 | #if _GL_HAS_ATTRIBUTE (externally_visible)
|
---|
233 | # define _GL_ATTRIBUTE_EXTERNALLY_VISIBLE __attribute__ ((externally_visible))
|
---|
234 | #else
|
---|
235 | # define _GL_ATTRIBUTE_EXTERNALLY_VISIBLE
|
---|
236 | #endif
|
---|
237 |
|
---|
238 | /* _GL_ATTRIBUTE_FALLTHROUGH declares that it is not a programming mistake if
|
---|
239 | the control flow falls through to the immediately following 'case' or
|
---|
240 | 'default' label. The compiler should not warn in this case. */
|
---|
241 | /* Applies to: Empty statement (;), inside a 'switch' statement. */
|
---|
242 | /* Always expands to something. */
|
---|
243 | #if _GL_HAS_C_ATTRIBUTE (fallthrough)
|
---|
244 | # define _GL_ATTRIBUTE_FALLTHROUGH [[__fallthrough__]]
|
---|
245 | #elif _GL_HAS_ATTRIBUTE (fallthrough)
|
---|
246 | # define _GL_ATTRIBUTE_FALLTHROUGH __attribute__ ((__fallthrough__))
|
---|
247 | #else
|
---|
248 | # define _GL_ATTRIBUTE_FALLTHROUGH ((void) 0)
|
---|
249 | #endif
|
---|
250 |
|
---|
251 | /* _GL_ATTRIBUTE_FORMAT ((ARCHETYPE, STRING-INDEX, FIRST-TO-CHECK))
|
---|
252 | declares that the STRING-INDEXth function argument is a format string of
|
---|
253 | style ARCHETYPE, which is one of:
|
---|
254 | printf, gnu_printf
|
---|
255 | scanf, gnu_scanf,
|
---|
256 | strftime, gnu_strftime,
|
---|
257 | strfmon,
|
---|
258 | or the same thing prefixed and suffixed with '__'.
|
---|
259 | If FIRST-TO-CHECK is not 0, arguments starting at FIRST-TO_CHECK
|
---|
260 | are suitable for the format string. */
|
---|
261 | /* Applies to: functions. */
|
---|
262 | #if _GL_HAS_ATTRIBUTE (format)
|
---|
263 | # define _GL_ATTRIBUTE_FORMAT(spec) __attribute__ ((__format__ spec))
|
---|
264 | #else
|
---|
265 | # define _GL_ATTRIBUTE_FORMAT(spec)
|
---|
266 | #endif
|
---|
267 |
|
---|
268 | /* _GL_ATTRIBUTE_LEAF declares that if the function is called from some other
|
---|
269 | compilation unit, it executes code from that unit only by return or by
|
---|
270 | exception handling. This declaration lets the compiler optimize that unit
|
---|
271 | more aggressively. */
|
---|
272 | /* Applies to: functions. */
|
---|
273 | #if _GL_HAS_ATTRIBUTE (leaf)
|
---|
274 | # define _GL_ATTRIBUTE_LEAF __attribute__ ((__leaf__))
|
---|
275 | #else
|
---|
276 | # define _GL_ATTRIBUTE_LEAF
|
---|
277 | #endif
|
---|
278 |
|
---|
279 | /* _GL_ATTRIBUTE_MALLOC declares that the function returns a pointer to freshly
|
---|
280 | allocated memory. */
|
---|
281 | /* Applies to: functions. */
|
---|
282 | #if _GL_HAS_ATTRIBUTE (malloc)
|
---|
283 | # define _GL_ATTRIBUTE_MALLOC __attribute__ ((__malloc__))
|
---|
284 | #else
|
---|
285 | # define _GL_ATTRIBUTE_MALLOC
|
---|
286 | #endif
|
---|
287 |
|
---|
288 | /* _GL_ATTRIBUTE_MAY_ALIAS declares that pointers to the type may point to the
|
---|
289 | same storage as pointers to other types. Thus this declaration disables
|
---|
290 | strict aliasing optimization. */
|
---|
291 | /* Applies to: types. */
|
---|
292 | /* Oracle Studio 12.6 mishandles may_alias despite __has_attribute OK. */
|
---|
293 | #if _GL_HAS_ATTRIBUTE (may_alias) && !defined __SUNPRO_C
|
---|
294 | # define _GL_ATTRIBUTE_MAY_ALIAS __attribute__ ((__may_alias__))
|
---|
295 | #else
|
---|
296 | # define _GL_ATTRIBUTE_MAY_ALIAS
|
---|
297 | #endif
|
---|
298 |
|
---|
299 | /* _GL_ATTRIBUTE_MAYBE_UNUSED declares that it is not a programming mistake if
|
---|
300 | the entity is not used. The compiler should not warn if the entity is not
|
---|
301 | used. */
|
---|
302 | /* Applies to:
|
---|
303 | - function, variable,
|
---|
304 | - struct, union, struct/union member,
|
---|
305 | - enumeration, enumeration item,
|
---|
306 | - typedef,
|
---|
307 | in C++ also: class. */
|
---|
308 | /* In C++ and C2x, this is spelled [[__maybe_unused__]].
|
---|
309 | GCC's syntax is __attribute__ ((__unused__)).
|
---|
310 | clang supports both syntaxes. */
|
---|
311 | #if _GL_HAS_C_ATTRIBUTE (maybe_unused)
|
---|
312 | # define _GL_ATTRIBUTE_MAYBE_UNUSED [[__maybe_unused__]]
|
---|
313 | #else
|
---|
314 | # define _GL_ATTRIBUTE_MAYBE_UNUSED _GL_ATTRIBUTE_UNUSED
|
---|
315 | #endif
|
---|
316 | /* Alternative spelling of this macro, for convenience and for
|
---|
317 | compatibility with glibc/include/libc-symbols.h. */
|
---|
318 | #define _GL_UNUSED _GL_ATTRIBUTE_MAYBE_UNUSED
|
---|
319 | /* Earlier spellings of this macro. */
|
---|
320 | #define _UNUSED_PARAMETER_ _GL_ATTRIBUTE_MAYBE_UNUSED
|
---|
321 |
|
---|
322 | /* _GL_ATTRIBUTE_NODISCARD declares that the caller of the function should not
|
---|
323 | discard the return value. The compiler may warn if the caller does not use
|
---|
324 | the return value, unless the caller uses something like ignore_value. */
|
---|
325 | /* Applies to: function, enumeration, class. */
|
---|
326 | #if _GL_HAS_C_ATTRIBUTE (nodiscard)
|
---|
327 | # define _GL_ATTRIBUTE_NODISCARD [[__nodiscard__]]
|
---|
328 | #elif _GL_HAS_ATTRIBUTE (warn_unused_result)
|
---|
329 | # define _GL_ATTRIBUTE_NODISCARD __attribute__ ((__warn_unused_result__))
|
---|
330 | #else
|
---|
331 | # define _GL_ATTRIBUTE_NODISCARD
|
---|
332 | #endif
|
---|
333 |
|
---|
334 | /* _GL_ATTRIBUTE_NOINLINE tells that the compiler should not inline the
|
---|
335 | function. */
|
---|
336 | /* Applies to: functions. */
|
---|
337 | #if _GL_HAS_ATTRIBUTE (noinline)
|
---|
338 | # define _GL_ATTRIBUTE_NOINLINE __attribute__ ((__noinline__))
|
---|
339 | #else
|
---|
340 | # define _GL_ATTRIBUTE_NOINLINE
|
---|
341 | #endif
|
---|
342 |
|
---|
343 | /* _GL_ATTRIBUTE_NONNULL ((N1, N2,...)) declares that the arguments N1, N2,...
|
---|
344 | must not be NULL.
|
---|
345 | _GL_ATTRIBUTE_NONNULL () declares that all pointer arguments must not be
|
---|
346 | null. */
|
---|
347 | /* Applies to: functions. */
|
---|
348 | #if _GL_HAS_ATTRIBUTE (nonnull)
|
---|
349 | # define _GL_ATTRIBUTE_NONNULL(args) __attribute__ ((__nonnull__ args))
|
---|
350 | #else
|
---|
351 | # define _GL_ATTRIBUTE_NONNULL(args)
|
---|
352 | #endif
|
---|
353 |
|
---|
354 | /* _GL_ATTRIBUTE_NONSTRING declares that the contents of a character array is
|
---|
355 | not meant to be NUL-terminated. */
|
---|
356 | /* Applies to: struct/union members and variables that are arrays of element
|
---|
357 | type '[[un]signed] char'. */
|
---|
358 | #if _GL_HAS_ATTRIBUTE (nonstring)
|
---|
359 | # define _GL_ATTRIBUTE_NONSTRING __attribute__ ((__nonstring__))
|
---|
360 | #else
|
---|
361 | # define _GL_ATTRIBUTE_NONSTRING
|
---|
362 | #endif
|
---|
363 |
|
---|
364 | /* There is no _GL_ATTRIBUTE_NORETURN; use _Noreturn instead. */
|
---|
365 |
|
---|
366 | /* _GL_ATTRIBUTE_NOTHROW declares that the function does not throw exceptions.
|
---|
367 | */
|
---|
368 | /* Applies to: functions. */
|
---|
369 | #if _GL_HAS_ATTRIBUTE (nothrow) && !defined __cplusplus
|
---|
370 | # define _GL_ATTRIBUTE_NOTHROW __attribute__ ((__nothrow__))
|
---|
371 | #else
|
---|
372 | # define _GL_ATTRIBUTE_NOTHROW
|
---|
373 | #endif
|
---|
374 |
|
---|
375 | /* _GL_ATTRIBUTE_PACKED declares:
|
---|
376 | For struct members: The member has the smallest possible alignment.
|
---|
377 | For struct, union, class: All members have the smallest possible alignment,
|
---|
378 | minimizing the memory required. */
|
---|
379 | /* Applies to: struct members, struct, union,
|
---|
380 | in C++ also: class. */
|
---|
381 | #if _GL_HAS_ATTRIBUTE (packed)
|
---|
382 | # define _GL_ATTRIBUTE_PACKED __attribute__ ((__packed__))
|
---|
383 | #else
|
---|
384 | # define _GL_ATTRIBUTE_PACKED
|
---|
385 | #endif
|
---|
386 |
|
---|
387 | /* _GL_ATTRIBUTE_PURE declares that It is OK for a compiler to omit duplicate
|
---|
388 | calls to the function with the same arguments if observable state is not
|
---|
389 | changed between calls.
|
---|
390 | This attribute is safe for a function that does not affect
|
---|
391 | observable state, and always returns exactly once.
|
---|
392 | (This attribute is looser than _GL_ATTRIBUTE_CONST.) */
|
---|
393 | /* Applies to: functions. */
|
---|
394 | #if _GL_HAS_ATTRIBUTE (pure)
|
---|
395 | # define _GL_ATTRIBUTE_PURE __attribute__ ((__pure__))
|
---|
396 | #else
|
---|
397 | # define _GL_ATTRIBUTE_PURE
|
---|
398 | #endif
|
---|
399 |
|
---|
400 | /* _GL_ATTRIBUTE_RETURNS_NONNULL declares that the function's return value is
|
---|
401 | a non-NULL pointer. */
|
---|
402 | /* Applies to: functions. */
|
---|
403 | #if _GL_HAS_ATTRIBUTE (returns_nonnull)
|
---|
404 | # define _GL_ATTRIBUTE_RETURNS_NONNULL __attribute__ ((__returns_nonnull__))
|
---|
405 | #else
|
---|
406 | # define _GL_ATTRIBUTE_RETURNS_NONNULL
|
---|
407 | #endif
|
---|
408 |
|
---|
409 | /* _GL_ATTRIBUTE_SENTINEL(pos) declares that the variadic function expects a
|
---|
410 | trailing NULL argument.
|
---|
411 | _GL_ATTRIBUTE_SENTINEL () - The last argument is NULL (requires C99).
|
---|
412 | _GL_ATTRIBUTE_SENTINEL ((N)) - The (N+1)st argument from the end is NULL. */
|
---|
413 | /* Applies to: functions. */
|
---|
414 | #if _GL_HAS_ATTRIBUTE (sentinel)
|
---|
415 | # define _GL_ATTRIBUTE_SENTINEL(pos) __attribute__ ((__sentinel__ pos))
|
---|
416 | #else
|
---|
417 | # define _GL_ATTRIBUTE_SENTINEL(pos)
|
---|
418 | #endif
|
---|
419 |
|
---|
420 | /* A helper macro. Don't use it directly. */
|
---|
421 | #if _GL_HAS_ATTRIBUTE (unused)
|
---|
422 | # define _GL_ATTRIBUTE_UNUSED __attribute__ ((__unused__))
|
---|
423 | #else
|
---|
424 | # define _GL_ATTRIBUTE_UNUSED
|
---|
425 | #endif
|
---|
426 |
|
---|
427 | ]dnl There is no _GL_ATTRIBUTE_VISIBILITY; see m4/visibility.m4 instead.
|
---|
428 | [
|
---|
429 | /* _GL_UNUSED_LABEL; declares that it is not a programming mistake if the
|
---|
430 | immediately preceding label is not used. The compiler should not warn
|
---|
431 | if the label is not used. */
|
---|
432 | /* Applies to: label (both in C and C++). */
|
---|
433 | /* Note that g++ < 4.5 does not support the '__attribute__ ((__unused__)) ;'
|
---|
434 | syntax. But clang does. */
|
---|
435 | #if !(defined __cplusplus && !_GL_GNUC_PREREQ (4, 5)) || defined __clang__
|
---|
436 | # define _GL_UNUSED_LABEL _GL_ATTRIBUTE_UNUSED
|
---|
437 | #else
|
---|
438 | # define _GL_UNUSED_LABEL
|
---|
439 | #endif
|
---|
440 | ])
|
---|
441 | AH_VERBATIM([async_safe],
|
---|
442 | [/* The _GL_ASYNC_SAFE marker should be attached to functions that are
|
---|
443 | signal handlers (for signals other than SIGABRT, SIGPIPE) or can be
|
---|
444 | invoked from such signal handlers. Such functions have some restrictions:
|
---|
445 | * All functions that it calls should be marked _GL_ASYNC_SAFE as well,
|
---|
446 | or should be listed as async-signal-safe in POSIX
|
---|
447 | <https://pubs.opengroup.org/onlinepubs/9699919799/functions/V2_chap02.html#tag_15_04>
|
---|
448 | section 2.4.3. Note that malloc(), sprintf(), and fwrite(), in
|
---|
449 | particular, are NOT async-signal-safe.
|
---|
450 | * All memory locations (variables and struct fields) that these functions
|
---|
451 | access must be marked 'volatile'. This holds for both read and write
|
---|
452 | accesses. Otherwise the compiler might optimize away stores to and
|
---|
453 | reads from such locations that occur in the program, depending on its
|
---|
454 | data flow analysis. For example, when the program contains a loop
|
---|
455 | that is intended to inspect a variable set from within a signal handler
|
---|
456 | while (!signal_occurred)
|
---|
457 | ;
|
---|
458 | the compiler is allowed to transform this into an endless loop if the
|
---|
459 | variable 'signal_occurred' is not declared 'volatile'.
|
---|
460 | Additionally, recall that:
|
---|
461 | * A signal handler should not modify errno (except if it is a handler
|
---|
462 | for a fatal signal and ends by raising the same signal again, thus
|
---|
463 | provoking the termination of the process). If it invokes a function
|
---|
464 | that may clobber errno, it needs to save and restore the value of
|
---|
465 | errno. */
|
---|
466 | #define _GL_ASYNC_SAFE
|
---|
467 | ])
|
---|
468 | AH_VERBATIM([micro_optimizations],
|
---|
469 | [/* _GL_CMP (n1, n2) performs a three-valued comparison on n1 vs. n2, where
|
---|
470 | n1 and n2 are expressions without side effects, that evaluate to real
|
---|
471 | numbers (excluding NaN).
|
---|
472 | It returns
|
---|
473 | 1 if n1 > n2
|
---|
474 | 0 if n1 == n2
|
---|
475 | -1 if n1 < n2
|
---|
476 | The naïve code (n1 > n2 ? 1 : n1 < n2 ? -1 : 0) produces a conditional
|
---|
477 | jump with nearly all GCC versions up to GCC 10.
|
---|
478 | This variant (n1 < n2 ? -1 : n1 > n2) produces a conditional with many
|
---|
479 | GCC versions up to GCC 9.
|
---|
480 | The better code (n1 > n2) - (n1 < n2) from Hacker's Delight § 2-9
|
---|
481 | avoids conditional jumps in all GCC versions >= 3.4. */
|
---|
482 | #define _GL_CMP(n1, n2) (((n1) > (n2)) - ((n1) < (n2)))
|
---|
483 | ])
|
---|
484 | dnl Hint which direction to take regarding cross-compilation guesses:
|
---|
485 | dnl When a user installs a program on a platform they are not intimately
|
---|
486 | dnl familiar with, --enable-cross-guesses=conservative is the appropriate
|
---|
487 | dnl choice. It implements the "If we don't know, assume the worst" principle.
|
---|
488 | dnl However, when an operating system developer (on a platform which is not
|
---|
489 | dnl yet known to gnulib) builds packages for their platform, they want to
|
---|
490 | dnl expose, not hide, possible platform bugs; in this case,
|
---|
491 | dnl --enable-cross-guesses=risky is the appropriate choice.
|
---|
492 | dnl Sets the variables
|
---|
493 | dnl gl_cross_guess_normal (to be used when 'yes' is good and 'no' is bad),
|
---|
494 | dnl gl_cross_guess_inverted (to be used when 'no' is good and 'yes' is bad).
|
---|
495 | AC_ARG_ENABLE([cross-guesses],
|
---|
496 | [AS_HELP_STRING([--enable-cross-guesses={conservative|risky}],
|
---|
497 | [specify policy for cross-compilation guesses])],
|
---|
498 | [if test "x$enableval" != xconservative && test "x$enableval" != xrisky; then
|
---|
499 | AC_MSG_WARN([invalid argument supplied to --enable-cross-guesses])
|
---|
500 | enableval=conservative
|
---|
501 | fi
|
---|
502 | gl_cross_guesses="$enableval"],
|
---|
503 | [gl_cross_guesses=conservative])
|
---|
504 | if test $gl_cross_guesses = risky; then
|
---|
505 | gl_cross_guess_normal="guessing yes"
|
---|
506 | gl_cross_guess_inverted="guessing no"
|
---|
507 | else
|
---|
508 | gl_cross_guess_normal="guessing no"
|
---|
509 | gl_cross_guess_inverted="guessing yes"
|
---|
510 | fi
|
---|
511 | dnl Preparation for running test programs:
|
---|
512 | dnl Tell glibc to write diagnostics from -D_FORTIFY_SOURCE=2 to stderr, not
|
---|
513 | dnl to /dev/tty, so they can be redirected to log files. Such diagnostics
|
---|
514 | dnl arise e.g., in the macros gl_PRINTF_DIRECTIVE_N, gl_SNPRINTF_DIRECTIVE_N.
|
---|
515 | LIBC_FATAL_STDERR_=1
|
---|
516 | export LIBC_FATAL_STDERR_
|
---|
517 | ])
|
---|
518 |
|
---|
519 | # gl_MODULE_INDICATOR_INIT_VARIABLE([variablename])
|
---|
520 | # gl_MODULE_INDICATOR_INIT_VARIABLE([variablename], [initialvalue])
|
---|
521 | # initializes the shell variable that indicates the presence of the given module
|
---|
522 | # as a C preprocessor expression.
|
---|
523 | AC_DEFUN([gl_MODULE_INDICATOR_INIT_VARIABLE],
|
---|
524 | [
|
---|
525 | GL_MODULE_INDICATOR_PREFIX[]_[$1]=m4_if([$2], , [0], [$2])
|
---|
526 | AC_SUBST(GL_MODULE_INDICATOR_PREFIX[]_[$1])
|
---|
527 | ])
|
---|
528 |
|
---|
529 | # gl_MODULE_INDICATOR_CONDITION
|
---|
530 | # expands to a C preprocessor expression that evaluates to 1 or 0, depending
|
---|
531 | # whether a gnulib module that has been requested shall be considered present
|
---|
532 | # or not.
|
---|
533 | m4_define([gl_MODULE_INDICATOR_CONDITION], [1])
|
---|
534 |
|
---|
535 | # gl_MODULE_INDICATOR_SET_VARIABLE([modulename])
|
---|
536 | # sets the shell variable that indicates the presence of the given module to
|
---|
537 | # a C preprocessor expression that will evaluate to 1.
|
---|
538 | AC_DEFUN([gl_MODULE_INDICATOR_SET_VARIABLE],
|
---|
539 | [
|
---|
540 | gl_MODULE_INDICATOR_SET_VARIABLE_AUX(
|
---|
541 | [GL_MODULE_INDICATOR_PREFIX[]_GNULIB_[]m4_translit([[$1]],
|
---|
542 | [abcdefghijklmnopqrstuvwxyz./-],
|
---|
543 | [ABCDEFGHIJKLMNOPQRSTUVWXYZ___])],
|
---|
544 | [gl_MODULE_INDICATOR_CONDITION])
|
---|
545 | ])
|
---|
546 |
|
---|
547 | # gl_MODULE_INDICATOR_SET_VARIABLE_AUX([variable])
|
---|
548 | # modifies the shell variable to include the gl_MODULE_INDICATOR_CONDITION.
|
---|
549 | # The shell variable's value is a C preprocessor expression that evaluates
|
---|
550 | # to 0 or 1.
|
---|
551 | AC_DEFUN([gl_MODULE_INDICATOR_SET_VARIABLE_AUX],
|
---|
552 | [
|
---|
553 | m4_if(m4_defn([gl_MODULE_INDICATOR_CONDITION]), [1],
|
---|
554 | [
|
---|
555 | dnl Simplify the expression VALUE || 1 to 1.
|
---|
556 | $1=1
|
---|
557 | ],
|
---|
558 | [gl_MODULE_INDICATOR_SET_VARIABLE_AUX_OR([$1],
|
---|
559 | [gl_MODULE_INDICATOR_CONDITION])])
|
---|
560 | ])
|
---|
561 |
|
---|
562 | # gl_MODULE_INDICATOR_SET_VARIABLE_AUX_OR([variable], [condition])
|
---|
563 | # modifies the shell variable to include the given condition. The shell
|
---|
564 | # variable's value is a C preprocessor expression that evaluates to 0 or 1.
|
---|
565 | AC_DEFUN([gl_MODULE_INDICATOR_SET_VARIABLE_AUX_OR],
|
---|
566 | [
|
---|
567 | dnl Simplify the expression 1 || CONDITION to 1.
|
---|
568 | if test "$[]$1" != 1; then
|
---|
569 | dnl Simplify the expression 0 || CONDITION to CONDITION.
|
---|
570 | if test "$[]$1" = 0; then
|
---|
571 | $1=$2
|
---|
572 | else
|
---|
573 | $1="($[]$1 || $2)"
|
---|
574 | fi
|
---|
575 | fi
|
---|
576 | ])
|
---|
577 |
|
---|
578 | # gl_MODULE_INDICATOR([modulename])
|
---|
579 | # defines a C macro indicating the presence of the given module
|
---|
580 | # in a location where it can be used.
|
---|
581 | # | Value | Value |
|
---|
582 | # | in lib/ | in tests/ |
|
---|
583 | # --------------------------------------------+---------+-----------+
|
---|
584 | # Module present among main modules: | 1 | 1 |
|
---|
585 | # --------------------------------------------+---------+-----------+
|
---|
586 | # Module present among tests-related modules: | 0 | 1 |
|
---|
587 | # --------------------------------------------+---------+-----------+
|
---|
588 | # Module not present at all: | 0 | 0 |
|
---|
589 | # --------------------------------------------+---------+-----------+
|
---|
590 | AC_DEFUN([gl_MODULE_INDICATOR],
|
---|
591 | [
|
---|
592 | AC_DEFINE_UNQUOTED([GNULIB_]m4_translit([[$1]],
|
---|
593 | [abcdefghijklmnopqrstuvwxyz./-],
|
---|
594 | [ABCDEFGHIJKLMNOPQRSTUVWXYZ___]),
|
---|
595 | [gl_MODULE_INDICATOR_CONDITION],
|
---|
596 | [Define to a C preprocessor expression that evaluates to 1 or 0,
|
---|
597 | depending whether the gnulib module $1 shall be considered present.])
|
---|
598 | ])
|
---|
599 |
|
---|
600 | # gl_MODULE_INDICATOR_FOR_TESTS([modulename])
|
---|
601 | # defines a C macro indicating the presence of the given module
|
---|
602 | # in lib or tests. This is useful to determine whether the module
|
---|
603 | # should be tested.
|
---|
604 | # | Value | Value |
|
---|
605 | # | in lib/ | in tests/ |
|
---|
606 | # --------------------------------------------+---------+-----------+
|
---|
607 | # Module present among main modules: | 1 | 1 |
|
---|
608 | # --------------------------------------------+---------+-----------+
|
---|
609 | # Module present among tests-related modules: | 1 | 1 |
|
---|
610 | # --------------------------------------------+---------+-----------+
|
---|
611 | # Module not present at all: | 0 | 0 |
|
---|
612 | # --------------------------------------------+---------+-----------+
|
---|
613 | AC_DEFUN([gl_MODULE_INDICATOR_FOR_TESTS],
|
---|
614 | [
|
---|
615 | AC_DEFINE([GNULIB_TEST_]m4_translit([[$1]],
|
---|
616 | [abcdefghijklmnopqrstuvwxyz./-],
|
---|
617 | [ABCDEFGHIJKLMNOPQRSTUVWXYZ___]), [1],
|
---|
618 | [Define to 1 when the gnulib module $1 should be tested.])
|
---|
619 | ])
|
---|
620 |
|
---|
621 | # gl_ASSERT_NO_GNULIB_POSIXCHECK
|
---|
622 | # asserts that there will never be a need to #define GNULIB_POSIXCHECK.
|
---|
623 | # and thereby enables an optimization of configure and config.h.
|
---|
624 | # Used by Emacs.
|
---|
625 | AC_DEFUN([gl_ASSERT_NO_GNULIB_POSIXCHECK],
|
---|
626 | [
|
---|
627 | dnl Override gl_WARN_ON_USE_PREPARE.
|
---|
628 | dnl But hide this definition from 'aclocal'.
|
---|
629 | AC_DEFUN([gl_W][ARN_ON_USE_PREPARE], [])
|
---|
630 | ])
|
---|
631 |
|
---|
632 | # gl_ASSERT_NO_GNULIB_TESTS
|
---|
633 | # asserts that there will be no gnulib tests in the scope of the configure.ac
|
---|
634 | # and thereby enables an optimization of config.h.
|
---|
635 | # Used by Emacs.
|
---|
636 | AC_DEFUN([gl_ASSERT_NO_GNULIB_TESTS],
|
---|
637 | [
|
---|
638 | dnl Override gl_MODULE_INDICATOR_FOR_TESTS.
|
---|
639 | AC_DEFUN([gl_MODULE_INDICATOR_FOR_TESTS], [])
|
---|
640 | ])
|
---|
641 |
|
---|
642 | # Test whether <features.h> exists.
|
---|
643 | # Set HAVE_FEATURES_H.
|
---|
644 | AC_DEFUN([gl_FEATURES_H],
|
---|
645 | [
|
---|
646 | AC_CHECK_HEADERS_ONCE([features.h])
|
---|
647 | if test $ac_cv_header_features_h = yes; then
|
---|
648 | HAVE_FEATURES_H=1
|
---|
649 | else
|
---|
650 | HAVE_FEATURES_H=0
|
---|
651 | fi
|
---|
652 | AC_SUBST([HAVE_FEATURES_H])
|
---|
653 | ])
|
---|
654 |
|
---|
655 | # gl_PROG_CC_C99
|
---|
656 | # Modifies the value of the shell variable CC in an attempt to make $CC
|
---|
657 | # understand ISO C99 source code.
|
---|
658 | AC_DEFUN([gl_PROG_CC_C99],
|
---|
659 | [
|
---|
660 | dnl Just use AC_PROG_CC_C99.
|
---|
661 | dnl When AC_PROG_CC_C99 and AC_PROG_CC_STDC are used together, the substituted
|
---|
662 | dnl value of CC will contain the C99 enabling options twice. But this is only
|
---|
663 | dnl a cosmetic problem.
|
---|
664 | dnl With Autoconf >= 2.70, use AC_PROG_CC since it implies AC_PROG_CC_C99;
|
---|
665 | dnl this avoids a "warning: The macro `AC_PROG_CC_C99' is obsolete."
|
---|
666 | m4_version_prereq([2.70],
|
---|
667 | [AC_REQUIRE([AC_PROG_CC])],
|
---|
668 | [AC_REQUIRE([AC_PROG_CC_C99])])
|
---|
669 | ])
|
---|
670 |
|
---|
671 | # gl_PROG_AR_RANLIB
|
---|
672 | # Determines the values for AR, ARFLAGS, RANLIB that fit with the compiler.
|
---|
673 | # The user can set the variables AR, ARFLAGS, RANLIB if he wants to override
|
---|
674 | # the values.
|
---|
675 | AC_DEFUN([gl_PROG_AR_RANLIB],
|
---|
676 | [
|
---|
677 | dnl Minix 3 comes with two toolchains: The Amsterdam Compiler Kit compiler
|
---|
678 | dnl as "cc", and GCC as "gcc". They have different object file formats and
|
---|
679 | dnl library formats. In particular, the GNU binutils programs ar and ranlib
|
---|
680 | dnl produce libraries that work only with gcc, not with cc.
|
---|
681 | AC_REQUIRE([AC_PROG_CC])
|
---|
682 | dnl The '][' hides this use from 'aclocal'.
|
---|
683 | AC_BEFORE([$0], [A][M_PROG_AR])
|
---|
684 | AC_CACHE_CHECK([for Minix Amsterdam compiler], [gl_cv_c_amsterdam_compiler],
|
---|
685 | [
|
---|
686 | AC_EGREP_CPP([Amsterdam],
|
---|
687 | [
|
---|
688 | #ifdef __ACK__
|
---|
689 | Amsterdam
|
---|
690 | #endif
|
---|
691 | ],
|
---|
692 | [gl_cv_c_amsterdam_compiler=yes],
|
---|
693 | [gl_cv_c_amsterdam_compiler=no])
|
---|
694 | ])
|
---|
695 |
|
---|
696 | dnl Don't compete with AM_PROG_AR's decision about AR/ARFLAGS if we are not
|
---|
697 | dnl building with __ACK__.
|
---|
698 | if test $gl_cv_c_amsterdam_compiler = yes; then
|
---|
699 | if test -z "$AR"; then
|
---|
700 | AR='cc -c.a'
|
---|
701 | fi
|
---|
702 | if test -z "$ARFLAGS"; then
|
---|
703 | ARFLAGS='-o'
|
---|
704 | fi
|
---|
705 | else
|
---|
706 | dnl AM_PROG_AR was added in automake v1.11.2. AM_PROG_AR does not AC_SUBST
|
---|
707 | dnl ARFLAGS variable (it is filed into Makefile.in directly by automake
|
---|
708 | dnl script on-demand, if not specified by ./configure of course).
|
---|
709 | dnl Don't AC_REQUIRE the AM_PROG_AR otherwise the code for __ACK__ above
|
---|
710 | dnl will be ignored. Also, pay attention to call AM_PROG_AR in else block
|
---|
711 | dnl because AM_PROG_AR is written so it could re-set AR variable even for
|
---|
712 | dnl __ACK__. It may seem like its easier to avoid calling the macro here,
|
---|
713 | dnl but we need to AC_SUBST both AR/ARFLAGS (thus those must have some good
|
---|
714 | dnl default value and automake should usually know them).
|
---|
715 | dnl
|
---|
716 | dnl The '][' hides this use from 'aclocal'.
|
---|
717 | m4_ifdef([A][M_PROG_AR], [A][M_PROG_AR], [:])
|
---|
718 | fi
|
---|
719 |
|
---|
720 | dnl In case the code above has not helped with setting AR/ARFLAGS, use
|
---|
721 | dnl Automake-documented default values for AR and ARFLAGS, but prefer
|
---|
722 | dnl ${host}-ar over ar (useful for cross-compiling).
|
---|
723 | AC_CHECK_TOOL([AR], [ar], [ar])
|
---|
724 | if test -z "$ARFLAGS"; then
|
---|
725 | ARFLAGS='cr'
|
---|
726 | fi
|
---|
727 |
|
---|
728 | AC_SUBST([AR])
|
---|
729 | AC_SUBST([ARFLAGS])
|
---|
730 | if test -z "$RANLIB"; then
|
---|
731 | if test $gl_cv_c_amsterdam_compiler = yes; then
|
---|
732 | RANLIB=':'
|
---|
733 | else
|
---|
734 | dnl Use the ranlib program if it is available.
|
---|
735 | AC_PROG_RANLIB
|
---|
736 | fi
|
---|
737 | fi
|
---|
738 | AC_SUBST([RANLIB])
|
---|
739 | ])
|
---|
740 |
|
---|
741 | # AC_C_RESTRICT
|
---|
742 | # This definition is copied from post-2.70 Autoconf and overrides the
|
---|
743 | # AC_C_RESTRICT macro from autoconf 2.60..2.70.
|
---|
744 | m4_version_prereq([2.70.1], [], [
|
---|
745 | AC_DEFUN([AC_C_RESTRICT],
|
---|
746 | [AC_CACHE_CHECK([for C/C++ restrict keyword], [ac_cv_c_restrict],
|
---|
747 | [ac_cv_c_restrict=no
|
---|
748 | # Put '__restrict__' first, to avoid problems with glibc and non-GCC; see:
|
---|
749 | # https://lists.gnu.org/archive/html/bug-autoconf/2016-02/msg00006.html
|
---|
750 | # Put 'restrict' last, because C++ lacks it.
|
---|
751 | for ac_kw in __restrict__ __restrict _Restrict restrict; do
|
---|
752 | AC_COMPILE_IFELSE(
|
---|
753 | [AC_LANG_PROGRAM(
|
---|
754 | [[typedef int *int_ptr;
|
---|
755 | int foo (int_ptr $ac_kw ip) { return ip[0]; }
|
---|
756 | int bar (int [$ac_kw]); /* Catch GCC bug 14050. */
|
---|
757 | int bar (int ip[$ac_kw]) { return ip[0]; }
|
---|
758 | ]],
|
---|
759 | [[int s[1];
|
---|
760 | int *$ac_kw t = s;
|
---|
761 | t[0] = 0;
|
---|
762 | return foo (t) + bar (t);
|
---|
763 | ]])],
|
---|
764 | [ac_cv_c_restrict=$ac_kw])
|
---|
765 | test "$ac_cv_c_restrict" != no && break
|
---|
766 | done
|
---|
767 | ])
|
---|
768 | AH_VERBATIM([restrict],
|
---|
769 | [/* Define to the equivalent of the C99 'restrict' keyword, or to
|
---|
770 | nothing if this is not supported. Do not define if restrict is
|
---|
771 | supported only directly. */
|
---|
772 | #undef restrict
|
---|
773 | /* Work around a bug in older versions of Sun C++, which did not
|
---|
774 | #define __restrict__ or support _Restrict or __restrict__
|
---|
775 | even though the corresponding Sun C compiler ended up with
|
---|
776 | "#define restrict _Restrict" or "#define restrict __restrict__"
|
---|
777 | in the previous line. This workaround can be removed once
|
---|
778 | we assume Oracle Developer Studio 12.5 (2016) or later. */
|
---|
779 | #if defined __SUNPRO_CC && !defined __RESTRICT && !defined __restrict__
|
---|
780 | # define _Restrict
|
---|
781 | # define __restrict__
|
---|
782 | #endif])
|
---|
783 | case $ac_cv_c_restrict in
|
---|
784 | restrict) ;;
|
---|
785 | no) AC_DEFINE([restrict], []) ;;
|
---|
786 | *) AC_DEFINE_UNQUOTED([restrict], [$ac_cv_c_restrict]) ;;
|
---|
787 | esac
|
---|
788 | ])# AC_C_RESTRICT
|
---|
789 | ])
|
---|
790 |
|
---|
791 | # gl_BIGENDIAN
|
---|
792 | # is like AC_C_BIGENDIAN, except that it can be AC_REQUIREd.
|
---|
793 | # Note that AC_REQUIRE([AC_C_BIGENDIAN]) does not work reliably because some
|
---|
794 | # macros invoke AC_C_BIGENDIAN with arguments.
|
---|
795 | AC_DEFUN([gl_BIGENDIAN],
|
---|
796 | [
|
---|
797 | AC_C_BIGENDIAN
|
---|
798 | ])
|
---|
799 |
|
---|
800 | # A temporary file descriptor.
|
---|
801 | # Must be less than 10, because dash 0.5.8 does not support redirections
|
---|
802 | # with multi-digit file descriptors.
|
---|
803 | m4_define([GL_TMP_FD], 9)
|
---|
804 |
|
---|
805 | # gl_SILENT(command)
|
---|
806 | # executes command, but without the normal configure output.
|
---|
807 | # This is useful when you want to invoke AC_CACHE_CHECK (or AC_CHECK_FUNC etc.)
|
---|
808 | # inside another AC_CACHE_CHECK.
|
---|
809 | AC_DEFUN([gl_SILENT],
|
---|
810 | [
|
---|
811 | exec GL_TMP_FD>&AS_MESSAGE_FD AS_MESSAGE_FD>/dev/null
|
---|
812 | $1
|
---|
813 | exec AS_MESSAGE_FD>&GL_TMP_FD GL_TMP_FD>&-
|
---|
814 | ])
|
---|
815 |
|
---|
816 | # gl_CACHE_VAL_SILENT(cache-id, command-to-set-it)
|
---|
817 | # is like AC_CACHE_VAL(cache-id, command-to-set-it), except that it does not
|
---|
818 | # output a spurious "(cached)" mark in the midst of other configure output.
|
---|
819 | # This macro should be used instead of AC_CACHE_VAL when it is not surrounded
|
---|
820 | # by an AC_MSG_CHECKING/AC_MSG_RESULT pair.
|
---|
821 | AC_DEFUN([gl_CACHE_VAL_SILENT],
|
---|
822 | [
|
---|
823 | gl_SILENT([
|
---|
824 | AC_CACHE_VAL([$1], [$2])
|
---|
825 | ])
|
---|
826 | ])
|
---|
827 |
|
---|
828 | # gl_CONDITIONAL(conditional, condition)
|
---|
829 | # is like AM_CONDITIONAL(conditional, condition), except that it does not
|
---|
830 | # produce an error
|
---|
831 | # configure: error: conditional "..." was never defined.
|
---|
832 | # Usually this means the macro was only invoked conditionally.
|
---|
833 | # when only invoked conditionally. Instead, in that case, both the _TRUE
|
---|
834 | # and the _FALSE case are disabled.
|
---|
835 | AC_DEFUN([gl_CONDITIONAL],
|
---|
836 | [
|
---|
837 | pushdef([AC_CONFIG_COMMANDS_PRE], [:])dnl
|
---|
838 | AM_CONDITIONAL([$1], [$2])
|
---|
839 | popdef([AC_CONFIG_COMMANDS_PRE])dnl
|
---|
840 | if test -z "${[$1]_TRUE}" && test -z "${[$1]_FALSE}"; then
|
---|
841 | [$1]_TRUE='#'
|
---|
842 | [$1]_FALSE='#'
|
---|
843 | fi
|
---|
844 | ])
|
---|
845 |
|
---|
846 | # gl_CC_ALLOW_WARNINGS
|
---|
847 | # sets and substitutes a variable GL_CFLAG_ALLOW_WARNINGS, to a $(CC) option
|
---|
848 | # that reverts a preceding '-Werror' option, if available.
|
---|
849 | # This is expected to be '-Wno-error' on gcc, clang (except clang/MSVC), xlclang
|
---|
850 | # and empty otherwise.
|
---|
851 | AC_DEFUN([gl_CC_ALLOW_WARNINGS],
|
---|
852 | [
|
---|
853 | AC_REQUIRE([AC_PROG_CC])
|
---|
854 | AC_CACHE_CHECK([for C compiler option to allow warnings],
|
---|
855 | [gl_cv_cc_wallow],
|
---|
856 | [rm -f conftest*
|
---|
857 | echo 'int dummy;' > conftest.c
|
---|
858 | AC_TRY_COMMAND([${CC-cc} $CFLAGS $CPPFLAGS -c conftest.c 2>conftest1.err]) >/dev/null
|
---|
859 | AC_TRY_COMMAND([${CC-cc} $CFLAGS $CPPFLAGS -Wno-error -c conftest.c 2>conftest2.err]) >/dev/null
|
---|
860 | dnl Test the number of error output lines, because AIX xlc accepts the
|
---|
861 | dnl option '-Wno-error', just to produce a warning
|
---|
862 | dnl "Option -Wno-error was incorrectly specified. The option will be ignored."
|
---|
863 | dnl afterwards.
|
---|
864 | if test $? = 0 && test `wc -l < conftest1.err` = `wc -l < conftest2.err`; then
|
---|
865 | gl_cv_cc_wallow='-Wno-error'
|
---|
866 | else
|
---|
867 | gl_cv_cc_wallow=none
|
---|
868 | fi
|
---|
869 | rm -f conftest*
|
---|
870 | ])
|
---|
871 | case "$gl_cv_cc_wallow" in
|
---|
872 | none) GL_CFLAG_ALLOW_WARNINGS='' ;;
|
---|
873 | *) GL_CFLAG_ALLOW_WARNINGS="$gl_cv_cc_wallow" ;;
|
---|
874 | esac
|
---|
875 | AC_SUBST([GL_CFLAG_ALLOW_WARNINGS])
|
---|
876 | ])
|
---|
877 |
|
---|
878 | # gl_CXX_ALLOW_WARNINGS
|
---|
879 | # sets and substitutes a variable GL_CXXFLAG_ALLOW_WARNINGS, to a $(CC) option
|
---|
880 | # that reverts a preceding '-Werror' option, if available.
|
---|
881 | AC_DEFUN([gl_CXX_ALLOW_WARNINGS],
|
---|
882 | [
|
---|
883 | dnl Requires AC_PROG_CXX or gl_PROG_ANSI_CXX.
|
---|
884 | if test -n "$CXX" && test "$CXX" != no; then
|
---|
885 | AC_CACHE_CHECK([for C++ compiler option to allow warnings],
|
---|
886 | [gl_cv_cxx_wallow],
|
---|
887 | [rm -f conftest*
|
---|
888 | echo 'int dummy;' > conftest.cc
|
---|
889 | AC_TRY_COMMAND([${CXX-c++} $CXXFLAGS $CPPFLAGS -c conftest.cc 2>conftest1.err]) >/dev/null
|
---|
890 | AC_TRY_COMMAND([${CXX-c++} $CXXFLAGS $CPPFLAGS -Wno-error -c conftest.cc 2>conftest2.err]) >/dev/null
|
---|
891 | dnl Test the number of error output lines, because AIX xlC accepts the
|
---|
892 | dnl option '-Wno-error', just to produce a warning
|
---|
893 | dnl "Option -Wno-error was incorrectly specified. The option will be ignored."
|
---|
894 | dnl afterwards.
|
---|
895 | if test $? = 0 && test `wc -l < conftest1.err` = `wc -l < conftest2.err`; then
|
---|
896 | gl_cv_cxx_wallow='-Wno-error'
|
---|
897 | else
|
---|
898 | gl_cv_cxx_wallow=none
|
---|
899 | fi
|
---|
900 | rm -f conftest*
|
---|
901 | ])
|
---|
902 | case "$gl_cv_cxx_wallow" in
|
---|
903 | none) GL_CXXFLAG_ALLOW_WARNINGS='' ;;
|
---|
904 | *) GL_CXXFLAG_ALLOW_WARNINGS="$gl_cv_cxx_wallow" ;;
|
---|
905 | esac
|
---|
906 | else
|
---|
907 | GL_CXXFLAG_ALLOW_WARNINGS=''
|
---|
908 | fi
|
---|
909 | AC_SUBST([GL_CXXFLAG_ALLOW_WARNINGS])
|
---|
910 | ])
|
---|
911 |
|
---|
912 | # gl_CC_GNULIB_WARNINGS
|
---|
913 | # sets and substitutes a variable GL_CFLAG_GNULIB_WARNINGS, to a $(CC) option
|
---|
914 | # set that enables or disables warnings as suitable for the Gnulib coding style.
|
---|
915 | AC_DEFUN([gl_CC_GNULIB_WARNINGS],
|
---|
916 | [
|
---|
917 | AC_REQUIRE([gl_CC_ALLOW_WARNINGS])
|
---|
918 | dnl Assume that the compiler supports -Wno-* options only if it also supports
|
---|
919 | dnl -Wno-error.
|
---|
920 | GL_CFLAG_GNULIB_WARNINGS=''
|
---|
921 | if test -n "$GL_CFLAG_ALLOW_WARNINGS"; then
|
---|
922 | dnl Enable these warning options:
|
---|
923 | dnl
|
---|
924 | dnl GCC clang
|
---|
925 | dnl -Wno-cast-qual >= 3 >= 3.9
|
---|
926 | dnl -Wno-conversion >= 3 >= 3.9
|
---|
927 | dnl -Wno-float-conversion >= 4.9 >= 3.9
|
---|
928 | dnl -Wno-float-equal >= 3 >= 3.9
|
---|
929 | dnl -Wimplicit-fallthrough >= 7 >= 3.9
|
---|
930 | dnl -Wno-pedantic >= 4.8 >= 3.9
|
---|
931 | dnl -Wno-sign-compare >= 3 >= 3.9
|
---|
932 | dnl -Wno-sign-conversion >= 4.3 >= 3.9
|
---|
933 | dnl -Wno-type-limits >= 4.3 >= 3.9
|
---|
934 | dnl -Wno-undef >= 3 >= 3.9
|
---|
935 | dnl -Wno-unsuffixed-float-constants >= 4.5
|
---|
936 | dnl -Wno-unused-function >= 3 >= 3.9
|
---|
937 | dnl -Wno-unused-parameter >= 3 >= 3.9
|
---|
938 | dnl
|
---|
939 | cat > conftest.c <<\EOF
|
---|
940 | #if __GNUC__ >= 3 || (__clang_major__ + (__clang_minor__ >= 9) > 3)
|
---|
941 | -Wno-cast-qual
|
---|
942 | -Wno-conversion
|
---|
943 | -Wno-float-equal
|
---|
944 | -Wno-sign-compare
|
---|
945 | -Wno-undef
|
---|
946 | -Wno-unused-function
|
---|
947 | -Wno-unused-parameter
|
---|
948 | #endif
|
---|
949 | #if __GNUC__ + (__GNUC_MINOR__ >= 9) > 4 || (__clang_major__ + (__clang_minor__ >= 9) > 3)
|
---|
950 | -Wno-float-conversion
|
---|
951 | #endif
|
---|
952 | #if __GNUC__ >= 7 || (__clang_major__ + (__clang_minor__ >= 9) > 3)
|
---|
953 | -Wimplicit-fallthrough
|
---|
954 | #endif
|
---|
955 | #if __GNUC__ + (__GNUC_MINOR__ >= 8) > 4 || (__clang_major__ + (__clang_minor__ >= 9) > 3)
|
---|
956 | -Wno-pedantic
|
---|
957 | #endif
|
---|
958 | #if __GNUC__ + (__GNUC_MINOR__ >= 3) > 4 || (__clang_major__ + (__clang_minor__ >= 9) > 3)
|
---|
959 | -Wno-sign-conversion
|
---|
960 | -Wno-type-limits
|
---|
961 | #endif
|
---|
962 | #if __GNUC__ + (__GNUC_MINOR__ >= 5) > 4
|
---|
963 | -Wno-unsuffixed-float-constants
|
---|
964 | #endif
|
---|
965 | EOF
|
---|
966 | gl_command="$CC $CFLAGS $CPPFLAGS -E conftest.c > conftest.out"
|
---|
967 | if AC_TRY_EVAL([gl_command]); then
|
---|
968 | gl_options=`grep -v '#' conftest.out`
|
---|
969 | for word in $gl_options; do
|
---|
970 | GL_CFLAG_GNULIB_WARNINGS="$GL_CFLAG_GNULIB_WARNINGS $word"
|
---|
971 | done
|
---|
972 | fi
|
---|
973 | rm -f conftest.c conftest.out
|
---|
974 | fi
|
---|
975 | AC_SUBST([GL_CFLAG_GNULIB_WARNINGS])
|
---|
976 | ])
|
---|
977 |
|
---|
978 | dnl gl_CONDITIONAL_HEADER([foo.h])
|
---|
979 | dnl takes a shell variable GL_GENERATE_FOO_H (with value true or false) as input
|
---|
980 | dnl and produces
|
---|
981 | dnl - an AC_SUBSTed variable FOO_H that is either a file name or empty, based
|
---|
982 | dnl on whether GL_GENERATE_FOO_H is true or false,
|
---|
983 | dnl - an Automake conditional GL_GENERATE_FOO_H that evaluates to the value of
|
---|
984 | dnl the shell variable GL_GENERATE_FOO_H.
|
---|
985 | AC_DEFUN([gl_CONDITIONAL_HEADER],
|
---|
986 | [
|
---|
987 | m4_pushdef([gl_header_name], AS_TR_SH(m4_toupper($1)))
|
---|
988 | m4_pushdef([gl_generate_var], [GL_GENERATE_]AS_TR_SH(m4_toupper($1)))
|
---|
989 | m4_pushdef([gl_generate_cond], [GL_GENERATE_]AS_TR_SH(m4_toupper($1)))
|
---|
990 | case "$gl_generate_var" in
|
---|
991 | false) gl_header_name='' ;;
|
---|
992 | true)
|
---|
993 | dnl It is OK to use a .h file in lib/ from within tests/, but not vice
|
---|
994 | dnl versa.
|
---|
995 | if test -z "$gl_header_name"; then
|
---|
996 | gl_header_name="${gl_source_base_prefix}$1"
|
---|
997 | fi
|
---|
998 | ;;
|
---|
999 | *) echo "*** gl_generate_var is not set correctly" 1>&2; exit 1 ;;
|
---|
1000 | esac
|
---|
1001 | AC_SUBST(gl_header_name)
|
---|
1002 | gl_CONDITIONAL(gl_generate_cond, [$gl_generate_var])
|
---|
1003 | m4_popdef([gl_generate_cond])
|
---|
1004 | m4_popdef([gl_generate_var])
|
---|
1005 | m4_popdef([gl_header_name])
|
---|
1006 | ])
|
---|
1007 |
|
---|
1008 | dnl Expands to some code for use in .c programs that, on native Windows, defines
|
---|
1009 | dnl the Microsoft deprecated alias function names to the underscore-prefixed
|
---|
1010 | dnl actual function names. With this macro, these function names are available
|
---|
1011 | dnl without linking with '-loldnames' and without generating warnings.
|
---|
1012 | dnl Usage: Use it after all system header files are included.
|
---|
1013 | dnl #include <...>
|
---|
1014 | dnl #include <...>
|
---|
1015 | dnl ]GL_MDA_DEFINES[
|
---|
1016 | dnl ...
|
---|
1017 | AC_DEFUN([GL_MDA_DEFINES],[
|
---|
1018 | AC_REQUIRE([_GL_MDA_DEFINES])
|
---|
1019 | [$gl_mda_defines]
|
---|
1020 | ])
|
---|
1021 | AC_DEFUN([_GL_MDA_DEFINES],
|
---|
1022 | [gl_mda_defines='
|
---|
1023 | #if defined _WIN32 && !defined __CYGWIN__
|
---|
1024 | #define access _access
|
---|
1025 | #define chdir _chdir
|
---|
1026 | #define chmod _chmod
|
---|
1027 | #define close _close
|
---|
1028 | #define creat _creat
|
---|
1029 | #define dup _dup
|
---|
1030 | #define dup2 _dup2
|
---|
1031 | #define ecvt _ecvt
|
---|
1032 | #define execl _execl
|
---|
1033 | #define execle _execle
|
---|
1034 | #define execlp _execlp
|
---|
1035 | #define execv _execv
|
---|
1036 | #define execve _execve
|
---|
1037 | #define execvp _execvp
|
---|
1038 | #define execvpe _execvpe
|
---|
1039 | #define fcloseall _fcloseall
|
---|
1040 | #define fcvt _fcvt
|
---|
1041 | #define fdopen _fdopen
|
---|
1042 | #define fileno _fileno
|
---|
1043 | #define gcvt _gcvt
|
---|
1044 | #define getcwd _getcwd
|
---|
1045 | #define getpid _getpid
|
---|
1046 | #define getw _getw
|
---|
1047 | #define isatty _isatty
|
---|
1048 | #define j0 _j0
|
---|
1049 | #define j1 _j1
|
---|
1050 | #define jn _jn
|
---|
1051 | #define lfind _lfind
|
---|
1052 | #define lsearch _lsearch
|
---|
1053 | #define lseek _lseek
|
---|
1054 | #define memccpy _memccpy
|
---|
1055 | #define mkdir _mkdir
|
---|
1056 | #define mktemp _mktemp
|
---|
1057 | #define open _open
|
---|
1058 | #define putenv _putenv
|
---|
1059 | #define putw _putw
|
---|
1060 | #define read _read
|
---|
1061 | #define rmdir _rmdir
|
---|
1062 | #define strdup _strdup
|
---|
1063 | #define swab _swab
|
---|
1064 | #define tempnam _tempnam
|
---|
1065 | #define tzset _tzset
|
---|
1066 | #define umask _umask
|
---|
1067 | #define unlink _unlink
|
---|
1068 | #define utime _utime
|
---|
1069 | #define wcsdup _wcsdup
|
---|
1070 | #define write _write
|
---|
1071 | #define y0 _y0
|
---|
1072 | #define y1 _y1
|
---|
1073 | #define yn _yn
|
---|
1074 | #endif
|
---|
1075 | '
|
---|
1076 | ])
|
---|