Commit f4f41baf authored by Tom Lane's avatar Tom Lane

Improve configure's check for ICU presence.

Without ICU's header files, "configure --with-icu" would succeed anyway,
at least when using the non-pkgconfig-based setup.  Then you got a bunch of
ugly failures at build.  Add an explicit header check to tighten that up.
parent 52f8a59d
...@@ -13910,17 +13910,27 @@ done ...@@ -13910,17 +13910,27 @@ done
if test "$with_icu" = yes; then if test "$with_icu" = yes; then
# ICU functions are macros, so we need to do this the long way. ac_save_CPPFLAGS=$CPPFLAGS
CPPFLAGS="$ICU_CFLAGS $CPPFLAGS"
# Verify we have ICU's header files
ac_fn_c_check_header_mongrel "$LINENO" "unicode/ucol.h" "ac_cv_header_unicode_ucol_h" "$ac_includes_default"
if test "x$ac_cv_header_unicode_ucol_h" = xyes; then :
else
as_fn_error $? "header file <unicode/ucol.h> is required for ICU" "$LINENO" 5
fi
# ucol_strcollUTF8() appeared in ICU 50.
# ucol_strcollUTF8() appeared in ICU 50, so check if we have it.
# ICU functions are macros, so we need to do this the long way.
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ucol_strcollUTF8" >&5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ucol_strcollUTF8" >&5
$as_echo_n "checking for ucol_strcollUTF8... " >&6; } $as_echo_n "checking for ucol_strcollUTF8... " >&6; }
if ${pgac_cv_func_ucol_strcollUTF8+:} false; then : if ${pgac_cv_func_ucol_strcollUTF8+:} false; then :
$as_echo_n "(cached) " >&6 $as_echo_n "(cached) " >&6
else else
ac_save_CPPFLAGS=$CPPFLAGS ac_save_LIBS=$LIBS
CPPFLAGS="$ICU_CFLAGS $CPPFLAGS"
ac_save_LIBS=$LIBS
LIBS="$ICU_LIBS $LIBS" LIBS="$ICU_LIBS $LIBS"
cat confdefs.h - <<_ACEOF >conftest.$ac_ext cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */ /* end confdefs.h. */
...@@ -13941,7 +13951,6 @@ else ...@@ -13941,7 +13951,6 @@ else
fi fi
rm -f core conftest.err conftest.$ac_objext \ rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext conftest$ac_exeext conftest.$ac_ext
CPPFLAGS=$ac_save_CPPFLAGS
LIBS=$ac_save_LIBS LIBS=$ac_save_LIBS
fi fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $pgac_cv_func_ucol_strcollUTF8" >&5 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $pgac_cv_func_ucol_strcollUTF8" >&5
...@@ -13951,6 +13960,8 @@ $as_echo "$pgac_cv_func_ucol_strcollUTF8" >&6; } ...@@ -13951,6 +13960,8 @@ $as_echo "$pgac_cv_func_ucol_strcollUTF8" >&6; }
$as_echo "#define HAVE_UCOL_STRCOLLUTF8 1" >>confdefs.h $as_echo "#define HAVE_UCOL_STRCOLLUTF8 1" >>confdefs.h
fi fi
CPPFLAGS=$ac_save_CPPFLAGS
fi fi
# Lastly, restore full LIBS list and check for readline/libedit symbols # Lastly, restore full LIBS list and check for readline/libedit symbols
......
...@@ -1655,13 +1655,17 @@ AC_CHECK_FUNCS([strtoll strtoq], [break]) ...@@ -1655,13 +1655,17 @@ AC_CHECK_FUNCS([strtoll strtoq], [break])
AC_CHECK_FUNCS([strtoull strtouq], [break]) AC_CHECK_FUNCS([strtoull strtouq], [break])
if test "$with_icu" = yes; then if test "$with_icu" = yes; then
# ICU functions are macros, so we need to do this the long way. ac_save_CPPFLAGS=$CPPFLAGS
CPPFLAGS="$ICU_CFLAGS $CPPFLAGS"
# Verify we have ICU's header files
AC_CHECK_HEADER(unicode/ucol.h, [],
[AC_MSG_ERROR([header file <unicode/ucol.h> is required for ICU])])
# ucol_strcollUTF8() appeared in ICU 50. # ucol_strcollUTF8() appeared in ICU 50, so check if we have it.
# ICU functions are macros, so we need to do this the long way.
AC_CACHE_CHECK([for ucol_strcollUTF8], [pgac_cv_func_ucol_strcollUTF8], AC_CACHE_CHECK([for ucol_strcollUTF8], [pgac_cv_func_ucol_strcollUTF8],
[ac_save_CPPFLAGS=$CPPFLAGS [ac_save_LIBS=$LIBS
CPPFLAGS="$ICU_CFLAGS $CPPFLAGS"
ac_save_LIBS=$LIBS
LIBS="$ICU_LIBS $LIBS" LIBS="$ICU_LIBS $LIBS"
AC_LINK_IFELSE([AC_LANG_PROGRAM( AC_LINK_IFELSE([AC_LANG_PROGRAM(
[#include <unicode/ucol.h> [#include <unicode/ucol.h>
...@@ -1669,11 +1673,12 @@ AC_LINK_IFELSE([AC_LANG_PROGRAM( ...@@ -1669,11 +1673,12 @@ AC_LINK_IFELSE([AC_LANG_PROGRAM(
[ucol_strcollUTF8(NULL, NULL, 0, NULL, 0, NULL);])], [ucol_strcollUTF8(NULL, NULL, 0, NULL, 0, NULL);])],
[pgac_cv_func_ucol_strcollUTF8=yes], [pgac_cv_func_ucol_strcollUTF8=yes],
[pgac_cv_func_ucol_strcollUTF8=no]) [pgac_cv_func_ucol_strcollUTF8=no])
CPPFLAGS=$ac_save_CPPFLAGS
LIBS=$ac_save_LIBS]) LIBS=$ac_save_LIBS])
if test "$pgac_cv_func_ucol_strcollUTF8" = yes ; then if test "$pgac_cv_func_ucol_strcollUTF8" = yes ; then
AC_DEFINE([HAVE_UCOL_STRCOLLUTF8], 1, [Define to 1 if you have the `ucol_strcollUTF8' function.]) AC_DEFINE([HAVE_UCOL_STRCOLLUTF8], 1, [Define to 1 if you have the `ucol_strcollUTF8' function.])
fi fi
CPPFLAGS=$ac_save_CPPFLAGS
fi fi
# Lastly, restore full LIBS list and check for readline/libedit symbols # Lastly, restore full LIBS list and check for readline/libedit symbols
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment