xref: /aosp_15_r20/external/pcre/src/config.h.in (revision 22dc650d8ae982c6770746019a6f94af92b0f024)
1/* src/config.h.in.  Generated from configure.ac by autoheader.  */
2
3
4/* PCRE2 is written in Standard C, but there are a few non-standard things it
5can cope with, allowing it to run on SunOS4 and other "close to standard"
6systems.
7
8In environments that support the GNU autotools, config.h.in is converted into
9config.h by the "configure" script. In environments that use CMake,
10config-cmake.in is converted into config.h. If you are going to build PCRE2 "by
11hand" without using "configure" or CMake, you should copy the distributed
12config.h.generic to config.h, and edit the macro definitions to be the way you
13need them. You must then add -DHAVE_CONFIG_H to all of your compile commands,
14so that config.h is included at the start of every source.
15
16Alternatively, you can avoid editing by using -D on the compiler command line
17to set the macro values. In this case, you do not have to set -DHAVE_CONFIG_H,
18but if you do, default values will be taken from config.h for non-boolean
19macros that are not defined on the command line.
20
21Boolean macros such as HAVE_STDLIB_H and SUPPORT_PCRE2_8 should either be
22defined (conventionally to 1) for TRUE, and not defined at all for FALSE. All
23such macros are listed as a commented #undef in config.h.generic. Macros such
24as MATCH_LIMIT, whose actual value is relevant, have defaults defined, but are
25surrounded by #ifndef/#endif lines so that the value can be overridden by -D.
26
27PCRE2 uses memmove() if HAVE_MEMMOVE is defined; otherwise it uses bcopy() if
28HAVE_BCOPY is defined. If your system has neither bcopy() nor memmove(), make
29sure both macros are undefined; an emulation function will then be used. */
30
31/* By default, the \R escape sequence matches any Unicode line ending
32   character or sequence of characters. If BSR_ANYCRLF is defined (to any
33   value), this is changed so that backslash-R matches only CR, LF, or CRLF.
34   The build-time default can be overridden by the user of PCRE2 at runtime.
35   */
36#undef BSR_ANYCRLF
37
38/* Define to any value to disable the use of the z and t modifiers in
39   formatting settings such as %zu or %td (this is rarely needed). */
40#undef DISABLE_PERCENT_ZT
41
42/* If you are compiling for a system that uses EBCDIC instead of ASCII
43   character codes, define this macro to any value. When EBCDIC is set, PCRE2
44   assumes that all input strings are in EBCDIC. If you do not define this
45   macro, PCRE2 will assume input strings are ASCII or UTF-8/16/32 Unicode. It
46   is not possible to build a version of PCRE2 that supports both EBCDIC and
47   UTF-8/16/32. */
48#undef EBCDIC
49
50/* In an EBCDIC environment, define this macro to any value to arrange for the
51   NL character to be 0x25 instead of the default 0x15. NL plays the role that
52   LF does in an ASCII/Unicode environment. */
53#undef EBCDIC_NL25
54
55/* Define this if your compiler supports __attribute__((uninitialized)) */
56#undef HAVE_ATTRIBUTE_UNINITIALIZED
57
58/* Define to 1 if you have the 'bcopy' function. */
59#undef HAVE_BCOPY
60
61/* Define this if your compiler provides __builtin_mul_overflow() */
62#undef HAVE_BUILTIN_MUL_OVERFLOW
63
64/* Define to 1 if you have the <bzlib.h> header file. */
65#undef HAVE_BZLIB_H
66
67/* Define to 1 if you have the <dirent.h> header file. */
68#undef HAVE_DIRENT_H
69
70/* Define to 1 if you have the <dlfcn.h> header file. */
71#undef HAVE_DLFCN_H
72
73/* Define to 1 if you have the <editline/readline.h> header file. */
74#undef HAVE_EDITLINE_READLINE_H
75
76/* Define to 1 if you have the <edit/readline/readline.h> header file. */
77#undef HAVE_EDIT_READLINE_READLINE_H
78
79/* Define to 1 if you have the <inttypes.h> header file. */
80#undef HAVE_INTTYPES_H
81
82/* Define to 1 if you have the <limits.h> header file. */
83#undef HAVE_LIMITS_H
84
85/* Define to 1 if you have the 'memfd_create' function. */
86#undef HAVE_MEMFD_CREATE
87
88/* Define to 1 if you have the 'memmove' function. */
89#undef HAVE_MEMMOVE
90
91/* Define to 1 if you have the <minix/config.h> header file. */
92#undef HAVE_MINIX_CONFIG_H
93
94/* Define to 1 if you have the 'mkostemp' function. */
95#undef HAVE_MKOSTEMP
96
97/* Define if you have POSIX threads libraries and header files. */
98#undef HAVE_PTHREAD
99
100/* Have PTHREAD_PRIO_INHERIT. */
101#undef HAVE_PTHREAD_PRIO_INHERIT
102
103/* Define to 1 if you have the <readline.h> header file. */
104#undef HAVE_READLINE_H
105
106/* Define to 1 if you have the <readline/history.h> header file. */
107#undef HAVE_READLINE_HISTORY_H
108
109/* Define to 1 if you have the <readline/readline.h> header file. */
110#undef HAVE_READLINE_READLINE_H
111
112/* Define to 1 if you have the `realpath' function. */
113#undef HAVE_REALPATH
114
115/* Define to 1 if you have the 'secure_getenv' function. */
116#undef HAVE_SECURE_GETENV
117
118/* Define to 1 if you have the <stdint.h> header file. */
119#undef HAVE_STDINT_H
120
121/* Define to 1 if you have the <stdio.h> header file. */
122#undef HAVE_STDIO_H
123
124/* Define to 1 if you have the <stdlib.h> header file. */
125#undef HAVE_STDLIB_H
126
127/* Define to 1 if you have the 'strerror' function. */
128#undef HAVE_STRERROR
129
130/* Define to 1 if you have the <strings.h> header file. */
131#undef HAVE_STRINGS_H
132
133/* Define to 1 if you have the <string.h> header file. */
134#undef HAVE_STRING_H
135
136/* Define to 1 if you have the <sys/stat.h> header file. */
137#undef HAVE_SYS_STAT_H
138
139/* Define to 1 if you have the <sys/types.h> header file. */
140#undef HAVE_SYS_TYPES_H
141
142/* Define to 1 if you have the <sys/wait.h> header file. */
143#undef HAVE_SYS_WAIT_H
144
145/* Define to 1 if you have the <unistd.h> header file. */
146#undef HAVE_UNISTD_H
147
148/* Define to 1 if the compiler supports simple visibility declarations. */
149#undef HAVE_VISIBILITY
150
151/* Define to 1 if you have the <wchar.h> header file. */
152#undef HAVE_WCHAR_H
153
154/* Define to 1 if you have the <windows.h> header file. */
155#undef HAVE_WINDOWS_H
156
157/* Define to 1 if you have the <zlib.h> header file. */
158#undef HAVE_ZLIB_H
159
160/* This limits the amount of memory that may be used while matching a pattern.
161   It applies to both pcre2_match() and pcre2_dfa_match(). It does not apply
162   to JIT matching. The value is in kibibytes (units of 1024 bytes). */
163#undef HEAP_LIMIT
164
165/* The value of LINK_SIZE determines the number of bytes used to store links
166   as offsets within the compiled regex. The default is 2, which allows for
167   compiled patterns up to 65535 code units long. This covers the vast
168   majority of cases. However, PCRE2 can also be compiled to use 3 or 4 bytes
169   instead. This allows for longer patterns in extreme cases. */
170#undef LINK_SIZE
171
172/* Define to the sub-directory where libtool stores uninstalled libraries. */
173#undef LT_OBJDIR
174
175/* The value of MATCH_LIMIT determines the default number of times the
176   pcre2_match() function can record a backtrack position during a single
177   matching attempt. The value is also used to limit a loop counter in
178   pcre2_dfa_match(). There is a runtime interface for setting a different
179   limit. The limit exists in order to catch runaway regular expressions that
180   take forever to determine that they do not match. The default is set very
181   large so that it does not accidentally catch legitimate cases. */
182#undef MATCH_LIMIT
183
184/* The above limit applies to all backtracks, whether or not they are nested.
185   In some environments it is desirable to limit the nesting of backtracking
186   (that is, the depth of tree that is searched) more strictly, in order to
187   restrict the maximum amount of heap memory that is used. The value of
188   MATCH_LIMIT_DEPTH provides this facility. To have any useful effect, it
189   must be less than the value of MATCH_LIMIT. The default is to use the same
190   value as MATCH_LIMIT. There is a runtime method for setting a different
191   limit. In the case of pcre2_dfa_match(), this limit controls the depth of
192   the internal nested function calls that are used for pattern recursions,
193   lookarounds, and atomic groups. */
194#undef MATCH_LIMIT_DEPTH
195
196/* This limit is parameterized just in case anybody ever wants to change it.
197   Care must be taken if it is increased, because it guards against integer
198   overflow caused by enormously large patterns. */
199#undef MAX_NAME_COUNT
200
201/* This limit is parameterized just in case anybody ever wants to change it.
202   Care must be taken if it is increased, because it guards against integer
203   overflow caused by enormously large patterns. */
204#undef MAX_NAME_SIZE
205
206/* The value of MAX_VARLOOKBEHIND specifies the default maximum length, in
207   characters, for a variable-length lookbehind assertion. */
208#undef MAX_VARLOOKBEHIND
209
210/* Defining NEVER_BACKSLASH_C locks out the use of \C in all patterns. */
211#undef NEVER_BACKSLASH_C
212
213/* The value of NEWLINE_DEFAULT determines the default newline character
214   sequence. PCRE2 client programs can override this by selecting other values
215   at run time. The valid values are 1 (CR), 2 (LF), 3 (CRLF), 4 (ANY), 5
216   (ANYCRLF), and 6 (NUL). */
217#undef NEWLINE_DEFAULT
218
219/* Name of package */
220#undef PACKAGE
221
222/* Define to the address where bug reports for this package should be sent. */
223#undef PACKAGE_BUGREPORT
224
225/* Define to the full name of this package. */
226#undef PACKAGE_NAME
227
228/* Define to the full name and version of this package. */
229#undef PACKAGE_STRING
230
231/* Define to the one symbol short name of this package. */
232#undef PACKAGE_TARNAME
233
234/* Define to the home page for this package. */
235#undef PACKAGE_URL
236
237/* Define to the version of this package. */
238#undef PACKAGE_VERSION
239
240/* The value of PARENS_NEST_LIMIT specifies the maximum depth of nested
241   parentheses (of any kind) in a pattern. This limits the amount of system
242   stack that is used while compiling a pattern. */
243#undef PARENS_NEST_LIMIT
244
245/* The value of PCRE2GREP_BUFSIZE is the starting size of the buffer used by
246   pcre2grep to hold parts of the file it is searching. The buffer will be
247   expanded up to PCRE2GREP_MAX_BUFSIZE if necessary, for files containing
248   very long lines. The actual amount of memory used by pcre2grep is three
249   times this number, because it allows for the buffering of "before" and
250   "after" lines. */
251#undef PCRE2GREP_BUFSIZE
252
253/* The value of PCRE2GREP_MAX_BUFSIZE specifies the maximum size of the buffer
254   used by pcre2grep to hold parts of the file it is searching. The actual
255   amount of memory used by pcre2grep is three times this number, because it
256   allows for the buffering of "before" and "after" lines. */
257#undef PCRE2GREP_MAX_BUFSIZE
258
259/* Define to any value to include debugging code. */
260#undef PCRE2_DEBUG
261
262/* to make a symbol visible */
263#undef PCRE2_EXPORT
264
265
266/* If you are compiling for a system other than a Unix-like system or
267   Win32, and it needs some magic to be inserted before the definition
268   of a function that is exported by the library, define this macro to
269   contain the relevant magic. If you do not define this macro, a suitable
270   __declspec value is used for Windows systems; in other environments
271   a compiler relevant "extern" is used with any "visibility" related
272   attributes from PCRE2_EXPORT included.
273   This macro apears at the start of every exported function that is part
274   of the external API. It does not appear on functions that are "external"
275   in the C sense, but which are internal to the library. */
276#undef PCRE2_EXP_DEFN
277
278/* Define to any value if linking statically (TODO: make nice with Libtool) */
279#undef PCRE2_STATIC
280
281/* Define to necessary symbol if this constant uses a non-standard name on
282   your system. */
283#undef PTHREAD_CREATE_JOINABLE
284
285/* Define to any non-zero number to enable support for SELinux compatible
286   executable memory allocator in JIT. Note that this will have no effect
287   unless SUPPORT_JIT is also defined. */
288#undef SLJIT_PROT_EXECUTABLE_ALLOCATOR
289
290/* Define to 1 if all of the C89 standard headers exist (not just the ones
291   required in a freestanding environment). This macro is provided for
292   backward compatibility; new code need not use it. */
293#undef STDC_HEADERS
294
295/* Define to any value to enable differential fuzzing support. */
296#undef SUPPORT_DIFF_FUZZ
297
298/* Define to any value to enable support for Just-In-Time compiling. */
299#undef SUPPORT_JIT
300
301/* Define to any value to allow pcre2grep to be linked with libbz2, so that it
302   is able to handle .bz2 files. */
303#undef SUPPORT_LIBBZ2
304
305/* Define to any value to allow pcre2test to be linked with libedit. */
306#undef SUPPORT_LIBEDIT
307
308/* Define to any value to allow pcre2test to be linked with libreadline. */
309#undef SUPPORT_LIBREADLINE
310
311/* Define to any value to allow pcre2grep to be linked with libz, so that it
312   is able to handle .gz files. */
313#undef SUPPORT_LIBZ
314
315/* Define to any value to enable callout script support in pcre2grep. */
316#undef SUPPORT_PCRE2GREP_CALLOUT
317
318/* Define to any value to enable fork support in pcre2grep callout scripts.
319   This will have no effect unless SUPPORT_PCRE2GREP_CALLOUT is also defined.
320   */
321#undef SUPPORT_PCRE2GREP_CALLOUT_FORK
322
323/* Define to any value to enable JIT support in pcre2grep. Note that this will
324   have no effect unless SUPPORT_JIT is also defined. */
325#undef SUPPORT_PCRE2GREP_JIT
326
327/* Define to any value to enable the 16 bit PCRE2 library. */
328#undef SUPPORT_PCRE2_16
329
330/* Define to any value to enable the 32 bit PCRE2 library. */
331#undef SUPPORT_PCRE2_32
332
333/* Define to any value to enable the 8 bit PCRE2 library. */
334#undef SUPPORT_PCRE2_8
335
336/* Define to any value to enable support for Unicode and UTF encoding. This
337   will work even in an EBCDIC environment, but it is incompatible with the
338   EBCDIC macro. That is, PCRE2 can support *either* EBCDIC code *or*
339   ASCII/Unicode, but not both at once. */
340#undef SUPPORT_UNICODE
341
342/* Define to any value for valgrind support to find invalid memory reads. */
343#undef SUPPORT_VALGRIND
344
345/* Enable extensions on AIX, Interix, z/OS.  */
346#ifndef _ALL_SOURCE
347# undef _ALL_SOURCE
348#endif
349/* Enable general extensions on macOS.  */
350#ifndef _DARWIN_C_SOURCE
351# undef _DARWIN_C_SOURCE
352#endif
353/* Enable general extensions on Solaris.  */
354#ifndef __EXTENSIONS__
355# undef __EXTENSIONS__
356#endif
357/* Enable GNU extensions on systems that have them.  */
358#ifndef _GNU_SOURCE
359# undef _GNU_SOURCE
360#endif
361/* Enable X/Open compliant socket functions that do not require linking
362   with -lxnet on HP-UX 11.11.  */
363#ifndef _HPUX_ALT_XOPEN_SOCKET_API
364# undef _HPUX_ALT_XOPEN_SOCKET_API
365#endif
366/* Identify the host operating system as Minix.
367   This macro does not affect the system headers' behavior.
368   A future release of Autoconf may stop defining this macro.  */
369#ifndef _MINIX
370# undef _MINIX
371#endif
372/* Enable general extensions on NetBSD.
373   Enable NetBSD compatibility extensions on Minix.  */
374#ifndef _NETBSD_SOURCE
375# undef _NETBSD_SOURCE
376#endif
377/* Enable OpenBSD compatibility extensions on NetBSD.
378   Oddly enough, this does nothing on OpenBSD.  */
379#ifndef _OPENBSD_SOURCE
380# undef _OPENBSD_SOURCE
381#endif
382/* Define to 1 if needed for POSIX-compatible behavior.  */
383#ifndef _POSIX_SOURCE
384# undef _POSIX_SOURCE
385#endif
386/* Define to 2 if needed for POSIX-compatible behavior.  */
387#ifndef _POSIX_1_SOURCE
388# undef _POSIX_1_SOURCE
389#endif
390/* Enable POSIX-compatible threading on Solaris.  */
391#ifndef _POSIX_PTHREAD_SEMANTICS
392# undef _POSIX_PTHREAD_SEMANTICS
393#endif
394/* Enable extensions specified by ISO/IEC TS 18661-5:2014.  */
395#ifndef __STDC_WANT_IEC_60559_ATTRIBS_EXT__
396# undef __STDC_WANT_IEC_60559_ATTRIBS_EXT__
397#endif
398/* Enable extensions specified by ISO/IEC TS 18661-1:2014.  */
399#ifndef __STDC_WANT_IEC_60559_BFP_EXT__
400# undef __STDC_WANT_IEC_60559_BFP_EXT__
401#endif
402/* Enable extensions specified by ISO/IEC TS 18661-2:2015.  */
403#ifndef __STDC_WANT_IEC_60559_DFP_EXT__
404# undef __STDC_WANT_IEC_60559_DFP_EXT__
405#endif
406/* Enable extensions specified by C23 Annex F.  */
407#ifndef __STDC_WANT_IEC_60559_EXT__
408# undef __STDC_WANT_IEC_60559_EXT__
409#endif
410/* Enable extensions specified by ISO/IEC TS 18661-4:2015.  */
411#ifndef __STDC_WANT_IEC_60559_FUNCS_EXT__
412# undef __STDC_WANT_IEC_60559_FUNCS_EXT__
413#endif
414/* Enable extensions specified by C23 Annex H and ISO/IEC TS 18661-3:2015.  */
415#ifndef __STDC_WANT_IEC_60559_TYPES_EXT__
416# undef __STDC_WANT_IEC_60559_TYPES_EXT__
417#endif
418/* Enable extensions specified by ISO/IEC TR 24731-2:2010.  */
419#ifndef __STDC_WANT_LIB_EXT2__
420# undef __STDC_WANT_LIB_EXT2__
421#endif
422/* Enable extensions specified by ISO/IEC 24747:2009.  */
423#ifndef __STDC_WANT_MATH_SPEC_FUNCS__
424# undef __STDC_WANT_MATH_SPEC_FUNCS__
425#endif
426/* Enable extensions on HP NonStop.  */
427#ifndef _TANDEM_SOURCE
428# undef _TANDEM_SOURCE
429#endif
430/* Enable X/Open extensions.  Define to 500 only if necessary
431   to make mbstate_t available.  */
432#ifndef _XOPEN_SOURCE
433# undef _XOPEN_SOURCE
434#endif
435
436
437/* Version number of package */
438#undef VERSION
439
440/* Number of bits in a file offset, on hosts where this is settable. */
441#undef _FILE_OFFSET_BITS
442
443/* Define to 1 on platforms where this makes off_t a 64-bit type. */
444#undef _LARGE_FILES
445
446/* Number of bits in time_t, on hosts where this is settable. */
447#undef _TIME_BITS
448
449/* Define to 1 on platforms where this makes time_t a 64-bit type. */
450#undef __MINGW_USE_VC2005_COMPAT
451
452/* Define to empty if 'const' does not conform to ANSI C. */
453#undef const
454
455/* Define to the type of a signed integer type of width exactly 64 bits if
456   such a type exists and the standard includes do not define it. */
457#undef int64_t
458
459/* Define as 'unsigned int' if <stddef.h> doesn't define. */
460#undef size_t
461