• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 to 1 if you have the <bzlib.h> header file. */
62#undef HAVE_BZLIB_H
63
64/* Define to 1 if you have the <dirent.h> header file. */
65#undef HAVE_DIRENT_H
66
67/* Define to 1 if you have the <dlfcn.h> header file. */
68#undef HAVE_DLFCN_H
69
70/* Define to 1 if you have the <editline/readline.h> header file. */
71#undef HAVE_EDITLINE_READLINE_H
72
73/* Define to 1 if you have the <edit/readline/readline.h> header file. */
74#undef HAVE_EDIT_READLINE_READLINE_H
75
76/* Define to 1 if you have the <inttypes.h> header file. */
77#undef HAVE_INTTYPES_H
78
79/* Define to 1 if you have the <limits.h> header file. */
80#undef HAVE_LIMITS_H
81
82/* Define to 1 if you have the `memfd_create' function. */
83#undef HAVE_MEMFD_CREATE
84
85/* Define to 1 if you have the `memmove' function. */
86#undef HAVE_MEMMOVE
87
88/* Define to 1 if you have the <minix/config.h> header file. */
89#undef HAVE_MINIX_CONFIG_H
90
91/* Define to 1 if you have the `mkostemp' function. */
92#undef HAVE_MKOSTEMP
93
94/* Define if you have POSIX threads libraries and header files. */
95#undef HAVE_PTHREAD
96
97/* Have PTHREAD_PRIO_INHERIT. */
98#undef HAVE_PTHREAD_PRIO_INHERIT
99
100/* Define to 1 if you have the <readline/history.h> header file. */
101#undef HAVE_READLINE_HISTORY_H
102
103/* Define to 1 if you have the <readline/readline.h> header file. */
104#undef HAVE_READLINE_READLINE_H
105
106/* Define to 1 if you have the `realpath' function. */
107#undef HAVE_REALPATH
108
109/* Define to 1 if you have the `secure_getenv' function. */
110#undef HAVE_SECURE_GETENV
111
112/* Define to 1 if you have the <stdint.h> header file. */
113#undef HAVE_STDINT_H
114
115/* Define to 1 if you have the <stdio.h> header file. */
116#undef HAVE_STDIO_H
117
118/* Define to 1 if you have the <stdlib.h> header file. */
119#undef HAVE_STDLIB_H
120
121/* Define to 1 if you have the `strerror' function. */
122#undef HAVE_STRERROR
123
124/* Define to 1 if you have the <strings.h> header file. */
125#undef HAVE_STRINGS_H
126
127/* Define to 1 if you have the <string.h> header file. */
128#undef HAVE_STRING_H
129
130/* Define to 1 if you have the <sys/stat.h> header file. */
131#undef HAVE_SYS_STAT_H
132
133/* Define to 1 if you have the <sys/types.h> header file. */
134#undef HAVE_SYS_TYPES_H
135
136/* Define to 1 if you have the <sys/wait.h> header file. */
137#undef HAVE_SYS_WAIT_H
138
139/* Define to 1 if you have the <unistd.h> header file. */
140#undef HAVE_UNISTD_H
141
142/* Define to 1 if the compiler supports simple visibility declarations. */
143#undef HAVE_VISIBILITY
144
145/* Define to 1 if you have the <wchar.h> header file. */
146#undef HAVE_WCHAR_H
147
148/* Define to 1 if you have the <windows.h> header file. */
149#undef HAVE_WINDOWS_H
150
151/* Define to 1 if you have the <zlib.h> header file. */
152#undef HAVE_ZLIB_H
153
154/* This limits the amount of memory that may be used while matching a pattern.
155   It applies to both pcre2_match() and pcre2_dfa_match(). It does not apply
156   to JIT matching. The value is in kibibytes (units of 1024 bytes). */
157#undef HEAP_LIMIT
158
159/* The value of LINK_SIZE determines the number of bytes used to store links
160   as offsets within the compiled regex. The default is 2, which allows for
161   compiled patterns up to 65535 code units long. This covers the vast
162   majority of cases. However, PCRE2 can also be compiled to use 3 or 4 bytes
163   instead. This allows for longer patterns in extreme cases. */
164#undef LINK_SIZE
165
166/* Define to the sub-directory where libtool stores uninstalled libraries. */
167#undef LT_OBJDIR
168
169/* The value of MATCH_LIMIT determines the default number of times the
170   pcre2_match() function can record a backtrack position during a single
171   matching attempt. The value is also used to limit a loop counter in
172   pcre2_dfa_match(). There is a runtime interface for setting a different
173   limit. The limit exists in order to catch runaway regular expressions that
174   take for ever to determine that they do not match. The default is set very
175   large so that it does not accidentally catch legitimate cases. */
176#undef MATCH_LIMIT
177
178/* The above limit applies to all backtracks, whether or not they are nested.
179   In some environments it is desirable to limit the nesting of backtracking
180   (that is, the depth of tree that is searched) more strictly, in order to
181   restrict the maximum amount of heap memory that is used. The value of
182   MATCH_LIMIT_DEPTH provides this facility. To have any useful effect, it
183   must be less than the value of MATCH_LIMIT. The default is to use the same
184   value as MATCH_LIMIT. There is a runtime method for setting a different
185   limit. In the case of pcre2_dfa_match(), this limit controls the depth of
186   the internal nested function calls that are used for pattern recursions,
187   lookarounds, and atomic groups. */
188#undef MATCH_LIMIT_DEPTH
189
190/* This limit is parameterized just in case anybody ever wants to change it.
191   Care must be taken if it is increased, because it guards against integer
192   overflow caused by enormously large patterns. */
193#undef MAX_NAME_COUNT
194
195/* This limit is parameterized just in case anybody ever wants to change it.
196   Care must be taken if it is increased, because it guards against integer
197   overflow caused by enormously large patterns. */
198#undef MAX_NAME_SIZE
199
200/* Defining NEVER_BACKSLASH_C locks out the use of \C in all patterns. */
201#undef NEVER_BACKSLASH_C
202
203/* The value of NEWLINE_DEFAULT determines the default newline character
204   sequence. PCRE2 client programs can override this by selecting other values
205   at run time. The valid values are 1 (CR), 2 (LF), 3 (CRLF), 4 (ANY), 5
206   (ANYCRLF), and 6 (NUL). */
207#undef NEWLINE_DEFAULT
208
209/* Name of package */
210#undef PACKAGE
211
212/* Define to the address where bug reports for this package should be sent. */
213#undef PACKAGE_BUGREPORT
214
215/* Define to the full name of this package. */
216#undef PACKAGE_NAME
217
218/* Define to the full name and version of this package. */
219#undef PACKAGE_STRING
220
221/* Define to the one symbol short name of this package. */
222#undef PACKAGE_TARNAME
223
224/* Define to the home page for this package. */
225#undef PACKAGE_URL
226
227/* Define to the version of this package. */
228#undef PACKAGE_VERSION
229
230/* The value of PARENS_NEST_LIMIT specifies the maximum depth of nested
231   parentheses (of any kind) in a pattern. This limits the amount of system
232   stack that is used while compiling a pattern. */
233#undef PARENS_NEST_LIMIT
234
235/* The value of PCRE2GREP_BUFSIZE is the starting size of the buffer used by
236   pcre2grep to hold parts of the file it is searching. The buffer will be
237   expanded up to PCRE2GREP_MAX_BUFSIZE if necessary, for files containing
238   very long lines. The actual amount of memory used by pcre2grep is three
239   times this number, because it allows for the buffering of "before" and
240   "after" lines. */
241#undef PCRE2GREP_BUFSIZE
242
243/* The value of PCRE2GREP_MAX_BUFSIZE specifies the maximum size of the buffer
244   used by pcre2grep to hold parts of the file it is searching. The actual
245   amount of memory used by pcre2grep is three times this number, because it
246   allows for the buffering of "before" and "after" lines. */
247#undef PCRE2GREP_MAX_BUFSIZE
248
249/* to make a symbol visible */
250#undef PCRE2POSIX_EXP_DECL
251
252/* to make a symbol visible */
253#undef PCRE2POSIX_EXP_DEFN
254
255/* Define to any value to include debugging code. */
256#undef PCRE2_DEBUG
257
258/* to make a symbol visible */
259#undef PCRE2_EXP_DECL
260
261
262/* If you are compiling for a system other than a Unix-like system or
263   Win32, and it needs some magic to be inserted before the definition
264   of a function that is exported by the library, define this macro to
265   contain the relevant magic. If you do not define this macro, a suitable
266    __declspec value is used for Windows systems; in other environments
267   "extern" is used for a C compiler and "extern C" for a C++ compiler.
268   This macro apears at the start of every exported function that is part
269   of the external API. It does not appear on functions that are "external"
270   in the C sense, but which are internal to the library. */
271#undef PCRE2_EXP_DEFN
272
273/* Define to any value if linking statically (TODO: make nice with Libtool) */
274#undef PCRE2_STATIC
275
276/* Define to necessary symbol if this constant uses a non-standard name on
277   your system. */
278#undef PTHREAD_CREATE_JOINABLE
279
280/* Define to any non-zero number to enable support for SELinux compatible
281   executable memory allocator in JIT. Note that this will have no effect
282   unless SUPPORT_JIT is also defined. */
283#undef SLJIT_PROT_EXECUTABLE_ALLOCATOR
284
285/* Define to 1 if all of the C90 standard headers exist (not just the ones
286   required in a freestanding environment). This macro is provided for
287   backward compatibility; new code need not use it. */
288#undef STDC_HEADERS
289
290/* Define to any value to enable support for Just-In-Time compiling. */
291#undef SUPPORT_JIT
292
293/* Define to any value to allow pcre2grep to be linked with libbz2, so that it
294   is able to handle .bz2 files. */
295#undef SUPPORT_LIBBZ2
296
297/* Define to any value to allow pcre2test to be linked with libedit. */
298#undef SUPPORT_LIBEDIT
299
300/* Define to any value to allow pcre2test to be linked with libreadline. */
301#undef SUPPORT_LIBREADLINE
302
303/* Define to any value to allow pcre2grep to be linked with libz, so that it
304   is able to handle .gz files. */
305#undef SUPPORT_LIBZ
306
307/* Define to any value to enable callout script support in pcre2grep. */
308#undef SUPPORT_PCRE2GREP_CALLOUT
309
310/* Define to any value to enable fork support in pcre2grep callout scripts.
311   This will have no effect unless SUPPORT_PCRE2GREP_CALLOUT is also defined.
312   */
313#undef SUPPORT_PCRE2GREP_CALLOUT_FORK
314
315/* Define to any value to enable JIT support in pcre2grep. Note that this will
316   have no effect unless SUPPORT_JIT is also defined. */
317#undef SUPPORT_PCRE2GREP_JIT
318
319/* Define to any value to enable the 16 bit PCRE2 library. */
320#undef SUPPORT_PCRE2_16
321
322/* Define to any value to enable the 32 bit PCRE2 library. */
323#undef SUPPORT_PCRE2_32
324
325/* Define to any value to enable the 8 bit PCRE2 library. */
326#undef SUPPORT_PCRE2_8
327
328/* Define to any value to enable support for Unicode and UTF encoding. This
329   will work even in an EBCDIC environment, but it is incompatible with the
330   EBCDIC macro. That is, PCRE2 can support *either* EBCDIC code *or*
331   ASCII/Unicode, but not both at once. */
332#undef SUPPORT_UNICODE
333
334/* Define to any value for valgrind support to find invalid memory reads. */
335#undef SUPPORT_VALGRIND
336
337/* Enable extensions on AIX 3, Interix.  */
338#ifndef _ALL_SOURCE
339# undef _ALL_SOURCE
340#endif
341/* Enable general extensions on macOS.  */
342#ifndef _DARWIN_C_SOURCE
343# undef _DARWIN_C_SOURCE
344#endif
345/* Enable general extensions on Solaris.  */
346#ifndef __EXTENSIONS__
347# undef __EXTENSIONS__
348#endif
349/* Enable GNU extensions on systems that have them.  */
350#ifndef _GNU_SOURCE
351# undef _GNU_SOURCE
352#endif
353/* Enable X/Open compliant socket functions that do not require linking
354   with -lxnet on HP-UX 11.11.  */
355#ifndef _HPUX_ALT_XOPEN_SOCKET_API
356# undef _HPUX_ALT_XOPEN_SOCKET_API
357#endif
358/* Identify the host operating system as Minix.
359   This macro does not affect the system headers' behavior.
360   A future release of Autoconf may stop defining this macro.  */
361#ifndef _MINIX
362# undef _MINIX
363#endif
364/* Enable general extensions on NetBSD.
365   Enable NetBSD compatibility extensions on Minix.  */
366#ifndef _NETBSD_SOURCE
367# undef _NETBSD_SOURCE
368#endif
369/* Enable OpenBSD compatibility extensions on NetBSD.
370   Oddly enough, this does nothing on OpenBSD.  */
371#ifndef _OPENBSD_SOURCE
372# undef _OPENBSD_SOURCE
373#endif
374/* Define to 1 if needed for POSIX-compatible behavior.  */
375#ifndef _POSIX_SOURCE
376# undef _POSIX_SOURCE
377#endif
378/* Define to 2 if needed for POSIX-compatible behavior.  */
379#ifndef _POSIX_1_SOURCE
380# undef _POSIX_1_SOURCE
381#endif
382/* Enable POSIX-compatible threading on Solaris.  */
383#ifndef _POSIX_PTHREAD_SEMANTICS
384# undef _POSIX_PTHREAD_SEMANTICS
385#endif
386/* Enable extensions specified by ISO/IEC TS 18661-5:2014.  */
387#ifndef __STDC_WANT_IEC_60559_ATTRIBS_EXT__
388# undef __STDC_WANT_IEC_60559_ATTRIBS_EXT__
389#endif
390/* Enable extensions specified by ISO/IEC TS 18661-1:2014.  */
391#ifndef __STDC_WANT_IEC_60559_BFP_EXT__
392# undef __STDC_WANT_IEC_60559_BFP_EXT__
393#endif
394/* Enable extensions specified by ISO/IEC TS 18661-2:2015.  */
395#ifndef __STDC_WANT_IEC_60559_DFP_EXT__
396# undef __STDC_WANT_IEC_60559_DFP_EXT__
397#endif
398/* Enable extensions specified by ISO/IEC TS 18661-4:2015.  */
399#ifndef __STDC_WANT_IEC_60559_FUNCS_EXT__
400# undef __STDC_WANT_IEC_60559_FUNCS_EXT__
401#endif
402/* Enable extensions specified by ISO/IEC TS 18661-3:2015.  */
403#ifndef __STDC_WANT_IEC_60559_TYPES_EXT__
404# undef __STDC_WANT_IEC_60559_TYPES_EXT__
405#endif
406/* Enable extensions specified by ISO/IEC TR 24731-2:2010.  */
407#ifndef __STDC_WANT_LIB_EXT2__
408# undef __STDC_WANT_LIB_EXT2__
409#endif
410/* Enable extensions specified by ISO/IEC 24747:2009.  */
411#ifndef __STDC_WANT_MATH_SPEC_FUNCS__
412# undef __STDC_WANT_MATH_SPEC_FUNCS__
413#endif
414/* Enable extensions on HP NonStop.  */
415#ifndef _TANDEM_SOURCE
416# undef _TANDEM_SOURCE
417#endif
418/* Enable X/Open extensions.  Define to 500 only if necessary
419   to make mbstate_t available.  */
420#ifndef _XOPEN_SOURCE
421# undef _XOPEN_SOURCE
422#endif
423
424
425/* Version number of package */
426#undef VERSION
427
428/* Define to empty if `const' does not conform to ANSI C. */
429#undef const
430
431/* Define to the type of a signed integer type of width exactly 64 bits if
432   such a type exists and the standard includes do not define it. */
433#undef int64_t
434
435/* Define to `unsigned int' if <sys/types.h> does not define. */
436#undef size_t
437