/[pcre]/code/trunk/configure.ac
ViewVC logotype

Diff of /code/trunk/configure.ac

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 415 by ph10, Sat Apr 11 14:22:17 2009 UTC revision 936 by ph10, Sat Feb 25 17:02:23 2012 UTC
# Line 1  Line 1 
1  dnl Process this file with autoconf to produce a configure script.  dnl Process this file with autoconf to produce a configure script.
2    
3  dnl NOTE FOR MAINTAINERS: Do not use major or minor version numbers with  dnl NOTE FOR MAINTAINERS: Do not use minor version numbers 08 or 09 because
4  dnl leading zeros, because they may be treated as octal constants. The  dnl the leading zeros may cause them to be treated as invalid octal constants
5  dnl PCRE_PRERELEASE feature is for identifying release candidates. It might  dnl if a PCRE user writes code that uses PCRE_MINOR as a number. There is now
6  dnl be defined as -RC2, for example. For real releases, it should be defined  dnl a check further down that throws an error if 08 or 09 are used.
7  dnl empty.  
8    dnl The PCRE_PRERELEASE feature is for identifying release candidates. It might
9  m4_define(pcre_major, [7])  dnl be defined as -RC2, for example. For real releases, it should be empty.
10  m4_define(pcre_minor, [9])  
11  m4_define(pcre_prerelease, [])  m4_define(pcre_major, [8])
12  m4_define(pcre_date, [2009-04-11])  m4_define(pcre_minor, [31])
13    m4_define(pcre_prerelease, [-RC1])
14    m4_define(pcre_date, [2012-02-012])
15    
16    # NOTE: The CMakeLists.txt file searches for the above variables in the first
17    # 50 lines of this file. Please update that if the variables above are moved.
18    
19  # Libtool shared library interface versions (current:revision:age)  # Libtool shared library interface versions (current:revision:age)
20  m4_define(libpcre_version, [0:1:0])  m4_define(libpcre_version, [1:0:0])
21    m4_define(libpcre16_version, [0:0:0])
22  m4_define(libpcreposix_version, [0:0:0])  m4_define(libpcreposix_version, [0:0:0])
23  m4_define(libpcrecpp_version, [0:0:0])  m4_define(libpcrecpp_version, [0:0:0])
24    
# Line 20  AC_PREREQ(2.57) Line 26  AC_PREREQ(2.57)
26  AC_INIT(PCRE, pcre_major.pcre_minor[]pcre_prerelease, , pcre)  AC_INIT(PCRE, pcre_major.pcre_minor[]pcre_prerelease, , pcre)
27  AC_CONFIG_SRCDIR([pcre.h.in])  AC_CONFIG_SRCDIR([pcre.h.in])
28  AM_INIT_AUTOMAKE([dist-bzip2 dist-zip])  AM_INIT_AUTOMAKE([dist-bzip2 dist-zip])
29    m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
30  AC_CONFIG_HEADERS(config.h)  AC_CONFIG_HEADERS(config.h)
31    
32    # This was added at the suggestion of libtoolize (03-Jan-10)
33    AC_CONFIG_MACRO_DIR([m4])
34    
35  # The default CFLAGS and CXXFLAGS in Autoconf are "-g -O2" for gcc and just  # The default CFLAGS and CXXFLAGS in Autoconf are "-g -O2" for gcc and just
36  # "-g" for any other compiler. There doesn't seem to be a standard way of  # "-g" for any other compiler. There doesn't seem to be a standard way of
37  # getting rid of the -g (which I don't think is needed for a production  # getting rid of the -g (which I don't think is needed for a production
# Line 63  fi Line 73  fi
73  # AC_PROG_CXX will return "g++" even if no c++ compiler is installed.  # AC_PROG_CXX will return "g++" even if no c++ compiler is installed.
74  # Check for that case, and just disable c++ code if g++ doesn't run.  # Check for that case, and just disable c++ code if g++ doesn't run.
75  AC_LANG_PUSH(C++)  AC_LANG_PUSH(C++)
76  AC_COMPILE_IFELSE(AC_LANG_PROGRAM([],[]),, CXX=""; CXXCP=""; CXXFLAGS="")  AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[])],, CXX=""; CXXCP=""; CXXFLAGS="")
77  AC_LANG_POP  AC_LANG_POP
78    
79    # Check for a 64-bit integer type
80    AC_TYPE_INT64_T
81    
82  AC_PROG_INSTALL  AC_PROG_INSTALL
83  AC_LIBTOOL_WIN32_DLL  AC_LIBTOOL_WIN32_DLL
84  AC_PROG_LIBTOOL  LT_INIT
85  AC_PROG_LN_S  AC_PROG_LN_S
86    
87  PCRE_MAJOR="pcre_major"  PCRE_MAJOR="pcre_major"
# Line 76  PCRE_MINOR="pcre_minor" Line 89  PCRE_MINOR="pcre_minor"
89  PCRE_PRERELEASE="pcre_prerelease"  PCRE_PRERELEASE="pcre_prerelease"
90  PCRE_DATE="pcre_date"  PCRE_DATE="pcre_date"
91    
92    if test "$PCRE_MINOR" = "08" -o "$PCRE_MINOR" = "09"
93    then
94      echo "***"
95      echo "*** Minor version number $PCRE_MINOR must not be used. ***"
96      echo "*** Use only 01 to 07 or 10 onwards, to avoid octal issues. ***"
97      echo "***"
98      exit 1
99    fi
100    
101  AC_SUBST(PCRE_MAJOR)  AC_SUBST(PCRE_MAJOR)
102  AC_SUBST(PCRE_MINOR)  AC_SUBST(PCRE_MINOR)
103  AC_SUBST(PCRE_PRERELEASE)  AC_SUBST(PCRE_PRERELEASE)
# Line 87  then Line 109  then
109    htmldir='${docdir}/html'    htmldir='${docdir}/html'
110  fi  fi
111    
112  # Handle --disable-cpp  # Handle --disable-pcre8 (enabled by default)
113    AC_ARG_ENABLE(pcre8,
114                  AS_HELP_STRING([--disable-pcre8],
115                                 [disable 8 bit character support]),
116                  , enable_pcre8=unset)
117    AC_SUBST(enable_pcre8)
118    
119    # Handle --enable-pcre16 (disabled by default)
120    AC_ARG_ENABLE(pcre16,
121                  AS_HELP_STRING([--enable-pcre16],
122                                 [enable 16 bit character support]),
123                  , enable_pcre16=unset)
124    AC_SUBST(enable_pcre16)
125    
126    # Handle --disable-cpp. The substitution of enable_cpp is needed for use in
127    # pcre-config.
128  AC_ARG_ENABLE(cpp,  AC_ARG_ENABLE(cpp,
129                AS_HELP_STRING([--disable-cpp],                AS_HELP_STRING([--disable-cpp],
130                               [disable C++ support]),                               [disable C++ support]),
131                , enable_cpp=yes)                , enable_cpp=unset)
132    AC_SUBST(enable_cpp)
133    
134    # Handle --enable-jit (disabled by default)
135    AC_ARG_ENABLE(jit,
136                  AS_HELP_STRING([--enable-jit],
137                                 [enable Just-In-Time compiling support]),
138                  , enable_jit=no)
139    
140    # Handle --disable-pcregrep-jit (enabled by default)
141    AC_ARG_ENABLE(pcregrep-jit,
142                  AS_HELP_STRING([--disable-pcregrep-jit],
143                                 [disable JIT support in pcregrep]),
144                  , enable_pcregrep_jit=yes)
145    
146  # Handle --enable-rebuild-chartables  # Handle --enable-rebuild-chartables
147  AC_ARG_ENABLE(rebuild-chartables,  AC_ARG_ENABLE(rebuild-chartables,
# Line 102  AC_ARG_ENABLE(rebuild-chartables, Line 152  AC_ARG_ENABLE(rebuild-chartables,
152  # Handle --enable-utf8 (disabled by default)  # Handle --enable-utf8 (disabled by default)
153  AC_ARG_ENABLE(utf8,  AC_ARG_ENABLE(utf8,
154                AS_HELP_STRING([--enable-utf8],                AS_HELP_STRING([--enable-utf8],
155                               [enable UTF-8 support (incompatible with --enable-ebcdic)]),                               [another name for --enable-utf. Kept only for compatibility reasons]),
156                , enable_utf8=unset)                , enable_utf8=unset)
157    
158    # Handle --enable-utf (disabled by default)
159    AC_ARG_ENABLE(utf,
160                  AS_HELP_STRING([--enable-utf],
161                                 [enable UTF-8/16 support (incompatible with --enable-ebcdic)]),
162                  , enable_utf=unset)
163    
164  # Handle --enable-unicode-properties  # Handle --enable-unicode-properties
165  AC_ARG_ENABLE(unicode-properties,  AC_ARG_ENABLE(unicode-properties,
166                AS_HELP_STRING([--enable-unicode-properties],                AS_HELP_STRING([--enable-unicode-properties],
167                               [enable Unicode properties support (implies --enable-utf8)]),                               [enable Unicode properties support (implies --enable-utf)]),
168                , enable_unicode_properties=no)                , enable_unicode_properties=no)
169    
170  # Handle --enable-newline=NL  # Handle --enable-newline=NL
# Line 150  AC_ARG_ENABLE(bsr-anycrlf, Line 206  AC_ARG_ENABLE(bsr-anycrlf,
206  # Handle --enable-ebcdic  # Handle --enable-ebcdic
207  AC_ARG_ENABLE(ebcdic,  AC_ARG_ENABLE(ebcdic,
208                AS_HELP_STRING([--enable-ebcdic],                AS_HELP_STRING([--enable-ebcdic],
209                               [assume EBCDIC coding rather than ASCII; incompatible with --enable-utf8; use only in (uncommon) EBCDIC environments; it implies --enable-rebuild-chartables]),                               [assume EBCDIC coding rather than ASCII; incompatible with --enable-utf; use only in (uncommon) EBCDIC environments; it implies --enable-rebuild-chartables]),
210                , enable_ebcdic=no)                , enable_ebcdic=no)
211    
212  # Handle --disable-stack-for-recursion  # Handle --disable-stack-for-recursion
# Line 171  AC_ARG_ENABLE(pcregrep-libbz2, Line 227  AC_ARG_ENABLE(pcregrep-libbz2,
227                               [link pcregrep with libbz2 to handle .bz2 files]),                               [link pcregrep with libbz2 to handle .bz2 files]),
228                , enable_pcregrep_libbz2=no)                , enable_pcregrep_libbz2=no)
229    
230    # Handle --with-pcregrep-bufsize=N
231    AC_ARG_WITH(pcregrep-bufsize,
232                  AS_HELP_STRING([--with-pcregrep-bufsize=N],
233                                 [pcregrep buffer size (default=20480)]),
234                  , with_pcregrep_bufsize=20480)
235    
236    # Handle --enable-pcretest-libedit
237    AC_ARG_ENABLE(pcretest-libedit,
238                  AS_HELP_STRING([--enable-pcretest-libedit],
239                                 [link pcretest with libedit]),
240                  , enable_pcretest_libedit=no)
241    
242  # Handle --enable-pcretest-libreadline  # Handle --enable-pcretest-libreadline
243  AC_ARG_ENABLE(pcretest-libreadline,  AC_ARG_ENABLE(pcretest-libreadline,
244                AS_HELP_STRING([--enable-pcretest-libreadline],                AS_HELP_STRING([--enable-pcretest-libreadline],
# Line 208  AC_ARG_WITH(match-limit-recursion, Line 276  AC_ARG_WITH(match-limit-recursion,
276                             [default limit on internal recursion (default=MATCH_LIMIT)]),                             [default limit on internal recursion (default=MATCH_LIMIT)]),
277              , with_match_limit_recursion=MATCH_LIMIT)              , with_match_limit_recursion=MATCH_LIMIT)
278    
279  # Make sure that if enable_unicode_properties was set, that UTF-8 support  # Copy enable_utf8 value to enable_utf for compatibility reasons
280  # is enabled.  if test "x$enable_utf8" != "xunset"
281  #  then
282      if test "x$enable_utf" != "xunset"
283      then
284        AC_MSG_ERROR([--enable/disable-utf8 is kept only for compatibility reasons and its value is copied to --enable/disable-utf. Newer code must use --enable/disable-utf alone.])
285      fi
286      enable_utf=$enable_utf8
287    fi
288    
289    # Set the default value for pcre8
290    if test "x$enable_pcre8" = "xunset"
291    then
292      enable_pcre8=yes
293    fi
294    
295    # Set the default value for pcre16
296    if test "x$enable_pcre16" = "xunset"
297    then
298      enable_pcre16=no
299    fi
300    
301    # Make sure enable_pcre8 or enable_pcre16 was set
302    if test "x$enable_pcre8$enable_pcre16" = "xnono"
303    then
304      AC_MSG_ERROR([Either 8 or 16 bit (or both) pcre library must be enabled])
305    fi
306    
307    # Make sure that if enable_unicode_properties was set, that UTF support is enabled.
308  if test "x$enable_unicode_properties" = "xyes"  if test "x$enable_unicode_properties" = "xyes"
309  then  then
310    if test "x$enable_utf8" = "xno"    if test "x$enable_utf" = "xno"
311    then    then
312      AC_MSG_ERROR([support for Unicode properties requires UTF-8 support])      AC_MSG_ERROR([support for Unicode properties requires UTF-8/16 support])
313    fi    fi
314    enable_utf8=yes    enable_utf=yes
315    fi
316    
317    # enable_utf is disabled by default.
318    if test "x$enable_utf" = "xunset"
319    then
320      enable_utf=no
321  fi  fi
322    
323  if test "x$enable_utf8" = "xunset"  # enable_cpp copies the value of enable_pcre8 by default
324    if test "x$enable_cpp" = "xunset"
325  then  then
326    enable_utf8=no    enable_cpp=$enable_pcre8
327    fi
328    
329    # Make sure that if enable_cpp was set, that enable_pcre8 support is enabled
330    if test "x$enable_cpp" = "xyes"
331    then
332      if test "x$enable_pcre8" = "xno"
333      then
334        AC_MSG_ERROR([C++ library requires pcre library with 8 bit characters])
335      fi
336  fi  fi
337    
338  # Make sure that if enable_ebcdic is set, rebuild_chartables is also enabled.  # Make sure that if enable_ebcdic is set, rebuild_chartables is also enabled.
339  # Also check that UTF-8 support is not requested, because PCRE cannot handle  # Also check that UTF support is not requested, because PCRE cannot handle
340  # EBCDIC and UTF-8 in the same build. To do so it would need to use different  # EBCDIC and UTF in the same build. To do so it would need to use different
341  # character constants depending on the mode.  # character constants depending on the mode.
342  #  #
343  if test "x$enable_ebcdic" = "xyes"  if test "x$enable_ebcdic" = "xyes"
344  then  then
345    enable_rebuild_chartables=yes    enable_rebuild_chartables=yes
346    if test "x$enable_utf8" = "xyes"    if test "x$enable_utf" = "xyes"
347    then    then
348      AC_MSG_ERROR([support for EBCDIC and UTF-8 cannot be enabled at the same time])      AC_MSG_ERROR([support for EBCDIC and UTF-8/16 cannot be enabled at the same time])
349    fi    fi
350  fi  fi
351    
# Line 301  for flag in "-alias,__ZN7pcrecpp2RE6no_a Line 411  for flag in "-alias,__ZN7pcrecpp2RE6no_a
411    LDFLAGS="$OLD_LDFLAGS -Wl,$flag"    LDFLAGS="$OLD_LDFLAGS -Wl,$flag"
412    # We try to run the linker with this new ld flag.  If the link fails,    # We try to run the linker with this new ld flag.  If the link fails,
413    # we give up and remove the new flag from LDFLAGS.    # we give up and remove the new flag from LDFLAGS.
414    AC_LINK_IFELSE(AC_LANG_PROGRAM([namespace pcrecpp {    AC_LINK_IFELSE([AC_LANG_PROGRAM([namespace pcrecpp {
415                                      class RE { static int no_arg; };                                      class RE { static int no_arg; };
416                                      int RE::no_arg;                                      int RE::no_arg;
417                                    }],                                    }],
418                                   []),                                   [])],
419                   [AC_MSG_RESULT([yes]);                   [AC_MSG_RESULT([yes]);
420                    EXTRA_LIBPCRECPP_LDFLAGS="$EXTRA_LIBPCRECPP_LDFLAGS -Wl,$flag";                    EXTRA_LIBPCRECPP_LDFLAGS="$EXTRA_LIBPCRECPP_LDFLAGS -Wl,$flag";
421                    break;],                    break;],
# Line 323  AC_CHECK_HEADERS(bits/type_traits.h, [pc Line 433  AC_CHECK_HEADERS(bits/type_traits.h, [pc
433  AC_CHECK_HEADERS(type_traits.h, [pcre_have_type_traits="1"],  AC_CHECK_HEADERS(type_traits.h, [pcre_have_type_traits="1"],
434                                  [pcre_have_type_traits="0"])                                  [pcre_have_type_traits="0"])
435    
436    # (This isn't c++-specific, but is only used in pcrecpp.cc, so try this
437    # in a c++ context.  This matters becuase strtoimax is C99 and may not
438    # be supported by the C++ compiler.)
439    # Figure out how to create a longlong from a string: strtoll and
440    # equiv.  It's not enough to call AC_CHECK_FUNCS: hpux has a
441    # strtoll, for instance, but it only takes 2 args instead of 3!
442    # We have to call AH_TEMPLATE since AC_DEFINE_UNQUOTED below is complex.
443    AH_TEMPLATE(HAVE_STRTOQ, [Define to 1 if you have `strtoq'.])
444    AH_TEMPLATE(HAVE_STRTOLL, [Define to 1 if you have `strtoll'.])
445    AH_TEMPLATE(HAVE__STRTOI64, [Define to 1 if you have `_strtoi64'.])
446    AH_TEMPLATE(HAVE_STRTOIMAX, [Define to 1 if you have `strtoimax'.])
447    have_strto_fn=0
448    for fn in strtoq strtoll _strtoi64 strtoimax; do
449      AC_MSG_CHECKING([for $fn])
450      if test "$fn" = strtoimax; then
451        include=stdint.h
452      else
453        include=stdlib.h
454      fi
455      AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <$include>],
456                                        [char* e; return $fn("100", &e, 10)])],
457                        [AC_MSG_RESULT(yes)
458                         AC_DEFINE_UNQUOTED(HAVE_`echo $fn | tr abcdefghijklmnopqrstuvwxyz ABCDEFGHIJKLMNOPQRSTUVWXYZ`, 1,
459                                            [Define to 1 if you have `$fn'.])
460                         have_strto_fn=1
461                         break],
462                        [AC_MSG_RESULT(no)])
463    done
464    
465    if test "$have_strto_fn" = 1; then
466      AC_CHECK_TYPES([long long],
467                     [pcre_have_long_long="1"],
468                     [pcre_have_long_long="0"])
469      AC_CHECK_TYPES([unsigned long long],
470                     [pcre_have_ulong_long="1"],
471                     [pcre_have_ulong_long="0"])
472    else
473      pcre_have_long_long="0"
474      pcre_have_ulong_long="0"
475    fi
476    AC_SUBST(pcre_have_long_long)
477    AC_SUBST(pcre_have_ulong_long)
478    
479  AC_LANG_POP  AC_LANG_POP
480  fi  fi
481  # Using AC_SUBST eliminates the need to include config.h in a public .h file  # Using AC_SUBST eliminates the need to include config.h in a public .h file
# Line 330  AC_SUBST(pcre_have_type_traits) Line 483  AC_SUBST(pcre_have_type_traits)
483  AC_SUBST(pcre_have_bits_type_traits)  AC_SUBST(pcre_have_bits_type_traits)
484    
485  # Conditional compilation  # Conditional compilation
486    AM_CONDITIONAL(WITH_PCRE8, test "x$enable_pcre8" = "xyes")
487    AM_CONDITIONAL(WITH_PCRE16, test "x$enable_pcre16" = "xyes")
488  AM_CONDITIONAL(WITH_PCRE_CPP, test "x$enable_cpp" = "xyes")  AM_CONDITIONAL(WITH_PCRE_CPP, test "x$enable_cpp" = "xyes")
489  AM_CONDITIONAL(WITH_REBUILD_CHARTABLES, test "x$enable_rebuild_chartables" = "xyes")  AM_CONDITIONAL(WITH_REBUILD_CHARTABLES, test "x$enable_rebuild_chartables" = "xyes")
490    AM_CONDITIONAL(WITH_JIT, test "x$enable_jit" = "xyes")
491    AM_CONDITIONAL(WITH_UTF, test "x$enable_utf" = "xyes")
492    
493  # Checks for typedefs, structures, and compiler characteristics.  # Checks for typedefs, structures, and compiler characteristics.
494    
495  AC_C_CONST  AC_C_CONST
496  AC_TYPE_SIZE_T  AC_TYPE_SIZE_T
497    
 pcre_have_strotolonglong=0  
 AC_CHECK_FUNCS(strtoq strtoll _strtoi64, [pcre_have_strotolonglong="1"; break])  
 # If we can't convert a string to a long long, pretend we don't even  
 # have a long long.  
 if test $pcre_have_strotolonglong = "0"; then  
    pcre_have_long_long="0"  
    pcre_have_ulong_long="0"  
 else  
   AC_CHECK_TYPES([long long],  
                  [pcre_have_long_long="1"],  
                  [pcre_have_long_long="0"])  
   AC_CHECK_TYPES([unsigned long long],  
                  [pcre_have_ulong_long="1"],  
                  [pcre_have_ulong_long="0"])  
 fi  
 AC_SUBST(pcre_have_long_long)  
 AC_SUBST(pcre_have_ulong_long)  
   
498  # Checks for library functions.  # Checks for library functions.
499    
500  AC_CHECK_FUNCS(bcopy memmove strerror)  AC_CHECK_FUNCS(bcopy memmove strerror)
# Line 365  AC_CHECK_FUNCS(bcopy memmove strerror) Line 504  AC_CHECK_FUNCS(bcopy memmove strerror)
504  AC_CHECK_HEADERS([zlib.h], [HAVE_ZLIB_H=1])  AC_CHECK_HEADERS([zlib.h], [HAVE_ZLIB_H=1])
505  AC_CHECK_LIB([z], [gzopen], [HAVE_LIBZ=1])  AC_CHECK_LIB([z], [gzopen], [HAVE_LIBZ=1])
506    
507  # Check for the availability of libbz2  # Check for the availability of libbz2. Originally we just used AC_CHECK_LIB,
508    # as for libz. However, this had the following problem, diagnosed and fixed by
509    # a user:
510    #
511    #   - libbz2 uses the Pascal calling convention (WINAPI) for the functions
512    #     under Win32.
513    #   - The standard autoconf AC_CHECK_LIB fails to include "bzlib.h",
514    #     therefore missing the function definition.
515    #   - The compiler thus generates a "C" signature for the test function.
516    #   - The linker fails to find the "C" function.
517    #   - PCRE fails to configure if asked to do so against libbz2.
518    #
519    # Solution:
520    #
521    #   - Replace the AC_CHECK_LIB test with a custom test.
522    
523  AC_CHECK_HEADERS([bzlib.h], [HAVE_BZLIB_H=1])  AC_CHECK_HEADERS([bzlib.h], [HAVE_BZLIB_H=1])
524  AC_CHECK_LIB([bz2], [BZ2_bzopen], [HAVE_LIBBZ2=1])  # Original test
525    # AC_CHECK_LIB([bz2], [BZ2_bzopen], [HAVE_LIBBZ2=1])
526    #
527    # Custom test follows
528    
529    AC_MSG_CHECKING([for libbz2])
530    OLD_LIBS="$LIBS"
531    LIBS="$LIBS -lbz2"
532    AC_LINK_IFELSE([AC_LANG_PROGRAM([[
533    #ifdef HAVE_BZLIB_H
534    #include <bzlib.h>
535    #endif]],
536    [[return (int)BZ2_bzopen("conftest", "rb");]])],
537    [AC_MSG_RESULT([yes]);HAVE_LIBBZ2=1; break;],
538    AC_MSG_RESULT([no]))
539    LIBS="$OLD_LIBS"
540    
541  # Check for the availabiity of libreadline  # Check for the availabiity of libreadline
542    
543  AC_CHECK_HEADERS([readline/readline.h], [HAVE_READLINE_H=1])  if test "$enable_pcretest_libreadline" = "yes"; then
544  AC_CHECK_HEADERS([readline/history.h], [HAVE_HISTORY_H=1])   AC_CHECK_HEADERS([readline/readline.h], [HAVE_READLINE_H=1])
545  AC_CHECK_LIB([readline], [readline], [HAVE_LIB_READLINE=1])   AC_CHECK_HEADERS([readline/history.h], [HAVE_HISTORY_H=1])
546     AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-lreadline"],
547       [unset ac_cv_lib_readline_readline;
548        AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-ltinfo"],
549         [unset ac_cv_lib_readline_readline;
550          AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-lcurses"],
551           [unset ac_cv_lib_readline_readline;
552            AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-lncurses"],
553             [unset ac_cv_lib_readline_readline;
554              AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-lncursesw"],
555               [unset ac_cv_lib_readline_readline;
556                AC_CHECK_LIB([readline], [readline], [LIBREADLINE="-ltermcap"],
557                 [LIBREADLINE=""],
558                 [-ltermcap])],
559               [-lncursesw])],
560             [-lncurses])],
561           [-lcurses])],
562         [-ltinfo])])
563     AC_SUBST(LIBREADLINE)
564     if test -n "$LIBREADLINE"; then
565       if test "$LIBREADLINE" != "-lreadline"; then
566         echo "-lreadline needs $LIBREADLINE"
567         LIBREADLINE="-lreadline $LIBREADLINE"
568       fi
569     fi
570    fi
571    
572    
573    # Check for the availability of libedit
574    
575    if test "$enable_pcretest_libedit" = "yes"; then
576      AC_CHECK_HEADERS([editline/readline.h], [HAVE_EDITLINE_READLINE_H=1],
577        [AC_CHECK_HEADERS([readline/readline.h], [HAVE_READLINE_READLINE_H=1])])
578      AC_CHECK_LIB([edit], [readline], [LIBEDIT="-ledit"])
579    fi
580    
581  # This facilitates -ansi builds under Linux  # This facilitates -ansi builds under Linux
582  dnl AC_DEFINE([_GNU_SOURCE], [], [Enable GNU extensions in glibc])  dnl AC_DEFINE([_GNU_SOURCE], [], [Enable GNU extensions in glibc])
583    
584    PCRE_STATIC_CFLAG=""
585  if test "x$enable_shared" = "xno" ; then  if test "x$enable_shared" = "xno" ; then
586    AC_DEFINE([PCRE_STATIC], [1], [    AC_DEFINE([PCRE_STATIC], [1], [
587      Define if linking statically (TODO: make nice with Libtool)])      Define if linking statically (TODO: make nice with Libtool)])
588      PCRE_STATIC_CFLAG="-DPCRE_STATIC"
589  fi  fi
590    AC_SUBST(PCRE_STATIC_CFLAG)
591    
592  # Here is where pcre specific defines are handled  # Here is where pcre specific defines are handled
593    
594  if test "$enable_utf8" = "yes"; then  if test "$enable_pcre8" = "yes"; then
595    AC_DEFINE([SUPPORT_UTF8], [], [    AC_DEFINE([SUPPORT_PCRE8], [], [
596      Define to enable support for the UTF-8 Unicode encoding. This will      Define to enable the 8 bit PCRE library.])
597      work even in an EBCDIC environment, but it is incompatible with  fi
598      the EBCDIC macro. That is, PCRE can support *either* EBCDIC code  
599      *or* ASCII/UTF-8, but not both at once.])  if test "$enable_pcre16" = "yes"; then
600      AC_DEFINE([SUPPORT_PCRE16], [], [
601        Define to enable the 16 bit PCRE library.])
602    fi
603    
604    if test "$enable_jit" = "yes"; then
605      AC_DEFINE([SUPPORT_JIT], [], [
606        Define to enable support for Just-In-Time compiling.])
607    else
608      enable_pcregrep_jit="no"
609    fi
610    
611    if test "$enable_pcregrep_jit" = "yes"; then
612      AC_DEFINE([SUPPORT_PCREGREP_JIT], [], [
613        Define to enable JIT support in pcregrep.])
614    fi
615    
616    if test "$enable_utf" = "yes"; then
617      AC_DEFINE([SUPPORT_UTF], [], [
618        Define to enable support for the UTF-8/16 Unicode encoding. This
619        will work even in an EBCDIC environment, but it is incompatible
620        with the EBCDIC macro. That is, PCRE can support *either* EBCDIC
621        code *or* ASCII/UTF-8/16, but not both at once.])
622  fi  fi
623    
624  if test "$enable_unicode_properties" = "yes"; then  if test "$enable_unicode_properties" = "yes"; then
625    AC_DEFINE([SUPPORT_UCP], [], [    AC_DEFINE([SUPPORT_UCP], [], [
626      Define to enable support for Unicode properties])      Define to enable support for Unicode properties.])
627  fi  fi
628    
629  if test "$enable_stack_for_recursion" = "no"; then  if test "$enable_stack_for_recursion" = "no"; then
# Line 424  if test "$enable_pcregrep_libbz2" = "yes Line 651  if test "$enable_pcregrep_libbz2" = "yes
651      able to handle .bz2 files.])      able to handle .bz2 files.])
652  fi  fi
653    
654  if test "$enable_pcretest_libreadline" = "yes"; then  if test $with_pcregrep_bufsize -lt 8192 ; then
655      with_pcregrep_bufsize="8192"
656    fi
657    
658    AC_DEFINE_UNQUOTED([PCREGREP_BUFSIZE], [$with_pcregrep_bufsize], [
659      The value of PCREGREP_BUFSIZE determines the size of buffer used by
660      pcregrep to hold parts of the file it is searching. On systems that
661      support it, "configure" can be used to override the default, which is
662      8192. This is also the minimum value. The actual amount of memory used by
663      pcregrep is three times this number, because it allows for the buffering of
664      "before" and "after" lines.])
665    
666    if test "$enable_pcretest_libedit" = "yes"; then
667      AC_DEFINE([SUPPORT_LIBEDIT], [], [
668        Define to allow pcretest to be linked with libedit.])
669      LIBREADLINE="$LIBEDIT"
670    elif test "$enable_pcretest_libreadline" = "yes"; then
671    AC_DEFINE([SUPPORT_LIBREADLINE], [], [    AC_DEFINE([SUPPORT_LIBREADLINE], [], [
672      Define to allow pcretest to be linked with libreadline.])      Define to allow pcretest to be linked with libreadline.])
673  fi  fi
# Line 514  if test "$enable_ebcdic" = "yes"; then Line 757  if test "$enable_ebcdic" = "yes"; then
757      character codes, define this macro as 1. On systems that can use      character codes, define this macro as 1. On systems that can use
758      "configure", this can be done via --enable-ebcdic. PCRE will then      "configure", this can be done via --enable-ebcdic. PCRE will then
759      assume that all input strings are in EBCDIC. If you do not define      assume that all input strings are in EBCDIC. If you do not define
760      this macro, PCRE will assume input strings are ASCII or UTF-8 Unicode.      this macro, PCRE will assume input strings are ASCII or UTF-8/16
761      It is not possible to build a version of PCRE that supports both      Unicode. It is not possible to build a version of PCRE that
762      EBCDIC and UTF-8.])      supports both EBCDIC and UTF-8/16.])
763  fi  fi
764    
765  # Platform specific issues  # Platform specific issues
# Line 537  esac Line 780  esac
780  EXTRA_LIBPCRE_LDFLAGS="$EXTRA_LIBPCRE_LDFLAGS \  EXTRA_LIBPCRE_LDFLAGS="$EXTRA_LIBPCRE_LDFLAGS \
781                         $NO_UNDEFINED -version-info libpcre_version"                         $NO_UNDEFINED -version-info libpcre_version"
782    
783    EXTRA_LIBPCRE16_LDFLAGS="$EXTRA_LIBPCRE16_LDFLAGS \
784                           $NO_UNDEFINED -version-info libpcre16_version"
785    
786  EXTRA_LIBPCREPOSIX_LDFLAGS="$EXTRA_LIBPCREPOSIX_LDFLAGS \  EXTRA_LIBPCREPOSIX_LDFLAGS="$EXTRA_LIBPCREPOSIX_LDFLAGS \
787                              $NO_UNDEFINED -version-info libpcreposix_version"                              $NO_UNDEFINED -version-info libpcreposix_version"
788    
# Line 545  EXTRA_LIBPCRECPP_LDFLAGS="$EXTRA_LIBPCRE Line 791  EXTRA_LIBPCRECPP_LDFLAGS="$EXTRA_LIBPCRE
791                            $EXPORT_ALL_SYMBOLS"                            $EXPORT_ALL_SYMBOLS"
792    
793  AC_SUBST(EXTRA_LIBPCRE_LDFLAGS)  AC_SUBST(EXTRA_LIBPCRE_LDFLAGS)
794    AC_SUBST(EXTRA_LIBPCRE16_LDFLAGS)
795  AC_SUBST(EXTRA_LIBPCREPOSIX_LDFLAGS)  AC_SUBST(EXTRA_LIBPCREPOSIX_LDFLAGS)
796  AC_SUBST(EXTRA_LIBPCRECPP_LDFLAGS)  AC_SUBST(EXTRA_LIBPCRECPP_LDFLAGS)
797    
798  # When we run 'make distcheck', use these arguments.  # When we run 'make distcheck', use these arguments. Turning off compiler
799  DISTCHECK_CONFIGURE_FLAGS="--enable-cpp --enable-unicode-properties"  # optimization makes it run faster.
800    DISTCHECK_CONFIGURE_FLAGS="CFLAGS='' CXXFLAGS='' --enable-pcre16 --enable-jit --enable-cpp --enable-unicode-properties"
801  AC_SUBST(DISTCHECK_CONFIGURE_FLAGS)  AC_SUBST(DISTCHECK_CONFIGURE_FLAGS)
802    
803  # Check that, if --enable-pcregrep-libz or --enable-pcregrep-libbz2 is  # Check that, if --enable-pcregrep-libz or --enable-pcregrep-libbz2 is
# Line 583  AC_SUBST(LIBBZ2) Line 831  AC_SUBST(LIBBZ2)
831    
832  # Similarly for --enable-pcretest-readline  # Similarly for --enable-pcretest-readline
833    
834    if test "$enable_pcretest_libedit" = "yes"; then
835      if test "$enable_pcretest_libreadline" = "yes"; then
836        echo "** Cannot use both --enable-pcretest-libedit and --enable-pcretest-readline"
837        exit 1
838      fi
839      if test "$HAVE_EDITLINE_READLINE_H" != "1" -a \
840              "$HAVE_READLINE_READLINE_H" != "1"; then
841        echo "** Cannot --enable-pcretest-libedit because neither editline/readline.h"
842        echo "** nor readline/readline.h was found."
843        exit 1
844      fi
845      if test -z "$LIBEDIT"; then
846        echo "** Cannot --enable-pcretest-libedit because libedit library was not found."
847        exit 1
848      fi
849    fi
850    
851  if test "$enable_pcretest_libreadline" = "yes"; then  if test "$enable_pcretest_libreadline" = "yes"; then
852    if test "$HAVE_READLINE_H" != "1"; then    if test "$HAVE_READLINE_H" != "1"; then
853      echo "** Cannot --enable-pcretest-readline because readline/readline.h was not found."      echo "** Cannot --enable-pcretest-readline because readline/readline.h was not found."
# Line 592  if test "$enable_pcretest_libreadline" = Line 857  if test "$enable_pcretest_libreadline" =
857      echo "** Cannot --enable-pcretest-readline because readline/history.h was not found."      echo "** Cannot --enable-pcretest-readline because readline/history.h was not found."
858      exit 1      exit 1
859    fi    fi
860    LIBREADLINE="-lreadline"    if test -z "$LIBREADLINE"; then
861        echo "** Cannot --enable-pcretest-readline because readline library was not found."
862        exit 1
863      fi
864  fi  fi
 AC_SUBST(LIBREADLINE)  
865    
866  # Produce these files, in addition to config.h.  # Produce these files, in addition to config.h.
867  AC_CONFIG_FILES(  AC_CONFIG_FILES(
868          Makefile          Makefile
869          libpcre.pc          libpcre.pc
870            libpcre16.pc
871            libpcreposix.pc
872          libpcrecpp.pc          libpcrecpp.pc
873          pcre-config          pcre-config
874          pcre.h          pcre.h
# Line 635  $PACKAGE-$VERSION configuration summary: Line 904  $PACKAGE-$VERSION configuration summary:
904      Linker flags .................... : ${LDFLAGS}      Linker flags .................... : ${LDFLAGS}
905      Extra libraries ................. : ${LIBS}      Extra libraries ................. : ${LIBS}
906    
907        Build 8 bit pcre library ........ : ${enable_pcre8}
908        Build 16 bit pcre library ....... : ${enable_pcre16}
909      Build C++ library ............... : ${enable_cpp}      Build C++ library ............... : ${enable_cpp}
910      Enable UTF-8 support ............ : ${enable_utf8}      Enable JIT compiling support .... : ${enable_jit}
911        Enable UTF-8/16 support ......... : ${enable_utf}
912      Unicode properties .............. : ${enable_unicode_properties}      Unicode properties .............. : ${enable_unicode_properties}
913      Newline char/sequence ........... : ${enable_newline}      Newline char/sequence ........... : ${enable_newline}
914      \R matches only ANYCRLF ......... : ${enable_bsr_anycrlf}      \R matches only ANYCRLF ......... : ${enable_bsr_anycrlf}
# Line 649  $PACKAGE-$VERSION configuration summary: Line 921  $PACKAGE-$VERSION configuration summary:
921      Match limit recursion ........... : ${with_match_limit_recursion}      Match limit recursion ........... : ${with_match_limit_recursion}
922      Build shared libs ............... : ${enable_shared}      Build shared libs ............... : ${enable_shared}
923      Build static libs ............... : ${enable_static}      Build static libs ............... : ${enable_static}
924        Use JIT in pcregrep ............. : ${enable_pcregrep_jit}
925        Buffer size for pcregrep ........ : ${with_pcregrep_bufsize}
926      Link pcregrep with libz ......... : ${enable_pcregrep_libz}      Link pcregrep with libz ......... : ${enable_pcregrep_libz}
927      Link pcregrep with libbz2 ....... : ${enable_pcregrep_libbz2}      Link pcregrep with libbz2 ....... : ${enable_pcregrep_libbz2}
928        Link pcretest with libedit ...... : ${enable_pcretest_libedit}
929      Link pcretest with libreadline .. : ${enable_pcretest_libreadline}      Link pcretest with libreadline .. : ${enable_pcretest_libreadline}
930    
931  EOF  EOF

Legend:
Removed from v.415  
changed lines
  Added in v.936

webmaster@exim.org
ViewVC Help
Powered by ViewVC 1.1.12