Radix cross Linux

The main Radix cross Linux repository contains the build scripts of packages, which have the most complete and common functionality for desktop machines

452 Commits   2 Branches   1 Tag
   371         kx dnl -*- Mode: Autoconf; tab-width: 4; indent-tabs-mode: nil; fill-column: 100 -*-
   371         kx dnl configure.ac serves as input for the GNU autoconf package
   371         kx dnl in order to create a configure script.
   371         kx 
   371         kx # The version number in the second argument to AC_INIT should be four numbers separated by
   371         kx # periods. Some parts of the code requires the first one to be less than 128 and the others to be less
   371         kx # than 256. The four numbers can optionally be followed by a period and a free-form string containing
   371         kx # no spaces or periods, like "frobozz-mumble-42" or "alpha0". If the free-form string ends with one or
   371         kx # several non-alphanumeric characters, those are split off and used only for the
   371         kx # ABOUTBOXPRODUCTVERSIONSUFFIX in openoffice.lst. Why that is necessary, no idea.
   371         kx 
   371         kx AC_INIT([LibreOffice],[24.2.0.3],[],[],[http://documentfoundation.org/])
   371         kx 
   371         kx dnl libnumbertext needs autoconf 2.68, but that can pick up autoconf268 just fine if it is installed
   371         kx dnl whereas aclocal (as run by autogen.sh) insists on using autoconf and fails hard
   371         kx dnl so check for the version of autoconf that is actually used to create the configure script
   371         kx AC_PREREQ([2.59])
   371         kx m4_if(m4_version_compare(m4_defn([AC_AUTOCONF_VERSION]), [2.68]), -1,
   371         kx     [AC_MSG_ERROR([at least autoconf version 2.68 is needed (you can use AUTOCONF environment variable to point to a suitable one)])])
   371         kx 
   371         kx if test -n "$BUILD_TYPE"; then
   371         kx     AC_MSG_ERROR([You have sourced config_host.mk in this shell.  This may lead to trouble, please run in a fresh (login) shell.])
   371         kx fi
   371         kx 
   371         kx save_CC=$CC
   371         kx save_CXX=$CXX
   371         kx 
   371         kx first_arg_basename()
   371         kx {
   371         kx     for i in $1; do
   371         kx         basename "$i"
   371         kx         break
   371         kx     done
   371         kx }
   371         kx 
   371         kx CC_BASE=`first_arg_basename "$CC"`
   371         kx CXX_BASE=`first_arg_basename "$CXX"`
   371         kx 
   371         kx BUILD_TYPE="LibO"
   371         kx SCPDEFS=""
   371         kx GIT_NEEDED_SUBMODULES=""
   371         kx LO_PATH= # used by path_munge to construct a PATH variable
   371         kx 
   371         kx FilterLibs()
   371         kx {
   371         kx     # Return value: $filteredlibs
   371         kx 
   371         kx     filteredlibs=
   371         kx     if test "$COM" = "MSC"; then
   371         kx         for f in $1; do
   371         kx             if test "x$f" != "x${f#-L}"; then
   371         kx                 filteredlibs="$filteredlibs -LIBPATH:${f:2}"
   371         kx             elif test "x$f" != "x${f#-l}"; then
   371         kx                 filteredlibs="$filteredlibs ${f:2}.lib"
   371         kx             else
   371         kx                 filteredlibs="$filteredlibs $f"
   371         kx             fi
   371         kx         done
   371         kx     else
   371         kx         for f in $1; do
   371         kx             case "$f" in
   371         kx                 # let's start with Fedora's paths for now
   371         kx                 -L/lib|-L/lib/|-L/lib64|-L/lib64/|-L/usr/lib|-L/usr/lib/|-L/usr/lib64|-L/usr/lib64/)
   371         kx                     # ignore it: on UNIXoids it is searched by default anyway
   371         kx                     # but if it's given explicitly then it may override other paths
   371         kx                     # (on macOS it would be an error to use it instead of SDK)
   371         kx                     ;;
   371         kx                 *)
   371         kx                     filteredlibs="$filteredlibs $f"
   371         kx                     ;;
   371         kx             esac
   371         kx         done
   371         kx     fi
   371         kx }
   371         kx 
   371         kx PathFormat()
   371         kx {
   371         kx     # Args: $1: A pathname. On Cygwin and WSL, in either the Unix or the Windows format. Note that this
   371         kx     # function is called also on Unix.
   371         kx     #
   371         kx     # Return value: $formatted_path and $formatted_path_unix.
   371         kx     #
   371         kx     # $formatted_path is the argument in Windows format, but using forward slashes instead of
   371         kx     # backslashes, using 8.3 pathname components if necessary (if it otherwise would contains spaces
   371         kx     # or shell metacharacters).
   371         kx     #
   371         kx     # $formatted_path_unix is the argument in a form usable in Cygwin or WSL, using 8.3 components if
   371         kx     # necessary. On Cygwin, it is the same as $formatted_path, but on WSL it is $formatted_path as a
   371         kx     # Unix pathname.
   371         kx     #
   371         kx     # Errors out if 8.3 names are needed but aren't present for some of the path components.
   371         kx 
   371         kx     # Examples:
   371         kx     #
   371         kx     # /home/tml/lo/master-optimised => C:/cygwin64/home/tml/lo/master-optimised
   371         kx     #
   371         kx     # C:\Program Files (x86)\Microsoft Visual Studio\Installer\vswhere.exe => C:/PROGRA~2/MICROS~3/INSTAL~1/vswhere.exe
   371         kx     #
   371         kx     # C:\Program Files (x86)\Microsoft Visual Studio\2019\Community => C:/PROGRA~2/MICROS~3/2019/COMMUN~1
   371         kx     #
   371         kx     # C:/PROGRA~2/WI3CF2~1/10/Include/10.0.18362.0/ucrt => C:/PROGRA~2/WI3CF2~1/10/Include/10.0.18362.0/ucrt
   371         kx     #
   371         kx     # /cygdrive/c/PROGRA~2/WI3CF2~1/10 => C:/PROGRA~2/WI3CF2~1/10
   371         kx     #
   371         kx     # C:\Program Files (x86)\Windows Kits\NETFXSDK\4.8\ => C:/PROGRA~2/WI3CF2~1/NETFXSDK/4.8/
   371         kx     #
   371         kx     # /usr/bin/find.exe => C:/cygwin64/bin/find.exe
   371         kx 
   371         kx     if test -n "$UNITTEST_WSL_PATHFORMAT"; then
   371         kx         printf "PathFormat $1 ==> "
   371         kx     fi
   371         kx 
   371         kx     formatted_path="$1"
   371         kx     if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx         if test "$build_os" = "wsl"; then
   371         kx             formatted_path=$(echo "$formatted_path" | tr -d '\r')
   371         kx         fi
   371         kx 
   371         kx         pf_conv_to_dos=
   371         kx         # spaces,parentheses,brackets,braces are problematic in pathname
   371         kx         # so are backslashes
   371         kx         case "$formatted_path" in
   371         kx             *\ * | *\)* | *\(* | *\{* | *\}* | *\[* | *\]* | *\\* )
   371         kx                 pf_conv_to_dos="yes"
   371         kx             ;;
   371         kx         esac
   371         kx         if test "$pf_conv_to_dos" = "yes"; then
   371         kx             if test "$build_os" = "wsl"; then
   371         kx                 case "$formatted_path" in
   371         kx                     /*)
   371         kx                         formatted_path=$(wslpath -w "$formatted_path")
   371         kx                         ;;
   371         kx                 esac
   371         kx                 formatted_path=$($WSL_LO_HELPER --8.3 "$formatted_path")
   371         kx             elif test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx                 formatted_path=`cygpath -sm "$formatted_path"`
   371         kx             else
   371         kx                 formatted_path=`cygpath -d "$formatted_path"`
   371         kx             fi
   371         kx             if test $? -ne 0;  then
   371         kx                 AC_MSG_ERROR([path conversion failed for "$1".])
   371         kx             fi
   371         kx         fi
   371         kx         fp_count_colon=`echo "$formatted_path" | $GREP -c "[:]"`
   371         kx         fp_count_slash=`echo "$formatted_path" | $GREP -c "[/]"`
   371         kx         if test "$fp_count_slash$fp_count_colon" != "00"; then
   371         kx             if test "$fp_count_colon" = "0"; then
   371         kx                 new_formatted_path=`realpath "$formatted_path"`
   371         kx                 if test $? -ne 0;  then
   371         kx                     AC_MSG_WARN([realpath failed for "$formatted_path", not necessarily a problem.])
   371         kx                 else
   371         kx                     formatted_path="$new_formatted_path"
   371         kx                 fi
   371         kx             fi
   371         kx             if test "$build_os" = "wsl"; then
   371         kx                 if test "$fp_count_colon" != "0"; then
   371         kx                     formatted_path=$(wslpath "$formatted_path")
   371         kx                     local final_slash=
   371         kx                     case "$formatted_path" in
   371         kx                         */)
   371         kx                             final_slash=/
   371         kx                             ;;
   371         kx                     esac
   371         kx                     formatted_path=$(wslpath -m $formatted_path)
   371         kx                     case "$formatted_path" in
   371         kx                         */)
   371         kx                             ;;
   371         kx                         *)
   371         kx                             formatted_path="$formatted_path"$final_slash
   371         kx                             ;;
   371         kx                     esac
   371         kx                 else
   371         kx                     formatted_path=$(wslpath -m "$formatted_path")
   371         kx                 fi
   371         kx             else
   371         kx                 formatted_path=`cygpath -m "$formatted_path"`
   371         kx             fi
   371         kx             if test $? -ne 0;  then
   371         kx                 AC_MSG_ERROR([path conversion failed for "$1".])
   371         kx             fi
   371         kx         fi
   371         kx         fp_count_space=`echo "$formatted_path" | $GREP -c "[ ]"`
   371         kx         if test "$fp_count_space" != "0"; then
   371         kx             AC_MSG_ERROR([converted path "$formatted_path" still contains spaces. Short filenames (8.3 filenames) support was disabled on this system?])
   371         kx         fi
   371         kx     fi
   371         kx     if test "$build_os" = "wsl"; then
   371         kx         # WSL can't run Windows binaries from Windows pathnames so we need a separate return value in Unix format
   371         kx         formatted_path_unix=$(wslpath "$formatted_path")
   371         kx     else
   371         kx         # But Cygwin can
   371         kx         formatted_path_unix="$formatted_path"
   371         kx     fi
   371         kx }
   371         kx 
   371         kx AbsolutePath()
   371         kx {
   371         kx     # There appears to be no simple and portable method to get an absolute and
   371         kx     # canonical path, so we try creating the directory if does not exist and
   371         kx     # utilizing the shell and pwd.
   371         kx 
   371         kx     # Args: $1: A possibly relative pathname
   371         kx     # Return value: $absolute_path
   371         kx 
   371         kx     # Convert to unix path, mkdir would treat c:/path as a relative path.
   371         kx     PathFormat "$1"
   371         kx     local rel="$formatted_path_unix"
   371         kx     absolute_path=""
   371         kx     test ! -e "$rel" && mkdir -p "$rel"
   371         kx     if test -d "$rel" ; then
   371         kx         cd "$rel" || AC_MSG_ERROR([absolute path resolution failed for "$rel".])
   371         kx         absolute_path="$(pwd)"
   371         kx         cd - > /dev/null
   371         kx     else
   371         kx         AC_MSG_ERROR([Failed to resolve absolute path.  "$rel" does not exist or is not a directory.])
   371         kx     fi
   371         kx }
   371         kx 
   371         kx WARNINGS_FILE=config.warn
   371         kx WARNINGS_FILE_FOR_BUILD=config.Build.warn
   371         kx rm -f "$WARNINGS_FILE" "$WARNINGS_FILE_FOR_BUILD"
   371         kx have_WARNINGS="no"
   371         kx add_warning()
   371         kx {
   371         kx     if test "$have_WARNINGS" = "no"; then
   371         kx         echo "*************************************" > "$WARNINGS_FILE"
   371         kx         have_WARNINGS="yes"
   371         kx         if which tput >/dev/null && test "`tput colors 2>/dev/null || echo 0`" -ge 8; then
   371         kx             dnl <esc> as actual byte (U+1b), [ escaped using quadrigraph @<:@
   371         kx             COLORWARN='*@<:@1;33;40m WARNING @<:@0m:'
   371         kx         else
   371         kx             COLORWARN="* WARNING :"
   371         kx         fi
   371         kx     fi
   371         kx     echo "$COLORWARN $@" >> "$WARNINGS_FILE"
   371         kx }
   371         kx 
   371         kx dnl Some Mac User have the bad habit of letting a lot of crap
   371         kx dnl accumulate in their PATH and even adding stuff in /usr/local/bin
   371         kx dnl that confuse the build.
   371         kx dnl For the ones that use LODE, let's be nice and protect them
   371         kx dnl from themselves
   371         kx 
   371         kx mac_sanitize_path()
   371         kx {
   371         kx     mac_path="$LODE_HOME/opt/bin:/usr/bin:/bin:/usr/sbin:/sbin"
   371         kx dnl a common but nevertheless necessary thing that may be in a fancy
   371         kx dnl path location is git, so make sure we have it
   371         kx     mac_git_path=`which git 2>/dev/null`
   371         kx     if test -n "$mac_git_path" -a -x "$mac_git_path" -a "$mac_git_path" != "/usr/bin/git" ; then
   371         kx         mac_path="$mac_path:`dirname $mac_git_path`"
   371         kx     fi
   371         kx dnl a not so common but nevertheless quite helpful thing that may be in a fancy
   371         kx dnl path location is gpg, so make sure we find it
   371         kx     mac_gpg_path=`which gpg 2>/dev/null`
   371         kx     if test -n "$mac_gpg_path" -a -x "$mac_gpg_path" -a "$mac_gpg_path" != "/usr/bin/gpg" ; then
   371         kx         mac_path="$mac_path:`dirname $mac_gpg_path`"
   371         kx     fi
   371         kx     PATH="$mac_path"
   371         kx     unset mac_path
   371         kx     unset mac_git_path
   371         kx     unset mac_gpg_path
   371         kx }
   371         kx 
   371         kx dnl semantically test a three digits version
   371         kx dnl $1 - $3 = minimal version
   371         kx dnl $4 - $6 = current version
   371         kx 
   371         kx check_semantic_version_three()
   371         kx {
   371         kx     test "$4" -gt "$1" \
   371         kx         -o \( "$4" -eq "$1" -a "$5" -gt "$2" \) \
   371         kx         -o \( "$4" -eq "$1" -a "$5" -eq "$2" -a "$6" -ge "$3" \)
   371         kx     return $?
   371         kx }
   371         kx 
   371         kx dnl calls check_semantic_version_three with digits in named variables $1_MAJOR, $1_MINOR, $1_TINY
   371         kx dnl $1 = current version prefix, e.g. EMSCRIPTEN => EMSCRIPTEN_
   371         kx dnl $2 = postfix to $1, e.g. MIN => EMSCRIPTEN_MIN_
   371         kx 
   371         kx check_semantic_version_three_prefixed()
   371         kx {
   371         kx     eval local MIN_MAJOR="\$${1}_${2}_MAJOR"
   371         kx     eval local MIN_MINOR="\$${1}_${2}_MINOR"
   371         kx     eval local MIN_TINY="\$${1}_${2}_TINY"
   371         kx     eval local CUR_MAJOR="\$${1}_MAJOR"
   371         kx     eval local CUR_MINOR="\$${1}_MINOR"
   371         kx     eval local CUR_TINY="\$${1}_TINY"
   371         kx     check_semantic_version_three $MIN_MAJOR $MIN_MINOR $MIN_TINY $CUR_MAJOR $CUR_MINOR $CUR_TINY
   371         kx     return $?
   371         kx }
   371         kx 
   371         kx echo "********************************************************************"
   371         kx echo "*"
   371         kx echo "*   Running ${PACKAGE_NAME} build configuration."
   371         kx echo "*"
   371         kx echo "********************************************************************"
   371         kx echo ""
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl checks build and host OSes
   371         kx dnl do this before argument processing to allow for platform dependent defaults
   371         kx dnl ===================================================================
   371         kx 
   371         kx # Check for WSL (version 2, at least). But if --host is explicitly specified (to really do build for
   371         kx # Linux on WSL) trust that.
   371         kx if test -z "$host" -a -z "$build" -a "`wslsys -v 2>/dev/null`" != ""; then
   371         kx     ac_cv_host="x86_64-pc-wsl"
   371         kx     ac_cv_host_cpu="x86_64"
   371         kx     ac_cv_host_os="wsl"
   371         kx     ac_cv_build="$ac_cv_host"
   371         kx     ac_cv_build_cpu="$ac_cv_host_cpu"
   371         kx     ac_cv_build_os="$ac_cv_host_os"
   371         kx 
   371         kx     # Emulation of Cygwin's cygpath command for WSL.
   371         kx     cygpath()
   371         kx     {
   371         kx         if test -n "$UNITTEST_WSL_CYGPATH"; then
   371         kx             echo -n cygpath "$@" "==> "
   371         kx         fi
   371         kx 
   371         kx         # Cygwin's real cygpath has a plethora of options but we use only a few here.
   371         kx         local args="$@"
   371         kx         local opt
   371         kx         local opt_d opt_m opt_u opt_w opt_l opt_s opt_p
   371         kx         OPTIND=1
   371         kx 
   371         kx         while getopts dmuwlsp opt; do
   371         kx             case "$opt" in
   371         kx                 \?)
   371         kx                     AC_MSG_ERROR([Unimplemented cygpath emulation option in invocation: cygpath $args])
   371         kx                     ;;
   371         kx                 ?)
   371         kx                     eval opt_$opt=yes
   371         kx                     ;;
   371         kx             esac
   371         kx         done
   371         kx 
   371         kx         shift $((OPTIND-1))
   371         kx 
   371         kx         if test $# -ne 1; then
   371         kx             AC_MSG_ERROR([Invalid cygpath emulation invocation: Pathname missing]);
   371         kx         fi
   371         kx 
   371         kx         local input="$1"
   371         kx 
   371         kx         local result
   371         kx 
   371         kx         if test -n "$opt_d" -o -n "$opt_m" -o -n "$opt_w"; then
   371         kx             # Print Windows path, possibly in 8.3 form (-d) or with forward slashes (-m)
   371         kx 
   371         kx             if test -n "$opt_u"; then
   371         kx                 AC_MSG_ERROR([Invalid cygpath invocation: Both Windows and Unix path output requested])
   371         kx             fi
   371         kx 
   371         kx             case "$input" in
   371         kx                 /mnt/*)
   371         kx                     # A Windows file in WSL format
   371         kx                     input=$(wslpath -w "$input")
   371         kx                     ;;
   371         kx                 [[a-zA-Z]]:\\* | \\* | [[a-zA-Z]]:/* | /*)
   371         kx                     # Already in Windows format
   371         kx                     ;;
   371         kx                 /*)
   371         kx                     input=$(wslpath -w "$input")
   371         kx                     ;;
   371         kx                 *)
   371         kx                     AC_MSG_ERROR([Invalid cygpath invocation: Path '$input' is not absolute])
   371         kx                     ;;
   371         kx             esac
   371         kx             if test -n "$opt_d" -o -n "$opt_s"; then
   371         kx                 input=$($WSL_LO_HELPER --8.3 "$input")
   371         kx             fi
   371         kx             if test -n "$opt_m"; then
   371         kx                 input="${input//\\//}"
   371         kx             fi
   371         kx             echo "$input"
   371         kx         else
   371         kx             # Print Unix path
   371         kx 
   371         kx             case "$input" in
   371         kx                 [[a-zA-Z]]:\\* | \\* | [[a-zA-Z]]:/* | /*)
   371         kx                     wslpath -u "$input"
   371         kx                     ;;
   371         kx                 /)
   371         kx                     echo "$input"
   371         kx                     ;;
   371         kx                 *)
   371         kx                     AC_MSG_ERROR([Invalid cygpath invocation: Path '$input' is not absolute])
   371         kx                     ;;
   371         kx             esac
   371         kx         fi
   371         kx     }
   371         kx 
   371         kx     if test -n "$UNITTEST_WSL_CYGPATH"; then
   371         kx         BUILDDIR=.
   371         kx 
   371         kx         # Nothing special with these file names, just arbitrary ones picked to test with
   371         kx         cygpath -d /usr/lib64/ld-linux-x86-64.so.2
   371         kx         cygpath -w /usr/lib64/ld-linux-x86-64.so.2
   371         kx         cygpath -m /usr/lib64/ld-linux-x86-64.so.2
   371         kx         cygpath -m -s /usr/lib64/ld-linux-x86-64.so.2
   371         kx         # At least on my machine for instance this file does have an 8.3 name
   371         kx         cygpath -d /mnt/c/windows/WindowsUpdate.log
   371         kx         # But for instance this one doesn't
   371         kx         cygpath -w /mnt/c/windows/system32/AboutSettingsHandlers.dll
   371         kx         cygpath -ws /mnt/c/windows/WindowsUpdate.log
   371         kx         cygpath -m /mnt/c/windows/system32/AboutSettingsHandlers.dll
   371         kx         cygpath -ms /mnt/c/windows/WindowsUpdate.log
   371         kx 
   371         kx         cygpath -u 'c:\windows\system32\AboutSettingsHandlers.dll'
   371         kx         cygpath -u 'c:/windows/system32/AboutSettingsHandlers.dll'
   371         kx 
   371         kx         exit 0
   371         kx     fi
   371         kx 
   371         kx     if test -z "$WSL_LO_HELPER"; then
   371         kx         if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/wsl-lo-helper" ; then
   371         kx             WSL_LO_HELPER="$LODE_HOME/opt/bin/wsl-lo-helper"
   371         kx         elif test -x "/opt/lo/bin/wsl-lo-helper"; then
   371         kx             WSL_LO_HELPER="/opt/lo/bin/wsl-lo-helper"
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$WSL_LO_HELPER"; then
   371         kx         AC_MSG_ERROR([wsl-lo-helper not found. See solenv/wsl/README.])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_CANONICAL_HOST
   371         kx AC_CANONICAL_BUILD
   371         kx 
   371         kx if test -n "$UNITTEST_WSL_PATHFORMAT"; then
   371         kx     BUILDDIR=.
   371         kx     GREP=grep
   371         kx 
   371         kx     # Use of PathFormat must be after AC_CANONICAL_BUILD above
   371         kx     PathFormat /
   371         kx     printf "$formatted_path , $formatted_path_unix\n"
   371         kx 
   371         kx     PathFormat $PWD
   371         kx     printf "$formatted_path , $formatted_path_unix\n"
   371         kx 
   371         kx     PathFormat "$PROGRAMFILESX86"
   371         kx     printf "$formatted_path , $formatted_path_unix\n"
   371         kx 
   371         kx     exit 0
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([for product name])
   371         kx PRODUCTNAME="AC_PACKAGE_NAME"
   371         kx if test -n "$with_product_name" -a "$with_product_name" != no; then
   371         kx     PRODUCTNAME="$with_product_name"
   371         kx fi
   371         kx if test "$enable_release_build" = "" -o "$enable_release_build" = "no"; then
   371         kx     PRODUCTNAME="${PRODUCTNAME}Dev"
   371         kx fi
   371         kx AC_MSG_RESULT([$PRODUCTNAME])
   371         kx AC_SUBST(PRODUCTNAME)
   371         kx PRODUCTNAME_WITHOUT_SPACES=$(printf %s "$PRODUCTNAME" | sed 's/ //g')
   371         kx AC_SUBST(PRODUCTNAME_WITHOUT_SPACES)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Our version is defined by the AC_INIT() at the top of this script.
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([for package version])
   371         kx if test -n "$with_package_version" -a "$with_package_version" != no; then
   371         kx     PACKAGE_VERSION="$with_package_version"
   371         kx fi
   371         kx AC_MSG_RESULT([$PACKAGE_VERSION])
   371         kx 
   371         kx set `echo "$PACKAGE_VERSION" | sed "s/\./ /g"`
   371         kx 
   371         kx LIBO_VERSION_MAJOR=$1
   371         kx LIBO_VERSION_MINOR=$2
   371         kx LIBO_VERSION_MICRO=$3
   371         kx LIBO_VERSION_PATCH=$4
   371         kx 
   371         kx LIBO_VERSION_SUFFIX=$5
   371         kx 
   371         kx # Split out LIBO_VERSION_SUFFIX_SUFFIX... horrible crack. But apparently wanted separately in
   371         kx # openoffice.lst as ABOUTBOXPRODUCTVERSIONSUFFIX. Note that the double brackets are for m4's sake,
   371         kx # they get undoubled before actually passed to sed.
   371         kx LIBO_VERSION_SUFFIX_SUFFIX=`echo "$LIBO_VERSION_SUFFIX" | sed -e 's/.*[[a-zA-Z0-9]]\([[^a-zA-Z0-9]]*\)$/\1/'`
   371         kx test -n "$LIBO_VERSION_SUFFIX_SUFFIX" && LIBO_VERSION_SUFFIX="${LIBO_VERSION_SUFFIX%${LIBO_VERSION_SUFFIX_SUFFIX}}"
   371         kx # LIBO_VERSION_SUFFIX, if non-empty, should include the period separator
   371         kx test -n "$LIBO_VERSION_SUFFIX" && LIBO_VERSION_SUFFIX=".$LIBO_VERSION_SUFFIX"
   371         kx 
   371         kx # The value for key CFBundleVersion in the Info.plist file must be a period-separated list of at most
   371         kx # three non-negative integers. Please find more information about CFBundleVersion at
   371         kx # https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleversion
   371         kx 
   371         kx # The value for key CFBundleShortVersionString in the Info.plist file must be a period-separated list
   371         kx # of at most three non-negative integers. Please find more information about
   371         kx # CFBundleShortVersionString at
   371         kx # https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring
   371         kx 
   371         kx # But that is enforced only in the App Store, and we apparently want to break the rules otherwise.
   371         kx 
   371         kx if test "$enable_macosx_sandbox" = yes; then
   371         kx     MACOSX_BUNDLE_SHORTVERSION=$LIBO_VERSION_MAJOR.$LIBO_VERSION_MINOR.`expr $LIBO_VERSION_MICRO '*' 1000 + $LIBO_VERSION_PATCH`
   371         kx     MACOSX_BUNDLE_VERSION=$MACOSX_BUNDLE_SHORTVERSION
   371         kx else
   371         kx     MACOSX_BUNDLE_SHORTVERSION=$LIBO_VERSION_MAJOR.$LIBO_VERSION_MINOR.$LIBO_VERSION_MICRO.$LIBO_VERSION_PATCH
   371         kx     MACOSX_BUNDLE_VERSION=$MACOSX_BUNDLE_SHORTVERSION$LIBO_VERSION_SUFFIX
   371         kx fi
   371         kx 
   371         kx AC_SUBST(LIBO_VERSION_MAJOR)
   371         kx AC_SUBST(LIBO_VERSION_MINOR)
   371         kx AC_SUBST(LIBO_VERSION_MICRO)
   371         kx AC_SUBST(LIBO_VERSION_PATCH)
   371         kx AC_SUBST(LIBO_VERSION_SUFFIX)
   371         kx AC_SUBST(LIBO_VERSION_SUFFIX_SUFFIX)
   371         kx AC_SUBST(MACOSX_BUNDLE_SHORTVERSION)
   371         kx AC_SUBST(MACOSX_BUNDLE_VERSION)
   371         kx 
   371         kx AC_DEFINE_UNQUOTED(LIBO_VERSION_MAJOR,$LIBO_VERSION_MAJOR)
   371         kx AC_DEFINE_UNQUOTED(LIBO_VERSION_MINOR,$LIBO_VERSION_MINOR)
   371         kx AC_DEFINE_UNQUOTED(LIBO_VERSION_MICRO,$LIBO_VERSION_MICRO)
   371         kx AC_DEFINE_UNQUOTED(LIBO_VERSION_PATCH,$LIBO_VERSION_PATCH)
   371         kx 
   371         kx git_date=`git log -1 --pretty=format:"%cd" --date=format:'%Y' 2>&/dev/null`
   371         kx LIBO_THIS_YEAR=${git_date:-2024}
   371         kx AC_DEFINE_UNQUOTED(LIBO_THIS_YEAR,$LIBO_THIS_YEAR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Product version
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([for product version])
   371         kx PRODUCTVERSION="$LIBO_VERSION_MAJOR.$LIBO_VERSION_MINOR"
   371         kx AC_MSG_RESULT([$PRODUCTVERSION])
   371         kx AC_SUBST(PRODUCTVERSION)
   371         kx 
   371         kx AC_PROG_EGREP
   371         kx # AC_PROG_EGREP doesn't set GREP on all systems as well
   371         kx AC_PATH_PROG(GREP, grep)
   371         kx 
   371         kx BUILDDIR=`pwd`
   371         kx cd $srcdir
   371         kx SRC_ROOT=`pwd`
   371         kx cd $BUILDDIR
   371         kx x_Cygwin=[\#]
   371         kx 
   371         kx dnl ======================================
   371         kx dnl Required GObject introspection version
   371         kx dnl ======================================
   371         kx INTROSPECTION_REQUIRED_VERSION=1.32.0
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Search all the common names for GNU Make
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([for GNU Make])
   371         kx 
   371         kx # try to use our own make if it is available and GNUMAKE was not already defined
   371         kx if test -z "$GNUMAKE"; then
   371         kx     if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/make" ; then
   371         kx         GNUMAKE="$LODE_HOME/opt/bin/make"
   371         kx     elif test -x "/opt/lo/bin/make"; then
   371         kx         GNUMAKE="/opt/lo/bin/make"
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx GNUMAKE_WIN_NATIVE=
   371         kx for a in "$MAKE" "$GNUMAKE" make gmake gnumake; do
   371         kx     if test -n "$a"; then
   371         kx         $a --version 2> /dev/null | grep GNU  2>&1 > /dev/null
   371         kx         if test $? -eq 0;  then
   371         kx             if test "$build_os" = "cygwin"; then
   371         kx                 if test -n "$($a -v | grep 'Built for Windows')" ; then
   371         kx                     GNUMAKE="$(cygpath -m "$(which "$(cygpath -u $a)")")"
   371         kx                     GNUMAKE_WIN_NATIVE="TRUE"
   371         kx                 else
   371         kx                     GNUMAKE=`which $a`
   371         kx                 fi
   371         kx             else
   371         kx                 GNUMAKE=`which $a`
   371         kx             fi
   371         kx             break
   371         kx         fi
   371         kx     fi
   371         kx done
   371         kx AC_MSG_RESULT($GNUMAKE)
   371         kx if test -z "$GNUMAKE"; then
   371         kx     AC_MSG_ERROR([not found. install GNU Make.])
   371         kx else
   371         kx     if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx         AC_MSG_NOTICE([Using a native Win32 GNU Make version.])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx win_short_path_for_make()
   371         kx {
   371         kx     local short_path="$1"
   371         kx     if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx         cygpath -sm "$short_path"
   371         kx     else
   371         kx         cygpath -u "$(cygpath -d "$short_path")"
   371         kx     fi
   371         kx }
   371         kx 
   371         kx 
   371         kx if test "$build_os" = "cygwin"; then
   371         kx     PathFormat "$SRC_ROOT"
   371         kx     SRC_ROOT="$formatted_path"
   371         kx     PathFormat "$BUILDDIR"
   371         kx     BUILDDIR="$formatted_path"
   371         kx     x_Cygwin=
   371         kx     AC_MSG_CHECKING(for explicit COMSPEC)
   371         kx     if test -z "$COMSPEC"; then
   371         kx         AC_MSG_ERROR([COMSPEC not set in environment, please set it and rerun])
   371         kx     else
   371         kx         AC_MSG_RESULT([found: $COMSPEC])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(SRC_ROOT)
   371         kx AC_SUBST(BUILDDIR)
   371         kx AC_SUBST(x_Cygwin)
   371         kx AC_DEFINE_UNQUOTED(SRCDIR,"$SRC_ROOT")
   371         kx AC_DEFINE_UNQUOTED(SRC_ROOT,"$SRC_ROOT")
   371         kx AC_DEFINE_UNQUOTED(BUILDDIR,"$BUILDDIR")
   371         kx 
   371         kx if test "z$EUID" = "z0" -a "`uname -o 2>/dev/null`" = "Cygwin"; then
   371         kx     AC_MSG_ERROR([You must build LibreOffice as a normal user - not using an administrative account])
   371         kx fi
   371         kx 
   371         kx # need sed in os checks...
   371         kx AC_PATH_PROGS(SED, sed)
   371         kx if test -z "$SED"; then
   371         kx     AC_MSG_ERROR([install sed to run this script])
   371         kx fi
   371         kx 
   371         kx # Set the ENABLE_LTO variable
   371         kx # ===================================================================
   371         kx AC_MSG_CHECKING([whether to use link-time optimization])
   371         kx if test -n "$enable_lto" -a "$enable_lto" != "no"; then
   371         kx     ENABLE_LTO="TRUE"
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     ENABLE_LTO=""
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_LTO)
   371         kx 
   371         kx AC_ARG_ENABLE(fuzz-options,
   371         kx     AS_HELP_STRING([--enable-fuzz-options],
   371         kx         [Randomly enable or disable each of those configurable options
   371         kx          that are supposed to be freely selectable without interdependencies,
   371         kx          or where bad interaction from interdependencies is automatically avoided.])
   371         kx )
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl When building for Android, --with-android-ndk,
   371         kx dnl --with-android-ndk-toolchain-version and --with-android-sdk are
   371         kx dnl mandatory
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_ARG_WITH(android-ndk,
   371         kx     AS_HELP_STRING([--with-android-ndk],
   371         kx         [Specify location of the Android Native Development Kit. Mandatory when building for Android.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(android-ndk-toolchain-version,
   371         kx     AS_HELP_STRING([--with-android-ndk-toolchain-version],
   371         kx         [Specify which toolchain version to use, of those present in the
   371         kx         Android NDK you are using. The default (and only supported version currently) is "clang5.0"]),,
   371         kx         with_android_ndk_toolchain_version=clang5.0)
   371         kx 
   371         kx AC_ARG_WITH(android-sdk,
   371         kx     AS_HELP_STRING([--with-android-sdk],
   371         kx         [Specify location of the Android SDK. Mandatory when building for Android.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(android-api-level,
   371         kx     AS_HELP_STRING([--with-android-api-level],
   371         kx         [Specify the API level when building for Android. Defaults to 16 for ARM and x86 and to 21 for ARM64 and x86-64]),
   371         kx ,)
   371         kx 
   371         kx ANDROID_NDK_DIR=
   371         kx if test -z "$with_android_ndk" -a -e "$SRC_ROOT/external/android-ndk" -a "$build" != "$host"; then
   371         kx     with_android_ndk="$SRC_ROOT/external/android-ndk"
   371         kx fi
   371         kx if test -n "$with_android_ndk"; then
   371         kx     eval ANDROID_NDK_DIR=$with_android_ndk
   371         kx 
   371         kx     ANDROID_API_LEVEL=21
   371         kx     if test -n "$with_android_api_level" ; then
   371         kx         ANDROID_API_LEVEL="$with_android_api_level"
   371         kx     fi
   371         kx 
   371         kx     if test $host_cpu = arm; then
   371         kx         LLVM_TRIPLE=armv7a-linux-androideabi
   371         kx         ANDROID_SYSROOT_PLATFORM=arm-linux-androideabi
   371         kx         ANDROID_APP_ABI=armeabi-v7a
   371         kx         ANDROIDCFLAGS="-mthumb -march=armv7-a -mfloat-abi=softfp -mfpu=neon -Wl,--fix-cortex-a8"
   371         kx     elif test $host_cpu = aarch64; then
   371         kx         LLVM_TRIPLE=aarch64-linux-android
   371         kx         ANDROID_SYSROOT_PLATFORM=$LLVM_TRIPLE
   371         kx         ANDROID_APP_ABI=arm64-v8a
   371         kx     elif test $host_cpu = x86_64; then
   371         kx         LLVM_TRIPLE=x86_64-linux-android
   371         kx         ANDROID_SYSROOT_PLATFORM=$LLVM_TRIPLE
   371         kx         ANDROID_APP_ABI=x86_64
   371         kx     else
   371         kx         # host_cpu is something like "i386" or "i686" I guess, NDK uses
   371         kx         # "x86" in some contexts
   371         kx         LLVM_TRIPLE=i686-linux-android
   371         kx         ANDROID_SYSROOT_PLATFORM=$LLVM_TRIPLE
   371         kx         ANDROID_APP_ABI=x86
   371         kx     fi
   371         kx 
   371         kx     # Set up a lot of pre-canned defaults
   371         kx 
   371         kx     if test ! -f $ANDROID_NDK_DIR/RELEASE.TXT; then
   371         kx         if test ! -f $ANDROID_NDK_DIR/source.properties; then
   371         kx             AC_MSG_ERROR([Unrecognized Android NDK. Missing RELEASE.TXT or source.properties file in $ANDROID_NDK_DIR.])
   371         kx         fi
   371         kx         ANDROID_NDK_VERSION=`sed -n -e 's/Pkg.Revision = //p' $ANDROID_NDK_DIR/source.properties`
   371         kx     else
   371         kx         ANDROID_NDK_VERSION=`cut -f1 -d' ' <$ANDROID_NDK_DIR/RELEASE.TXT`
   371         kx     fi
   371         kx     if test -z "$ANDROID_NDK_VERSION";  then
   371         kx         AC_MSG_ERROR([Failed to determine Android NDK version. Please check your installation.])
   371         kx     fi
   371         kx     case $ANDROID_NDK_VERSION in
   371         kx     r9*|r10*)
   371         kx         AC_MSG_ERROR([Building for Android requires NDK version >= 23.*])
   371         kx         ;;
   371         kx     11.1.*|12.1.*|13.1.*|14.1.*|16.*|17.*|18.*|19.*|20.*|21.*|22.*)
   371         kx         AC_MSG_ERROR([Building for Android requires NDK version >= 23.*])
   371         kx         ;;
   371         kx     23.*|24.*|25.*)
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_WARN([Untested Android NDK version $ANDROID_NDK_VERSION, only versions 23.* to 25.* have been used successfully. Proceed at your own risk.])
   371         kx         add_warning "Untested Android NDK version $ANDROID_NDK_VERSION, only versions 23.* to 25.* have been used successfully. Proceed at your own risk."
   371         kx         ;;
   371         kx     esac
   371         kx 
   371         kx     case "$with_android_ndk_toolchain_version" in
   371         kx     clang5.0)
   371         kx         ANDROID_GCC_TOOLCHAIN_VERSION=4.9
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unrecognized value for the --with-android-ndk-toolchain-version option. Building for Android is only supported with Clang 5.*])
   371         kx     esac
   371         kx 
   371         kx     AC_MSG_NOTICE([using the Android API level... $ANDROID_API_LEVEL])
   371         kx 
   371         kx     # NDK 15 or later toolchain is 64bit-only, except for Windows that we don't support. Using a 64-bit
   371         kx     # linker is required if you compile large parts of the code with -g. A 32-bit linker just won't
   371         kx     # manage to link the (app-specific) single huge .so that is built for the app in
   371         kx     # android/source/ if there is debug information in a significant part of the object files.
   371         kx     # (A 64-bit ld.gold grows too much over 10 gigabytes of virtual space when linking such a .so if
   371         kx     # all objects have been built with debug information.)
   371         kx     case $build_os in
   371         kx     linux-gnu*)
   371         kx         android_HOST_TAG=linux-x86_64
   371         kx         ;;
   371         kx     darwin*)
   371         kx         android_HOST_TAG=darwin-x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([We only support building for Android from Linux or macOS])
   371         kx         # ndk would also support windows and windows-x86_64
   371         kx         ;;
   371         kx     esac
   371         kx     ANDROID_TOOLCHAIN=$ANDROID_NDK_DIR/toolchains/llvm/prebuilt/$android_HOST_TAG
   371         kx     ANDROID_COMPILER_BIN=$ANDROID_TOOLCHAIN/bin
   371         kx 
   371         kx     test -z "$AR" && AR=$ANDROID_COMPILER_BIN/llvm-ar
   371         kx     test -z "$NM" && NM=$ANDROID_COMPILER_BIN/llvm-nm
   371         kx     test -z "$OBJDUMP" && OBJDUMP=$ANDROID_COMPILER_BIN/llvm-objdump
   371         kx     test -z "$RANLIB" && RANLIB=$ANDROID_COMPILER_BIN/llvm-ranlib
   371         kx     test -z "$STRIP" && STRIP=$ANDROID_COMPILER_BIN/llvm-strip
   371         kx 
   371         kx     ANDROIDCFLAGS="$ANDROIDCFLAGS -target ${LLVM_TRIPLE}${ANDROID_API_LEVEL}"
   371         kx     ANDROIDCFLAGS="$ANDROIDCFLAGS -no-canonical-prefixes -ffunction-sections -fdata-sections -Qunused-arguments"
   371         kx     if test "$ENABLE_LTO" = TRUE; then
   371         kx         # -flto comes from com_GCC_defs.mk, too, but we need to make sure it gets passed as part of
   371         kx         # $CC and $CXX when building external libraries
   371         kx         ANDROIDCFLAGS="$ANDROIDCFLAGS -flto -fuse-linker-plugin -O2"
   371         kx     fi
   371         kx 
   371         kx     ANDROIDCXXFLAGS="$ANDROIDCFLAGS -stdlib=libc++"
   371         kx 
   371         kx     if test -z "$CC"; then
   371         kx         CC="$ANDROID_COMPILER_BIN/clang $ANDROIDCFLAGS"
   371         kx         CC_BASE="clang"
   371         kx     fi
   371         kx     if test -z "$CXX"; then
   371         kx         CXX="$ANDROID_COMPILER_BIN/clang++ $ANDROIDCXXFLAGS"
   371         kx         CXX_BASE="clang++"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ANDROID_NDK_DIR)
   371         kx AC_SUBST(ANDROID_API_LEVEL)
   371         kx AC_SUBST(ANDROID_APP_ABI)
   371         kx AC_SUBST(ANDROID_GCC_TOOLCHAIN_VERSION)
   371         kx AC_SUBST(ANDROID_SYSROOT_PLATFORM)
   371         kx AC_SUBST(ANDROID_TOOLCHAIN)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl --with-android-sdk
   371         kx dnl ===================================================================
   371         kx ANDROID_SDK_DIR=
   371         kx if test -z "$with_android_sdk" -a -e "$SRC_ROOT/external/android-sdk-linux" -a "$build" != "$host"; then
   371         kx     with_android_sdk="$SRC_ROOT/external/android-sdk-linux"
   371         kx fi
   371         kx if test -n "$with_android_sdk"; then
   371         kx     eval ANDROID_SDK_DIR=$with_android_sdk
   371         kx     PATH="$ANDROID_SDK_DIR/platform-tools:$ANDROID_SDK_DIR/tools:$PATH"
   371         kx fi
   371         kx AC_SUBST(ANDROID_SDK_DIR)
   371         kx 
   371         kx AC_ARG_ENABLE([android-lok],
   371         kx     AS_HELP_STRING([--enable-android-lok],
   371         kx         [The Android app from the android/ subdir needs several tweaks all
   371         kx          over the place that break the LOK when used in the Online-based
   371         kx          Android app.  This switch indicates that the intent of this build is
   371         kx          actually the Online-based, non-modified LOK.])
   371         kx )
   371         kx ENABLE_ANDROID_LOK=
   371         kx if test -n "$ANDROID_NDK_DIR" ; then
   371         kx     if test "$enable_android_lok" = yes; then
   371         kx         ENABLE_ANDROID_LOK=TRUE
   371         kx         AC_DEFINE(HAVE_FEATURE_ANDROID_LOK)
   371         kx         AC_MSG_NOTICE([building the Android version... for the Online-based Android app])
   371         kx     else
   371         kx         AC_MSG_NOTICE([building the Android version... for the app from the android/ subdir])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([ENABLE_ANDROID_LOK])
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE([android-editing],
   371         kx     AS_HELP_STRING([--enable-android-editing],
   371         kx         [Enable the experimental editing feature on Android.])
   371         kx )
   371         kx ENABLE_ANDROID_EDITING=
   371         kx if test "$enable_android_editing" = yes; then
   371         kx     ENABLE_ANDROID_EDITING=TRUE
   371         kx fi
   371         kx AC_SUBST([ENABLE_ANDROID_EDITING])
   371         kx 
   371         kx disable_database_connectivity_dependencies()
   371         kx {
   371         kx     enable_evolution2=no
   371         kx     enable_firebird_sdbc=no
   371         kx     enable_mariadb_sdbc=no
   371         kx     enable_postgresql_sdbc=no
   371         kx     enable_report_builder=no
   371         kx }
   371         kx 
   371         kx # ===================================================================
   371         kx #
   371         kx # Start initial platform setup
   371         kx #
   371         kx # The using_* variables reflect platform support and should not be
   371         kx # changed after the "End initial platform setup" block.
   371         kx # This is also true for most test_* variables.
   371         kx # ===================================================================
   371         kx build_crypto=yes
   371         kx test_clucene=no
   371         kx test_gdb_index=no
   371         kx test_openldap=yes
   371         kx test_split_debug=no
   371         kx test_webdav=yes
   371         kx usable_dlapi=yes
   371         kx 
   371         kx # There is currently just iOS not using salplug, so this explicitly enables it.
   371         kx # must: using_freetype_fontconfig
   371         kx #  may: using_headless_plugin defaults to $using_freetype_fontconfig
   371         kx # must: using_x11
   371         kx 
   371         kx # Default values, as such probably valid just for Linux, set
   371         kx # differently below just for Mac OSX, but at least better than
   371         kx # hardcoding these as we used to do. Much of this is duplicated also
   371         kx # in solenv for old build system and for gbuild, ideally we should
   371         kx # perhaps define stuff like this only here in configure.ac?
   371         kx 
   371         kx LINKFLAGSSHL="-shared"
   371         kx PICSWITCH="-fpic"
   371         kx DLLPOST=".so"
   371         kx 
   371         kx LINKFLAGSNOUNDEFS="-Wl,-z,defs"
   371         kx 
   371         kx INSTROOTBASESUFFIX=
   371         kx INSTROOTCONTENTSUFFIX=
   371         kx SDKDIRNAME=sdk
   371         kx 
   371         kx HOST_PLATFORM="$host"
   371         kx 
   371         kx host_cpu_for_clang="$host_cpu"
   371         kx 
   371         kx case "$host_os" in
   371         kx 
   371         kx solaris*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     build_skia=yes
   371         kx     _os=SunOS
   371         kx 
   371         kx     dnl ===========================================================
   371         kx     dnl Check whether we're using Solaris 10 - SPARC or Intel.
   371         kx     dnl ===========================================================
   371         kx     AC_MSG_CHECKING([the Solaris operating system release])
   371         kx     _os_release=`echo $host_os | $SED -e s/solaris2\.//`
   371         kx     if test "$_os_release" -lt "10"; then
   371         kx         AC_MSG_ERROR([use Solaris >= 10 to build LibreOffice])
   371         kx     else
   371         kx         AC_MSG_RESULT([ok ($_os_release)])
   371         kx     fi
   371         kx 
   371         kx     dnl Check whether we're using a SPARC or i386 processor
   371         kx     AC_MSG_CHECKING([the processor type])
   371         kx     if test "$host_cpu" = "sparc" -o "$host_cpu" = "i386"; then
   371         kx         AC_MSG_RESULT([ok ($host_cpu)])
   371         kx     else
   371         kx         AC_MSG_ERROR([only SPARC and i386 processors are supported])
   371         kx     fi
   371         kx     ;;
   371         kx 
   371         kx linux-gnu*|k*bsd*-gnu*|linux-musl*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     build_skia=yes
   371         kx     test_gdb_index=yes
   371         kx     test_split_debug=yes
   371         kx     if test "$enable_fuzzers" = yes; then
   371         kx         test_system_freetype=no
   371         kx     fi
   371         kx     _os=Linux
   371         kx     ;;
   371         kx 
   371         kx gnu)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=no
   371         kx     _os=GNU
   371         kx      ;;
   371         kx 
   371         kx cygwin*|wsl*)
   371         kx     # When building on Windows normally with MSVC under Cygwin,
   371         kx     # configure thinks that the host platform (the platform the
   371         kx     # built code will run on) is Cygwin, even if it obviously is
   371         kx     # Windows, which in Autoconf terminology is called
   371         kx     # "mingw32". (Which is misleading as MinGW is the name of the
   371         kx     # tool-chain, not an operating system.)
   371         kx 
   371         kx     # Somewhat confusing, yes. But this configure script doesn't
   371         kx     # look at $host etc that much, it mostly uses its own $_os
   371         kx     # variable, set here in this case statement.
   371         kx 
   371         kx     using_freetype_fontconfig=no
   371         kx     using_x11=no
   371         kx     test_unix_dlapi=no
   371         kx     test_openldap=no
   371         kx     enable_pagein=no
   371         kx     build_skia=yes
   371         kx     _os=WINNT
   371         kx 
   371         kx     DLLPOST=".dll"
   371         kx     LINKFLAGSNOUNDEFS=
   371         kx 
   371         kx     if test "$host_cpu" = "aarch64"; then
   371         kx         build_skia=no
   371         kx         enable_gpgmepp=no
   371         kx         enable_coinmp=no
   371         kx         enable_firebird_sdbc=no
   371         kx     fi
   371         kx     ;;
   371         kx 
   371         kx darwin*) # macOS
   371         kx     using_freetype_fontconfig=no
   371         kx     using_x11=no
   371         kx     build_skia=yes
   371         kx     enable_pagein=no
   371         kx     if test -n "$LODE_HOME" ; then
   371         kx         mac_sanitize_path
   371         kx         AC_MSG_NOTICE([sanitized the PATH to $PATH])
   371         kx     fi
   371         kx     _os=Darwin
   371         kx     INSTROOTBASESUFFIX=/$PRODUCTNAME_WITHOUT_SPACES.app
   371         kx     INSTROOTCONTENTSUFFIX=/Contents
   371         kx     SDKDIRNAME=${PRODUCTNAME_WITHOUT_SPACES}${PRODUCTVERSION}_SDK
   371         kx     # See "Default values, as such probably valid just for Linux" comment above the case "$host_os"
   371         kx     LINKFLAGSSHL="-dynamiclib"
   371         kx 
   371         kx     # -fPIC is default
   371         kx     PICSWITCH=""
   371         kx 
   371         kx     DLLPOST=".dylib"
   371         kx 
   371         kx     # -undefined error is the default
   371         kx     LINKFLAGSNOUNDEFS=""
   371         kx     case "$host_cpu" in
   371         kx     aarch64|arm64)
   371         kx         # Apple's Clang uses "arm64"
   371         kx         host_cpu_for_clang=arm64
   371         kx     esac
   371         kx ;;
   371         kx 
   371         kx ios*) # iOS
   371         kx     using_freetype_fontconfig=no
   371         kx     using_x11=no
   371         kx     build_crypto=no
   371         kx     test_libcmis=no
   371         kx     test_openldap=no
   371         kx     test_webdav=no
   371         kx     if test -n "$LODE_HOME" ; then
   371         kx         mac_sanitize_path
   371         kx         AC_MSG_NOTICE([sanitized the PATH to $PATH])
   371         kx     fi
   371         kx     enable_gpgmepp=no
   371         kx     _os=iOS
   371         kx     enable_mpl_subset=yes
   371         kx     enable_lotuswordpro=no
   371         kx     disable_database_connectivity_dependencies
   371         kx     enable_coinmp=no
   371         kx     enable_lpsolve=no
   371         kx     enable_extension_integration=no
   371         kx     enable_xmlhelp=no
   371         kx     with_ppds=no
   371         kx     if test "$enable_ios_simulator" = "yes"; then
   371         kx         host=x86_64-apple-darwin
   371         kx     fi
   371         kx     # See "Default values, as such probably valid just for Linux" comment above the case "$host_os"
   371         kx     LINKFLAGSSHL="-dynamiclib"
   371         kx 
   371         kx     # -fPIC is default
   371         kx     PICSWITCH=""
   371         kx 
   371         kx     DLLPOST=".dylib"
   371         kx 
   371         kx     # -undefined error is the default
   371         kx     LINKFLAGSNOUNDEFS=""
   371         kx 
   371         kx     # HOST_PLATFORM is used for external projects and their configury typically doesn't like the "ios"
   371         kx     # part, so use aarch64-apple-darwin for now.
   371         kx     HOST_PLATFORM=aarch64-apple-darwin
   371         kx 
   371         kx     # Apple's Clang uses "arm64"
   371         kx     host_cpu_for_clang=arm64
   371         kx ;;
   371         kx 
   371         kx freebsd*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     build_skia=yes
   371         kx     AC_MSG_CHECKING([the FreeBSD operating system release])
   371         kx     if test -n "$with_os_version"; then
   371         kx         OSVERSION="$with_os_version"
   371         kx     else
   371         kx         OSVERSION=`/sbin/sysctl -n kern.osreldate`
   371         kx     fi
   371         kx     AC_MSG_RESULT([found OSVERSION=$OSVERSION])
   371         kx     AC_MSG_CHECKING([which thread library to use])
   371         kx     if test "$OSVERSION" -lt "500016"; then
   371         kx         PTHREAD_CFLAGS="-D_THREAD_SAFE"
   371         kx         PTHREAD_LIBS="-pthread"
   371         kx     elif test "$OSVERSION" -lt "502102"; then
   371         kx         PTHREAD_CFLAGS="-D_THREAD_SAFE"
   371         kx         PTHREAD_LIBS="-lc_r"
   371         kx     else
   371         kx         PTHREAD_CFLAGS=""
   371         kx         PTHREAD_LIBS="-pthread"
   371         kx     fi
   371         kx     AC_MSG_RESULT([$PTHREAD_LIBS])
   371         kx     _os=FreeBSD
   371         kx     ;;
   371         kx 
   371         kx *netbsd*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     test_gtk3_kde5=no
   371         kx     build_skia=yes
   371         kx     PTHREAD_LIBS="-pthread -lpthread"
   371         kx     _os=NetBSD
   371         kx     ;;
   371         kx 
   371         kx openbsd*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     PTHREAD_CFLAGS="-D_THREAD_SAFE"
   371         kx     PTHREAD_LIBS="-pthread"
   371         kx     _os=OpenBSD
   371         kx     ;;
   371         kx 
   371         kx dragonfly*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     build_skia=yes
   371         kx     PTHREAD_LIBS="-pthread"
   371         kx     _os=DragonFly
   371         kx     ;;
   371         kx 
   371         kx linux-android*)
   371         kx     # API exists, but seems not really usable since Android 7 AFAIK
   371         kx     usable_dlapi=no
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_headless_plugin=no
   371         kx     using_x11=no
   371         kx     build_crypto=no
   371         kx     test_openldap=no
   371         kx     test_system_freetype=no
   371         kx     test_webdav=no
   371         kx     disable_database_connectivity_dependencies
   371         kx     enable_lotuswordpro=no
   371         kx     enable_mpl_subset=yes
   371         kx     enable_cairo_canvas=no
   371         kx     enable_coinmp=yes
   371         kx     enable_lpsolve=no
   371         kx     enable_odk=no
   371         kx     enable_python=no
   371         kx     enable_xmlhelp=no
   371         kx     _os=Android
   371         kx     ;;
   371         kx 
   371         kx haiku*)
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=no
   371         kx     test_gtk3=no
   371         kx     test_gtk3_kde5=no
   371         kx     test_kf5=yes
   371         kx     test_kf6=yes
   371         kx     enable_odk=no
   371         kx     enable_coinmp=no
   371         kx     enable_pdfium=no
   371         kx     enable_sdremote=no
   371         kx     enable_postgresql_sdbc=no
   371         kx     enable_firebird_sdbc=no
   371         kx     _os=Haiku
   371         kx     ;;
   371         kx 
   371         kx emscripten)
   371         kx     # API currently just exists in headers, not code
   371         kx     usable_dlapi=no
   371         kx     using_freetype_fontconfig=yes
   371         kx     using_x11=yes
   371         kx     test_openldap=no
   371         kx     test_qt5=yes
   371         kx     test_split_debug=yes
   371         kx     test_system_freetype=no
   371         kx     enable_compiler_plugins=no
   371         kx     enable_customtarget_components=yes
   371         kx     enable_split_debug=yes
   371         kx     enable_wasm_strip=yes
   371         kx     with_system_zlib=no
   371         kx     with_theme="colibre"
   371         kx     _os=Emscripten
   371         kx     ;;
   371         kx 
   371         kx *)
   371         kx     AC_MSG_ERROR([$host_os operating system is not suitable to build LibreOffice for!])
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx AC_SUBST(HOST_PLATFORM)
   371         kx 
   371         kx if test -z "$using_x11" -o -z "$using_freetype_fontconfig"; then
   371         kx     AC_MSG_ERROR([You must set \$using_freetype_fontconfig and \$using_x11 for your platform])
   371         kx fi
   371         kx 
   371         kx # Set defaults, if not set by platform
   371         kx test "${test_cups+set}" = set || test_cups="$using_x11"
   371         kx test "${test_dbus+set}" = set || test_dbus="$using_x11"
   371         kx test "${test_gen+set}" = set || test_gen="$using_x11"
   371         kx test "${test_gstreamer_1_0+set}" = set || test_gstreamer_1_0="$using_x11"
   371         kx test "${test_gtk3+set}" = set || test_gtk3="$using_x11"
   371         kx test "${test_gtk4+set}" = set || test_gtk4="$using_x11"
   371         kx test "${test_kf5+set}" = set || test_kf5="$using_x11"
   371         kx test "${test_kf6+set}" = set || test_kf6="$using_x11"
   371         kx # don't handle test_qt5, so it can disable test_kf5 later
   371         kx test "${test_qt6+set}" = set || test_qt6="$using_x11"
   371         kx test "${test_randr+set}" = set || test_randr="$using_x11"
   371         kx test "${test_xrender+set}" = set || test_xrender="$using_x11"
   371         kx test "${using_headless_plugin+set}" = set || using_headless_plugin="$using_freetype_fontconfig"
   371         kx 
   371         kx test "${test_gtk3_kde5+set}" != set -a "$test_kf5" = yes -a "$test_gtk3" = yes && test_gtk3_kde5="yes"
   371         kx # Make sure fontconfig and freetype test both either system or not
   371         kx test "${test_system_fontconfig+set}" != set -a "${test_system_freetype+set}" = set && test_system_fontconfig="$test_system_freetype"
   371         kx test "${test_system_freetype+set}" != set -a "${test_system_fontconfig+set}" = set && test_system_freetype="$test_system_fontconfig"
   371         kx 
   371         kx # convenience / platform overriding "fixes"
   371         kx # Don't sort!
   371         kx test "$test_kf5" = yes -a "$test_qt5" = no && test_kf5=no
   371         kx test "$test_kf5" = yes && test_qt5=yes
   371         kx test "$test_gtk3" != yes && enable_gtk3=no
   371         kx test "$test_gtk3" != yes -o "$test_kf5" != yes && test_gtk3_kde5=no
   371         kx test "$using_freetype_fontconfig" = no && using_headless_plugin=no
   371         kx test "$using_freetype_fontconfig" = yes && test_cairo=yes
   371         kx 
   371         kx # Keep in sync with the above $using_x11 depending test default list
   371         kx disable_x11_tests()
   371         kx {
   371         kx     test_cups=no
   371         kx     test_dbus=no
   371         kx     test_gen=no
   371         kx     test_gstreamer_1_0=no
   371         kx     test_gtk3_kde5=no
   371         kx     test_gtk3=no
   371         kx     test_gtk4=no
   371         kx     test_kf5=no
   371         kx     test_kf6=no
   371         kx     test_qt5=no
   371         kx     test_qt6=no
   371         kx     test_randr=no
   371         kx     test_xrender=no
   371         kx }
   371         kx 
   371         kx test "$using_x11" = yes && USING_X11=TRUE
   371         kx 
   371         kx if test "$using_freetype_fontconfig" = yes; then
   371         kx     AC_DEFINE(USE_HEADLESS_CODE)
   371         kx     USE_HEADLESS_CODE=TRUE
   371         kx     if test "$using_headless_plugin" = yes; then
   371         kx         AC_DEFINE(ENABLE_HEADLESS)
   371         kx         ENABLE_HEADLESS=TRUE
   371         kx     fi
   371         kx else
   371         kx     test_fontconfig=no
   371         kx     test_freetype=no
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_HEADLESS)
   371         kx AC_SUBST(USE_HEADLESS_CODE)
   371         kx 
   371         kx AC_MSG_NOTICE([VCL platform has a usable dynamic loading API: $usable_dlapi])
   371         kx AC_MSG_NOTICE([VCL platform uses freetype+fontconfig: $using_freetype_fontconfig])
   371         kx AC_MSG_NOTICE([VCL platform uses headless plugin: $using_headless_plugin])
   371         kx AC_MSG_NOTICE([VCL platform uses X11: $using_x11])
   371         kx 
   371         kx # ===================================================================
   371         kx #
   371         kx # End initial platform setup
   371         kx #
   371         kx # ===================================================================
   371         kx 
   371         kx if test "$_os" = "Android" ; then
   371         kx     # Verify that the NDK and SDK options are proper
   371         kx     if test -z "$with_android_ndk"; then
   371         kx         AC_MSG_ERROR([the --with-android-ndk option is mandatory, unless it is available at external/android-ndk/.])
   371         kx     elif test ! -f "$ANDROID_NDK_DIR/meta/abis.json"; then
   371         kx         AC_MSG_ERROR([the --with-android-ndk option does not point to an Android NDK])
   371         kx     fi
   371         kx 
   371         kx     if test -z "$ANDROID_SDK_DIR"; then
   371         kx         AC_MSG_ERROR([the --with-android-sdk option is mandatory, unless it is available at external/android-sdk-linux/.])
   371         kx     elif test ! -d "$ANDROID_SDK_DIR/platforms"; then
   371         kx         AC_MSG_ERROR([the --with-android-sdk option does not point to an Android SDK])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(SDKDIRNAME)
   371         kx 
   371         kx AC_SUBST(PTHREAD_CFLAGS)
   371         kx AC_SUBST(PTHREAD_LIBS)
   371         kx 
   371         kx # Check for explicit A/C/CXX/OBJC/OBJCXX/LDFLAGS.
   371         kx # By default use the ones specified by our build system,
   371         kx # but explicit override is possible.
   371         kx AC_MSG_CHECKING(for explicit AFLAGS)
   371         kx if test -n "$AFLAGS"; then
   371         kx     AC_MSG_RESULT([$AFLAGS])
   371         kx     x_AFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_AFLAGS=[\#]
   371         kx fi
   371         kx AC_MSG_CHECKING(for explicit CFLAGS)
   371         kx if test -n "$CFLAGS"; then
   371         kx     AC_MSG_RESULT([$CFLAGS])
   371         kx     x_CFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_CFLAGS=[\#]
   371         kx fi
   371         kx AC_MSG_CHECKING(for explicit CXXFLAGS)
   371         kx if test -n "$CXXFLAGS"; then
   371         kx     AC_MSG_RESULT([$CXXFLAGS])
   371         kx     x_CXXFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_CXXFLAGS=[\#]
   371         kx fi
   371         kx AC_MSG_CHECKING(for explicit OBJCFLAGS)
   371         kx if test -n "$OBJCFLAGS"; then
   371         kx     AC_MSG_RESULT([$OBJCFLAGS])
   371         kx     x_OBJCFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_OBJCFLAGS=[\#]
   371         kx fi
   371         kx AC_MSG_CHECKING(for explicit OBJCXXFLAGS)
   371         kx if test -n "$OBJCXXFLAGS"; then
   371         kx     AC_MSG_RESULT([$OBJCXXFLAGS])
   371         kx     x_OBJCXXFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_OBJCXXFLAGS=[\#]
   371         kx fi
   371         kx AC_MSG_CHECKING(for explicit LDFLAGS)
   371         kx if test -n "$LDFLAGS"; then
   371         kx     AC_MSG_RESULT([$LDFLAGS])
   371         kx     x_LDFLAGS=
   371         kx else
   371         kx     AC_MSG_RESULT(no)
   371         kx     x_LDFLAGS=[\#]
   371         kx fi
   371         kx AC_SUBST(AFLAGS)
   371         kx AC_SUBST(CFLAGS)
   371         kx AC_SUBST(CXXFLAGS)
   371         kx AC_SUBST(OBJCFLAGS)
   371         kx AC_SUBST(OBJCXXFLAGS)
   371         kx AC_SUBST(LDFLAGS)
   371         kx AC_SUBST(x_AFLAGS)
   371         kx AC_SUBST(x_CFLAGS)
   371         kx AC_SUBST(x_CXXFLAGS)
   371         kx AC_SUBST(x_OBJCFLAGS)
   371         kx AC_SUBST(x_OBJCXXFLAGS)
   371         kx AC_SUBST(x_LDFLAGS)
   371         kx 
   371         kx dnl These are potentially set for MSVC, in the code checking for UCRT below:
   371         kx my_original_CFLAGS=$CFLAGS
   371         kx my_original_CXXFLAGS=$CXXFLAGS
   371         kx my_original_CPPFLAGS=$CPPFLAGS
   371         kx 
   371         kx dnl The following checks for gcc, cc and then cl (if it weren't guarded for win32)
   371         kx dnl Needs to precede the AC_C_BIGENDIAN and AC_SEARCH_LIBS calls below, which apparently call
   371         kx dnl AC_PROG_CC internally.
   371         kx if test "$_os" != "WINNT"; then
   371         kx     # AC_PROG_CC sets CFLAGS to -g -O2 if not set, avoid that
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     AC_PROG_CC
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test -z "$CC_BASE"; then
   371         kx         CC_BASE=`first_arg_basename "$CC"`
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test "$_os" != "WINNT"; then
   371         kx     AC_C_BIGENDIAN([ENDIANNESS=big], [ENDIANNESS=little])
   371         kx else
   371         kx     ENDIANNESS=little
   371         kx fi
   371         kx AC_SUBST(ENDIANNESS)
   371         kx 
   371         kx if test "$usable_dlapi" != no; then
   371         kx     AC_DEFINE([HAVE_DLAPI])
   371         kx     if test "$test_unix_dlapi" != no; then
   371         kx         save_LIBS="$LIBS"
   371         kx         AC_SEARCH_LIBS([dlsym], [dl],
   371         kx             [case "$ac_cv_search_dlsym" in -l*) UNIX_DLAPI_LIBS="$ac_cv_search_dlsym";; esac],
   371         kx             [AC_MSG_ERROR([dlsym not found in either libc nor libdl])])
   371         kx         LIBS="$save_LIBS"
   371         kx         AC_DEFINE([HAVE_UNIX_DLAPI])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(UNIX_DLAPI_LIBS)
   371         kx 
   371         kx # Check for a (GNU) backtrace implementation
   371         kx AC_ARG_VAR([BACKTRACE_CFLAGS], [Compiler flags needed to use backtrace(3)])
   371         kx AC_ARG_VAR([BACKTRACE_LIBS], [Linker flags needed to use backtrace(3)])
   371         kx AS_IF([test "x$BACKTRACE_LIBS$BACKTRACE_CFLAGS" = x], [
   371         kx     save_LIBS="$LIBS"
   371         kx     AC_SEARCH_LIBS([backtrace], [libexecinfo],
   371         kx         [case "$ac_cv_search_backtrace" in -l*) BACKTRACE_LIBS="$ac_cv_search_backtrace";; esac],
   371         kx         [PKG_CHECK_MODULES([BACKTRACE], [libexecinfo], [ac_cv_search_backtrace=], [:])])
   371         kx     LIBS="$save_LIBS"
   371         kx ])
   371         kx AS_IF([test "x$ac_cv_search_backtrace" != xno ], [
   371         kx     AC_DEFINE([HAVE_FEATURE_BACKTRACE])
   371         kx ])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Sanity checks for Emscripten SDK setup
   371         kx dnl ===================================================================
   371         kx 
   371         kx EMSCRIPTEN_MIN_MAJOR=2
   371         kx EMSCRIPTEN_MIN_MINOR=0
   371         kx EMSCRIPTEN_MIN_TINY=31
   371         kx EMSCRIPTEN_MIN_VERSION="${EMSCRIPTEN_MIN_MAJOR}.${EMSCRIPTEN_MIN_MINOR}.${EMSCRIPTEN_MIN_TINY}"
   371         kx 
   371         kx if test "$_os" = "Emscripten"; then
   371         kx     AC_MSG_CHECKING([if Emscripten is at least $EMSCRIPTEN_MIN_VERSION])
   371         kx     AS_IF([test -z "$EMSDK"],
   371         kx           [AC_MSG_ERROR([No \$EMSDK environment variable.])])
   371         kx     EMSCRIPTEN_VERSION_H=$EMSDK/upstream/emscripten/cache/sysroot/include/emscripten/version.h
   371         kx     if test -f "$EMSCRIPTEN_VERSION_H"; then
   371         kx         EMSCRIPTEN_MAJOR=$($GREP __EMSCRIPTEN_major__ "$EMSCRIPTEN_VERSION_H" | $SED -ne 's/.*__EMSCRIPTEN_major__ //p')
   371         kx         EMSCRIPTEN_MINOR=$($GREP __EMSCRIPTEN_minor__ "$EMSCRIPTEN_VERSION_H" | $SED -ne 's/.*__EMSCRIPTEN_minor__ //p')
   371         kx         EMSCRIPTEN_TINY=$($GREP __EMSCRIPTEN_tiny__ "$EMSCRIPTEN_VERSION_H" | $SED -ne 's/.*__EMSCRIPTEN_tiny__ //p')
   371         kx     else
   371         kx         EMSCRIPTEN_DEFINES=$(echo | emcc -dM -E - | $GREP __EMSCRIPTEN_)
   371         kx         EMSCRIPTEN_MAJOR=$(echo "$EMSCRIPTEN_DEFINES" | $SED -ne 's/.*__EMSCRIPTEN_major__ //p')
   371         kx         EMSCRIPTEN_MINOR=$(echo "$EMSCRIPTEN_DEFINES" | $SED -ne 's/.*__EMSCRIPTEN_minor__ //p')
   371         kx         EMSCRIPTEN_TINY=$(echo "$EMSCRIPTEN_DEFINES" | $SED -ne 's/.*__EMSCRIPTEN_tiny__ //p')
   371         kx     fi
   371         kx 
   371         kx     EMSCRIPTEN_VERSION="${EMSCRIPTEN_MAJOR}.${EMSCRIPTEN_MINOR}.${EMSCRIPTEN_TINY}"
   371         kx 
   371         kx     check_semantic_version_three_prefixed EMSCRIPTEN MIN
   371         kx     if test $? -eq 0; then
   371         kx         AC_MSG_RESULT([yes ($EMSCRIPTEN_VERSION)])
   371         kx     else
   371         kx         AC_MSG_ERROR([no, found $EMSCRIPTEN_VERSION])
   371         kx     fi
   371         kx 
   371         kx     EMSCRIPTEN_ERROR=0
   371         kx     if ! which emconfigure >/dev/null 2>&1; then
   371         kx         AC_MSG_WARN([emconfigure must be in your \$PATH])
   371         kx         EMSCRIPTEN_ERROR=1
   371         kx     fi
   371         kx     if test -z "$EMMAKEN_JUST_CONFIGURE"; then
   371         kx         AC_MSG_WARN(["\$EMMAKEN_JUST_CONFIGURE wasn't set by emconfigure. Prefix configure or use autogen.sh])
   371         kx         EMSCRIPTEN_ERROR=1
   371         kx     fi
   371         kx     EMSDK_FILE_PACKAGER="$(em-config EMSCRIPTEN_ROOT)"/tools/file_packager
   371         kx     if ! test -x "$EMSDK_FILE_PACKAGER"; then
   371         kx         AC_MSG_WARN([No file_packager found in $(em-config EMSCRIPTEN_ROOT)/tools/file_packager.])
   371         kx         EMSCRIPTEN_ERROR=1
   371         kx     fi
   371         kx     if test $EMSCRIPTEN_ERROR -ne 0; then
   371         kx         AC_MSG_ERROR(["Please fix your EMSDK setup to build with Emscripten!"])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(EMSDK_FILE_PACKAGER)
   371         kx 
   371         kx ###############################################################################
   371         kx # Extensions switches --enable/--disable
   371         kx ###############################################################################
   371         kx # By default these should be enabled unless having extra dependencies.
   371         kx # If there is extra dependency over configure options then the enable should
   371         kx # be automagic based on whether the requiring feature is enabled or not.
   371         kx # All this options change anything only with --enable-extension-integration.
   371         kx 
   371         kx # The name of this option and its help string makes it sound as if
   371         kx # extensions are built anyway, just not integrated in the installer,
   371         kx # if you use --disable-extension-integration. Is that really the
   371         kx # case?
   371         kx 
   371         kx AC_ARG_ENABLE(ios-simulator,
   371         kx     AS_HELP_STRING([--enable-ios-simulator],
   371         kx         [build for iOS simulator])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(extension-integration,
   371         kx     AS_HELP_STRING([--disable-extension-integration],
   371         kx         [Disable integration of the built extensions in the installer of the
   371         kx          product. Use this switch to disable the integration.])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(avmedia,
   371         kx     AS_HELP_STRING([--disable-avmedia],
   371         kx         [Disable displaying and inserting AV media in documents. Work in progress, use only if you are hacking on it.]),
   371         kx ,test "${enable_avmedia+set}" = set || enable_avmedia=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(database-connectivity,
   371         kx     AS_HELP_STRING([--disable-database-connectivity],
   371         kx         [Disable various database connectivity. Work in progress, use only if you are hacking on it.])
   371         kx )
   371         kx 
   371         kx # This doesn't mean not building (or "integrating") extensions
   371         kx # (although it probably should; i.e. it should imply
   371         kx # --disable-extension-integration I guess), it means not supporting
   371         kx # any extension mechanism at all
   371         kx libo_FUZZ_ARG_ENABLE(extensions,
   371         kx     AS_HELP_STRING([--disable-extensions],
   371         kx         [Disable all add-on extension functionality. Work in progress, use only if you are hacking on it.])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(scripting,
   371         kx     AS_HELP_STRING([--disable-scripting],
   371         kx         [Disable BASIC, Java and Python. Work in progress, use only if you are hacking on it.]),
   371         kx ,test "${enable_scripting+set}" = set || enable_scripting=yes)
   371         kx 
   371         kx # This is mainly for Android and iOS, but could potentially be used in some
   371         kx # special case otherwise, too, so factored out as a separate setting
   371         kx 
   371         kx AC_ARG_ENABLE(dynamic-loading,
   371         kx     AS_HELP_STRING([--disable-dynamic-loading],
   371         kx         [Disable any use of dynamic loading of code. Work in progress, use only if you are hacking on it.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(report-builder,
   371         kx     AS_HELP_STRING([--disable-report-builder],
   371         kx         [Disable the Report Builder.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(ext-wiki-publisher,
   371         kx     AS_HELP_STRING([--enable-ext-wiki-publisher],
   371         kx         [Enable the Wiki Publisher extension.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(lpsolve,
   371         kx     AS_HELP_STRING([--disable-lpsolve],
   371         kx         [Disable compilation of the lp solve solver ])
   371         kx )
   371         kx libo_FUZZ_ARG_ENABLE(coinmp,
   371         kx     AS_HELP_STRING([--disable-coinmp],
   371         kx         [Disable compilation of the CoinMP solver ])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(pdfimport,
   371         kx     AS_HELP_STRING([--disable-pdfimport],
   371         kx         [Disable building the PDF import feature.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(pdfium,
   371         kx     AS_HELP_STRING([--disable-pdfium],
   371         kx         [Disable building PDFium. Results in unsecure PDF signature verification.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(skia,
   371         kx     AS_HELP_STRING([--disable-skia],
   371         kx         [Disable building Skia. Use --enable-skia=debug to build without optimizations.])
   371         kx )
   371         kx 
   371         kx ###############################################################################
   371         kx 
   371         kx dnl ---------- *** ----------
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(mergelibs,
   371         kx     AS_HELP_STRING([--enable-mergelibs],
   371         kx         [Merge several of the smaller libraries into one big, "merged", one.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(breakpad,
   371         kx     AS_HELP_STRING([--enable-breakpad],
   371         kx         [Enables breakpad for crash reporting.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(crashdump,
   371         kx     AS_HELP_STRING([--disable-crashdump],
   371         kx         [Disable dump.ini and dump-file, when --enable-breakpad])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(fetch-external,
   371         kx     AS_HELP_STRING([--disable-fetch-external],
   371         kx         [Disables fetching external tarballs from web sources.])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(fuzzers,
   371         kx     AS_HELP_STRING([--enable-fuzzers],
   371         kx         [Enables building libfuzzer targets for fuzz testing.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(pch,
   371         kx     AS_HELP_STRING([--enable-pch=<yes/no/system/base/normal/full>],
   371         kx         [Enables precompiled header support for C++. Forced default on Windows/VC build.
   371         kx          Using 'system' will include only external headers, 'base' will add also headers
   371         kx          from base modules, 'normal' will also add all headers except from the module built,
   371         kx          'full' will use all suitable headers even from a module itself.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(epm,
   371         kx     AS_HELP_STRING([--enable-epm],
   371         kx         [LibreOffice includes self-packaging code, that requires epm, however epm is
   371         kx          useless for large scale package building.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(odk,
   371         kx     AS_HELP_STRING([--enable-odk],
   371         kx         [Enable building the Office Development Kit, the part that extensions need to build against])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(mpl-subset,
   371         kx     AS_HELP_STRING([--enable-mpl-subset],
   371         kx         [Don't compile any pieces which are not MPL or more liberally licensed])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(evolution2,
   371         kx     AS_HELP_STRING([--enable-evolution2],
   371         kx         [Allows the built-in evolution 2 addressbook connectivity build to be
   371         kx          enabled.])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(avahi,
   371         kx     AS_HELP_STRING([--enable-avahi],
   371         kx         [Determines whether to use Avahi to advertise Impress to remote controls.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(werror,
   371         kx     AS_HELP_STRING([--enable-werror],
   371         kx         [Turn warnings to errors. (Has no effect in modules where the treating
   371         kx          of warnings as errors is disabled explicitly.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(assert-always-abort,
   371         kx     AS_HELP_STRING([--enable-assert-always-abort],
   371         kx         [make assert() failures abort even when building without --enable-debug or --enable-dbgutil.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(dbgutil,
   371         kx     AS_HELP_STRING([--enable-dbgutil],
   371         kx         [Provide debugging support from --enable-debug and include additional debugging
   371         kx          utilities such as object counting or more expensive checks.
   371         kx          This is the recommended option for developers.
   371         kx          Note that this makes the build ABI incompatible, it is not possible to mix object
   371         kx          files or libraries from a --enable-dbgutil and a --disable-dbgutil build.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(debug,
   371         kx     AS_HELP_STRING([--enable-debug],
   371         kx         [Include debugging information, disable compiler optimization and inlining plus
   371         kx          extra debugging code like assertions. Extra large build! (enables -g compiler flag).]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(split-debug,
   371         kx     AS_HELP_STRING([--disable-split-debug],
   371         kx         [Disable using split debug information (-gsplit-dwarf compile flag). Split debug information
   371         kx          saves disk space and build time, but requires tools that support it (both build tools and debuggers).]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(gdb-index,
   371         kx     AS_HELP_STRING([--disable-gdb-index],
   371         kx         [Disables creating debug information in the gdb index format, which makes gdb start faster.
   371         kx          The feature requires a linker that supports the --gdb-index option.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(sal-log,
   371         kx     AS_HELP_STRING([--enable-sal-log],
   371         kx         [Make SAL_INFO and SAL_WARN calls do something even in a non-debug build.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(symbols,
   371         kx     AS_HELP_STRING([--enable-symbols],
   371         kx         [Generate debug information.
   371         kx          By default, enabled for --enable-debug and --enable-dbgutil, disabled
   371         kx          otherwise. It is possible to explicitly specify gbuild build targets
   371         kx          (where 'all' means everything, '-' prepended means to not enable, '/' appended means
   371         kx          everything in the directory; there is no ordering, more specific overrides
   371         kx          more general, and disabling takes precedence).
   371         kx          Example: --enable-symbols="all -sw/ -Library_sc".]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(optimized,
   371         kx     AS_HELP_STRING([--enable-optimized=<yes/no/debug>],
   371         kx         [Whether to compile with optimization flags.
   371         kx          By default, disabled for --enable-debug and --enable-dbgutil, enabled
   371         kx          otherwise. Using 'debug' will try to use only optimizations that should
   371         kx          not interfere with debugging. For Emscripten we default to optimized (-O1)
   371         kx          debug build, as otherwise binaries become too large.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(runtime-optimizations,
   371         kx     AS_HELP_STRING([--disable-runtime-optimizations],
   371         kx         [Statically disable certain runtime optimizations (like rtl/alloc.h or
   371         kx          JVM JIT) that are known to interact badly with certain dynamic analysis
   371         kx          tools (like -fsanitize=address or Valgrind).  By default, disabled iff
   371         kx          CC contains "-fsanitize=*".  (For Valgrind, those runtime optimizations
   371         kx          are typically disabled dynamically via RUNNING_ON_VALGRIND.)]))
   371         kx 
   371         kx AC_ARG_WITH(valgrind,
   371         kx     AS_HELP_STRING([--with-valgrind],
   371         kx         [Make availability of Valgrind headers a hard requirement.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(compiler-plugins,
   371         kx     AS_HELP_STRING([--enable-compiler-plugins],
   371         kx         [Enable compiler plugins that will perform additional checks during
   371         kx          building. Enabled automatically by --enable-dbgutil.
   371         kx          Use --enable-compiler-plugins=debug to also enable debug code in the plugins.]))
   371         kx COMPILER_PLUGINS_DEBUG=
   371         kx if test "$enable_compiler_plugins" = debug; then
   371         kx     enable_compiler_plugins=yes
   371         kx     COMPILER_PLUGINS_DEBUG=TRUE
   371         kx fi
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(compiler-plugins-analyzer-pch,
   371         kx     AS_HELP_STRING([--disable-compiler-plugins-analyzer-pch],
   371         kx         [Disable use of precompiled headers when running the Clang compiler plugin analyzer.  Not
   371         kx          relevant in the --disable-compiler-plugins case.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(ooenv,
   371         kx     AS_HELP_STRING([--enable-ooenv],
   371         kx         [Enable ooenv for the instdir installation.]))
   371         kx 
   371         kx AC_ARG_ENABLE(lto,
   371         kx     AS_HELP_STRING([--enable-lto],
   371         kx         [Enable link-time optimization. Suitable for (optimised) product builds. Building might take
   371         kx          longer but libraries and executables are optimized for speed. For GCC, best to use the 'gold'
   371         kx          linker.)]))
   371         kx 
   371         kx AC_ARG_ENABLE(python,
   371         kx     AS_HELP_STRING([--enable-python=<no/auto/system/internal/fully-internal>],
   371         kx         [Enables or disables Python support at run-time.
   371         kx          Also specifies what Python to use at build-time.
   371         kx          'fully-internal' even forces the internal version for uses of Python
   371         kx          during the build.
   371         kx          On macOS the only choices are
   371         kx          'internal' (default) or 'fully-internal'. Otherwise the default is 'auto'.
   371         kx          ]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(gtk3,
   371         kx     AS_HELP_STRING([--disable-gtk3],
   371         kx         [Determines whether to use Gtk+ 3.0 vclplug on platforms where Gtk+ 3.0 is available.]),
   371         kx ,test "${test_gtk3}" = no -o "${enable_gtk3+set}" = set || enable_gtk3=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(gtk4,
   371         kx     AS_HELP_STRING([--enable-gtk4],
   371         kx         [Determines whether to use Gtk+ 4.0 vclplug on platforms where Gtk+ 4.0 is available.]))
   371         kx 
   371         kx AC_ARG_ENABLE(atspi-tests,
   371         kx     AS_HELP_STRING([--disable-atspi-tests],
   371         kx         [Determines whether to enable AT-SPI2 tests for the GTK3 vclplug.]))
   371         kx 
   371         kx AC_ARG_ENABLE(introspection,
   371         kx     AS_HELP_STRING([--enable-introspection],
   371         kx         [Generate files for GObject introspection.  Requires --enable-gtk3.  (Typically used by
   371         kx          Linux distributions.)]))
   371         kx 
   371         kx AC_ARG_ENABLE(split-app-modules,
   371         kx     AS_HELP_STRING([--enable-split-app-modules],
   371         kx         [Split file lists for app modules, e.g. base, calc.
   371         kx          Has effect only with make distro-pack-install]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(split-opt-features,
   371         kx     AS_HELP_STRING([--enable-split-opt-features],
   371         kx         [Split file lists for some optional features, e.g. pyuno, testtool.
   371         kx          Has effect only with make distro-pack-install]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(cairo-canvas,
   371         kx     AS_HELP_STRING([--disable-cairo-canvas],
   371         kx         [Determines whether to build the Cairo canvas on platforms where Cairo is available.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(dbus,
   371         kx     AS_HELP_STRING([--disable-dbus],
   371         kx         [Determines whether to enable features that depend on dbus.
   371         kx          e.g. Presentation mode screensaver control, bluetooth presentation control, automatic font install]),
   371         kx ,test "${enable_dbus+set}" = set || enable_dbus=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(sdremote,
   371         kx     AS_HELP_STRING([--disable-sdremote],
   371         kx         [Determines whether to enable Impress remote control (i.e. the server component).]),
   371         kx ,test "${enable_sdremote+set}" = set || enable_sdremote=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(sdremote-bluetooth,
   371         kx     AS_HELP_STRING([--disable-sdremote-bluetooth],
   371         kx         [Determines whether to build sdremote with bluetooth support.
   371         kx          Requires dbus on Linux.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(gio,
   371         kx     AS_HELP_STRING([--disable-gio],
   371         kx         [Determines whether to use the GIO support.]),
   371         kx ,test "${enable_gio+set}" = set || enable_gio=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(qt5,
   371         kx     AS_HELP_STRING([--enable-qt5],
   371         kx         [Determines whether to use Qt5 vclplug on platforms where Qt5 is
   371         kx          available.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(qt6,
   371         kx     AS_HELP_STRING([--enable-qt6],
   371         kx         [Determines whether to use Qt6 vclplug on platforms where Qt6 is
   371         kx          available.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(kf5,
   371         kx     AS_HELP_STRING([--enable-kf5],
   371         kx         [Determines whether to use Qt5/KF5 vclplug on platforms where Qt5 and
   371         kx          KF5 are available.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(kf6,
   371         kx     AS_HELP_STRING([--enable-kf6],
   371         kx         [Determines whether to use KF6 vclplug on platforms where Qt6 and
   371         kx          KF6 are available.]),
   371         kx ,)
   371         kx 
   371         kx 
   371         kx AC_ARG_ENABLE(gtk3_kde5,
   371         kx     AS_HELP_STRING([--enable-gtk3-kde5],
   371         kx         [Determines whether to use Gtk3 vclplug with KF5 file dialogs on
   371         kx          platforms where Gtk3, Qt5 and Plasma is available.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(gen,
   371         kx     AS_HELP_STRING([--enable-gen],
   371         kx         [To select the gen backend in case of --disable-dynamic-loading.
   371         kx          Per default auto-enabled when X11 is used.]),
   371         kx ,test "${test_gen}" = no -o "${enable_gen+set}" = set || enable_gen=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(gui,
   371         kx     AS_HELP_STRING([--disable-gui],
   371         kx         [Disable use of X11 or Wayland to reduce dependencies (e.g. for building LibreOfficeKit).]),
   371         kx ,enable_gui=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(randr,
   371         kx     AS_HELP_STRING([--disable-randr],
   371         kx         [Disable RandR support in the vcl project.]),
   371         kx ,test "${enable_randr+set}" = set || enable_randr=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(gstreamer-1-0,
   371         kx     AS_HELP_STRING([--disable-gstreamer-1-0],
   371         kx         [Disable building with the gstreamer 1.0 avmedia backend.]),
   371         kx ,test "${enable_gstreamer_1_0+set}" = set || enable_gstreamer_1_0=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE([eot],
   371         kx     [AS_HELP_STRING([--enable-eot],
   371         kx         [Enable support for Embedded OpenType fonts.])],
   371         kx ,test "${enable_eot+set}" = set || enable_eot=no)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(cve-tests,
   371         kx     AS_HELP_STRING([--disable-cve-tests],
   371         kx         [Prevent CVE tests to be executed]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(build-opensymbol,
   371         kx     AS_HELP_STRING([--enable-build-opensymbol],
   371         kx         [Do not use the prebuilt opens___.ttf. Build it instead. This needs
   371         kx          fontforge installed.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(dependency-tracking,
   371         kx     AS_HELP_STRING([--enable-dependency-tracking],
   371         kx         [Do not reject slow dependency extractors.])[
   371         kx   --disable-dependency-tracking
   371         kx                           Disables generation of dependency information.
   371         kx                           Speed up one-time builds.],
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(icecream,
   371         kx     AS_HELP_STRING([--enable-icecream],
   371         kx         [Use the 'icecream' distributed compiling tool to speedup the compilation.
   371         kx          It defaults to /opt/icecream for the location of the icecream gcc/g++
   371         kx          wrappers, you can override that using --with-gcc-home=/the/path switch.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(ld,
   371         kx     AS_HELP_STRING([--enable-ld=<linker>],
   371         kx         [Use the specified linker. Both 'gold' and 'lld' linkers generally use less memory and link faster.
   371         kx          By default tries to use the best linker possible, use --disable-ld to use the default linker.
   371         kx          If <linker> contains any ':', the part before the first ':' is used as the value of
   371         kx          -fuse-ld, while the part after the first ':' is used as the value of --ld-path (which is
   371         kx          needed for Clang 12).]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(cups,
   371         kx     AS_HELP_STRING([--disable-cups],
   371         kx         [Do not build cups support.])
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(ccache,
   371         kx     AS_HELP_STRING([--disable-ccache],
   371         kx         [Do not try to use ccache automatically.
   371         kx          By default we will try to detect if ccache is available; in that case if
   371         kx          CC/CXX are not yet set, and --enable-icecream is not given, we
   371         kx          attempt to use ccache. --disable-ccache disables ccache completely.
   371         kx          Additionally ccache's depend mode is enabled if possible,
   371         kx          use --enable-ccache=nodepend to enable ccache without depend mode.
   371         kx ]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(z7-debug,
   371         kx     AS_HELP_STRING([--enable-z7-debug],
   371         kx         [Makes the MSVC compiler use -Z7 for debugging instead of the default -Zi. Using this option takes
   371         kx          more disk spaces but allows to use ccache. Final PDB files are created even with this option enabled.
   371         kx          Enabled by default if ccache is detected.]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(online-update,
   371         kx     AS_HELP_STRING([--enable-online-update],
   371         kx         [Enable the online update service that will check for new versions of
   371         kx          LibreOffice. Disabled by default. Requires --with-privacy-policy-url to be set.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(online-update-mar,
   371         kx     AS_HELP_STRING([--enable-online-update-mar],
   371         kx         [Enable the experimental Mozilla-like online update service that will
   371         kx          check for new versions of LibreOffice. Disabled by default.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-baseurl,
   371         kx     AS_HELP_STRING([--with-online-update-mar-baseurl=...],
   371         kx         [Set the base URL value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-certificateder,
   371         kx     AS_HELP_STRING([--with-online-update-mar-certificateder=...],
   371         kx         [Set the certificate DER value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-certificatename,
   371         kx     AS_HELP_STRING([--with-online-update-mar-certificatename=...],
   371         kx         [Set the certificate name value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-certificatepath,
   371         kx     AS_HELP_STRING([--with-online-update-mar-certificatepath=...],
   371         kx         [Set the certificate path value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-serverurl,
   371         kx     AS_HELP_STRING([--with-online-update-mar-serverurl=...],
   371         kx         [Set the server URL value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(online-update-mar-uploadurl,
   371         kx     AS_HELP_STRING([--with-online-update-mar-uploadurl=...],
   371         kx         [Set the upload URL value for --enable-online-update-mar.
   371         kx          (Can be left off for debug purposes, even if that may render the feature
   371         kx          non-functional.)]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(extension-update,
   371         kx     AS_HELP_STRING([--disable-extension-update],
   371         kx         [Disable possibility to update installed extensions.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(release-build,
   371         kx     AS_HELP_STRING([--enable-release-build],
   371         kx         [Enable release build. Note that the "release build" choice is orthogonal to
   371         kx          whether symbols are present, debug info is generated, or optimization
   371         kx          is done.
   371         kx          See https://wiki.documentfoundation.org/Development/DevBuild]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(windows-build-signing,
   371         kx     AS_HELP_STRING([--enable-windows-build-signing],
   371         kx         [Enable signing of windows binaries (*.exe, *.dll)]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(silent-msi,
   371         kx     AS_HELP_STRING([--enable-silent-msi],
   371         kx         [Enable MSI with LIMITUI=1 (silent install).]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(wix,
   371         kx     AS_HELP_STRING([--enable-wix],
   371         kx         [Build Windows installer using WiX.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(macosx-code-signing,
   371         kx     AS_HELP_STRING([--enable-macosx-code-signing=<identity>],
   371         kx         [Sign executables, dylibs, frameworks and the app bundle. If you
   371         kx          don't provide an identity the first suitable certificate
   371         kx          in your keychain is used.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(macosx-package-signing,
   371         kx     AS_HELP_STRING([--enable-macosx-package-signing=<identity>],
   371         kx         [Create a .pkg suitable for uploading to the Mac App Store and sign
   371         kx          it. If you don't provide an identity the first suitable certificate
   371         kx          in your keychain is used.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(macosx-sandbox,
   371         kx     AS_HELP_STRING([--enable-macosx-sandbox],
   371         kx         [Make the app bundle run in a sandbox. Requires code signing.
   371         kx          Is required by apps distributed in the Mac App Store, and implies
   371         kx          adherence to App Store rules.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(macosx-bundle-identifier,
   371         kx     AS_HELP_STRING([--with-macosx-bundle-identifier=tld.mumble.orifice.TheOffice],
   371         kx         [Define the macOS bundle identifier. Default is the somewhat weird
   371         kx          org.libreoffice.script ("script", huh?).]),
   371         kx ,with_macosx_bundle_identifier=org.libreoffice.script)
   371         kx 
   371         kx AC_ARG_WITH(macosx-provisioning-profile,
   371         kx     AS_HELP_STRING([--with-macosx-provisioning-profile=/path/to/mac.provisionprofile],
   371         kx         [Specify the path to a provisioning profile to use]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(product-name,
   371         kx     AS_HELP_STRING([--with-product-name='My Own Office Suite'],
   371         kx         [Define the product name. Default is AC_PACKAGE_NAME.]),
   371         kx ,with_product_name=$PRODUCTNAME)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(community-flavor,
   371         kx     AS_HELP_STRING([--disable-community-flavor],
   371         kx         [Disable the Community branding.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(package-version,
   371         kx     AS_HELP_STRING([--with-package-version='3.1.4.5'],
   371         kx         [Define the package version. Default is AC_PACKAGE_VERSION. Use only if you distribute an own build for macOS.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(readonly-installset,
   371         kx     AS_HELP_STRING([--enable-readonly-installset],
   371         kx         [Prevents any attempts by LibreOffice to write into its installation. That means
   371         kx          at least that no "system-wide" extensions can be added. Partly experimental work in
   371         kx          progress, probably not fully implemented. Always enabled for macOS.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(mariadb-sdbc,
   371         kx     AS_HELP_STRING([--disable-mariadb-sdbc],
   371         kx         [Disable the build of the MariaDB/MySQL-SDBC driver.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(postgresql-sdbc,
   371         kx     AS_HELP_STRING([--disable-postgresql-sdbc],
   371         kx         [Disable the build of the PostgreSQL-SDBC driver.])
   371         kx )
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(lotuswordpro,
   371         kx     AS_HELP_STRING([--disable-lotuswordpro],
   371         kx         [Disable the build of the Lotus Word Pro filter.]),
   371         kx ,test "${enable_lotuswordpro+set}" = set || enable_lotuswordpro=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(firebird-sdbc,
   371         kx     AS_HELP_STRING([--disable-firebird-sdbc],
   371         kx         [Disable the build of the Firebird-SDBC driver if it doesn't compile for you.]),
   371         kx ,test "${enable_firebird_sdbc+set}" = set || enable_firebird_sdbc=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(bogus-pkg-config,
   371         kx     AS_HELP_STRING([--enable-bogus-pkg-config],
   371         kx         [MACOSX only: on MacOSX pkg-config can cause trouble. by default if one is found in the PATH, an error is issued. This flag turn that error into a warning.]),
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(openssl,
   371         kx     AS_HELP_STRING([--disable-openssl],
   371         kx         [Disable using libssl/libcrypto from OpenSSL. If disabled,
   371         kx          components will use NSS. Work in progress,
   371         kx          use only if you are hacking on it.]),
   371         kx ,enable_openssl=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(cipher-openssl-backend,
   371         kx     AS_HELP_STRING([--enable-cipher-openssl-backend],
   371         kx         [Enable using OpenSSL as the actual implementation of the rtl/cipher.h functionality.
   371         kx          Requires --enable-openssl.]))
   371         kx 
   371         kx AC_ARG_ENABLE(nss,
   371         kx     AS_HELP_STRING([--disable-nss],
   371         kx         [Disable using NSS. If disabled,
   371         kx          components will use openssl. Work in progress,
   371         kx          use only if you are hacking on it.]),
   371         kx ,enable_nss=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(library-bin-tar,
   371         kx     AS_HELP_STRING([--enable-library-bin-tar],
   371         kx         [Enable the building and reused of tarball of binary build for some 'external' libraries.
   371         kx         Some libraries can save their build result in a tarball
   371         kx         stored in TARFILE_LOCATION. That binary tarball is
   371         kx         uniquely identified by the source tarball,
   371         kx         the content of the config_host.mk file and the content
   371         kx         of the top-level directory in core for that library
   371         kx         If this option is enabled, then if such a tarfile exist, it will be untarred
   371         kx         instead of the source tarfile, and the build step will be skipped for that
   371         kx         library.
   371         kx         If a proper tarfile does not exist, then the normal source-based
   371         kx         build is done for that library and a proper binary tarfile is created
   371         kx         for the next time.]),
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(dconf,
   371         kx     AS_HELP_STRING([--disable-dconf],
   371         kx         [Disable the dconf configuration backend (enabled by default where
   371         kx          available).]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(formula-logger,
   371         kx     AS_HELP_STRING(
   371         kx         [--enable-formula-logger],
   371         kx         [Enable formula logger for logging formula calculation flow in Calc.]
   371         kx     )
   371         kx )
   371         kx 
   371         kx AC_ARG_ENABLE(ldap,
   371         kx     AS_HELP_STRING([--disable-ldap],
   371         kx         [Disable LDAP support.]),
   371         kx ,enable_ldap=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(opencl,
   371         kx     AS_HELP_STRING([--disable-opencl],
   371         kx         [Disable OpenCL support.]),
   371         kx ,enable_opencl=yes)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(librelogo,
   371         kx     AS_HELP_STRING([--disable-librelogo],
   371         kx         [Do not build LibreLogo.]),
   371         kx ,enable_librelogo=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(wasm-strip,
   371         kx     AS_HELP_STRING([--enable-wasm-strip],
   371         kx         [Strip the static build like for WASM/emscripten platform.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(main-module,
   371         kx     AS_HELP_STRING([--with-main-module=<writer/calc>],
   371         kx         [Specify which main module to build for wasm.
   371         kx         Default value is 'writer'.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(wasm-exceptions,
   371         kx     AS_HELP_STRING([--enable-wasm-exceptions],
   371         kx         [Build with native WASM exceptions (AKA -fwasm-exceptions),
   371         kx         matter of fact, this is currently not finished by any implementation)
   371         kx         (see https://webassembly.org/roadmap/ for the current state]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_ENABLE(xmlhelp,
   371         kx     AS_HELP_STRING([--disable-xmlhelp],
   371         kx         [Disable XML help support]),
   371         kx ,enable_xmlhelp=yes)
   371         kx 
   371         kx AC_ARG_ENABLE(customtarget-components,
   371         kx     AS_HELP_STRING([--enable-customtarget-components],
   371         kx         [Generates the static UNO object constructor mapping from the build.]))
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Optional Packages (--with/without-)
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_ARG_WITH(gcc-home,
   371         kx     AS_HELP_STRING([--with-gcc-home],
   371         kx         [Specify the location of gcc/g++ manually. This can be used in conjunction
   371         kx          with --enable-icecream when icecream gcc/g++ wrappers are installed in a
   371         kx          non-default path.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(gnu-patch,
   371         kx     AS_HELP_STRING([--with-gnu-patch],
   371         kx         [Specify location of GNU patch on Solaris or FreeBSD.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(build-platform-configure-options,
   371         kx     AS_HELP_STRING([--with-build-platform-configure-options],
   371         kx         [Specify options for the configure script run for the *build* platform in a cross-compilation]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(gnu-cp,
   371         kx     AS_HELP_STRING([--with-gnu-cp],
   371         kx         [Specify location of GNU cp on Solaris or FreeBSD.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(external-tar,
   371         kx     AS_HELP_STRING([--with-external-tar=<TARFILE_PATH>],
   371         kx         [Specify an absolute path of where to find (and store) tarfiles.]),
   371         kx     TARFILE_LOCATION=$withval ,
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(referenced-git,
   371         kx     AS_HELP_STRING([--with-referenced-git=<OTHER_CHECKOUT_DIR>],
   371         kx         [Specify another checkout directory to reference. This makes use of
   371         kx                  git submodule update --reference, and saves a lot of diskspace
   371         kx                  when having multiple trees side-by-side.]),
   371         kx     GIT_REFERENCE_SRC=$withval ,
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(linked-git,
   371         kx     AS_HELP_STRING([--with-linked-git=<submodules repo basedir>],
   371         kx         [Specify a directory where the repositories of submodules are located.
   371         kx          This uses a method similar to git-new-workdir to get submodules.]),
   371         kx     GIT_LINK_SRC=$withval ,
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(galleries,
   371         kx     AS_HELP_STRING([--with-galleries],
   371         kx         [Specify how galleries should be built. It is possible either to
   371         kx          build these internally from source ("build"),
   371         kx          or to disable them ("no")]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(templates,
   371         kx     AS_HELP_STRING([--with-templates],
   371         kx         [Specify we build with or without template files. It is possible either to
   371         kx          build with templates ("yes"),
   371         kx          or to disable them ("no")]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(theme,
   371         kx     AS_HELP_STRING([--with-theme="theme1 theme2..."],
   371         kx         [Choose which themes to include. By default those themes with an '*' are included.
   371         kx          Possible choices: *breeze, *breeze_dark, *breeze_dark_svg, *breeze_svg,
   371         kx          *colibre, *colibre_svg, *colibre_dark, *colibre_dark_svg,
   371         kx          *elementary, *elementary_svg,
   371         kx          *karasa_jaga, *karasa_jaga_svg,
   371         kx          *sifr, *sifr_dark, *sifr_dark_svg, *sifr_svg,
   371         kx          *sukapura, *sukapura_dark, *sukapura_dark_svg, *sukapura_svg.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(helppack-integration,
   371         kx     AS_HELP_STRING([--without-helppack-integration],
   371         kx         [It will not integrate the helppacks to the installer
   371         kx          of the product. Please use this switch to use the online help
   371         kx          or separate help packages.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(fonts,
   371         kx     AS_HELP_STRING([--without-fonts],
   371         kx         [LibreOffice includes some third-party fonts to provide a reliable basis for
   371         kx          help content, templates, samples, etc. When these fonts are already
   371         kx          known to be available on the system then you should use this option.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(epm,
   371         kx     AS_HELP_STRING([--with-epm],
   371         kx         [Decides which epm to use. Default is to use the one from the system if
   371         kx          one is built. When either this is not there or you say =internal epm
   371         kx          will be built.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(package-format,
   371         kx     AS_HELP_STRING([--with-package-format],
   371         kx         [Specify package format(s) for LibreOffice installation sets. The
   371         kx          implicit --without-package-format leads to no installation sets being
   371         kx          generated. Possible values: archive, bsd, deb, dmg,
   371         kx          installed, msi, pkg, and rpm.
   371         kx          Example: --with-package-format='deb rpm']),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(tls,
   371         kx     AS_HELP_STRING([--with-tls],
   371         kx         [Decides which TLS/SSL and cryptographic implementations to use for
   371         kx          LibreOffice's code. Default is to use NSS although OpenSSL is also
   371         kx          possible. Notice that selecting NSS restricts the usage of OpenSSL
   371         kx          in LO's code but selecting OpenSSL doesn't restrict by now the
   371         kx          usage of NSS in LO's code. Possible values: openssl, nss.
   371         kx          Example: --with-tls="nss"]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(system-libs,
   371         kx     AS_HELP_STRING([--with-system-libs],
   371         kx         [Use libraries already on system -- enables all --with-system-* flags.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(system-bzip2,
   371         kx     AS_HELP_STRING([--with-system-bzip2],
   371         kx         [Use bzip2 already on system. Used when --enable-online-update-mar
   371         kx         or --enable-python=internal]),,
   371         kx     [with_system_bzip2="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-headers,
   371         kx     AS_HELP_STRING([--with-system-headers],
   371         kx         [Use headers already on system -- enables all --with-system-* flags for
   371         kx          external packages whose headers are the only entities used i.e.
   371         kx          boost/odbc/sane-header(s).]),,
   371         kx     [with_system_headers="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-jars,
   371         kx     AS_HELP_STRING([--without-system-jars],
   371         kx         [When building with --with-system-libs, also the needed jars are expected
   371         kx          on the system. Use this to disable that]),,
   371         kx     [with_system_jars="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-cairo,
   371         kx     AS_HELP_STRING([--with-system-cairo],
   371         kx         [Use cairo libraries already on system.  Happens automatically for
   371         kx          (implicit) --enable-gtk3.]))
   371         kx 
   371         kx AC_ARG_WITH(system-epoxy,
   371         kx     AS_HELP_STRING([--with-system-epoxy],
   371         kx         [Use epoxy libraries already on system.  Happens automatically for
   371         kx          (implicit) --enable-gtk3.]),,
   371         kx        [with_system_epoxy="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(myspell-dicts,
   371         kx     AS_HELP_STRING([--with-myspell-dicts],
   371         kx         [Adds myspell dictionaries to the LibreOffice installation set]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(system-dicts,
   371         kx     AS_HELP_STRING([--without-system-dicts],
   371         kx         [Do not use dictionaries from system paths.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(external-dict-dir,
   371         kx     AS_HELP_STRING([--with-external-dict-dir],
   371         kx         [Specify external dictionary dir.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(external-hyph-dir,
   371         kx     AS_HELP_STRING([--with-external-hyph-dir],
   371         kx         [Specify external hyphenation pattern dir.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(external-thes-dir,
   371         kx     AS_HELP_STRING([--with-external-thes-dir],
   371         kx         [Specify external thesaurus dir.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(system-zlib,
   371         kx     AS_HELP_STRING([--with-system-zlib],
   371         kx         [Use zlib already on system.]),,
   371         kx     [with_system_zlib=auto])
   371         kx 
   371         kx AC_ARG_WITH(system-jpeg,
   371         kx     AS_HELP_STRING([--with-system-jpeg],
   371         kx         [Use jpeg already on system.]),,
   371         kx     [with_system_jpeg="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-expat,
   371         kx     AS_HELP_STRING([--with-system-expat],
   371         kx         [Use expat already on system.]),,
   371         kx     [with_system_expat="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-libxml,
   371         kx     AS_HELP_STRING([--with-system-libxml],
   371         kx         [Use libxml/libxslt already on system.]),,
   371         kx     [with_system_libxml=auto])
   371         kx 
   371         kx AC_ARG_WITH(system-openldap,
   371         kx     AS_HELP_STRING([--with-system-openldap],
   371         kx         [Use the OpenLDAP LDAP SDK already on system.]),,
   371         kx     [with_system_openldap="$with_system_libs"])
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(poppler,
   371         kx     AS_HELP_STRING([--disable-poppler],
   371         kx         [Disable building Poppler.])
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(system-poppler,
   371         kx     AS_HELP_STRING([--with-system-poppler],
   371         kx         [Use system poppler (only needed for PDF import).]),,
   371         kx     [with_system_poppler="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-abseil,
   371         kx     AS_HELP_STRING([--with-system-abseil],
   371         kx         [Use the abseil libraries already on system.]),,
   371         kx     [with_system_abseil="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-openjpeg,
   371         kx     AS_HELP_STRING([--with-system-openjpeg],
   371         kx         [Use the OpenJPEG library already on system.]),,
   371         kx     [with_system_openjpeg="$with_system_libs"])
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(gpgmepp,
   371         kx     AS_HELP_STRING([--disable-gpgmepp],
   371         kx         [Disable building gpgmepp. Do not use in normal cases unless you want to fix potential problems it causes.])
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(system-gpgmepp,
   371         kx     AS_HELP_STRING([--with-system-gpgmepp],
   371         kx         [Use gpgmepp already on system]),,
   371         kx     [with_system_gpgmepp="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-mariadb,
   371         kx     AS_HELP_STRING([--with-system-mariadb],
   371         kx         [Use MariaDB/MySQL libraries already on system.]),,
   371         kx     [with_system_mariadb="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_ENABLE(bundle-mariadb,
   371         kx     AS_HELP_STRING([--enable-bundle-mariadb],
   371         kx         [When using MariaDB/MySQL libraries already on system, bundle them with the MariaDB Connector/LibreOffice.])
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(system-postgresql,
   371         kx     AS_HELP_STRING([--with-system-postgresql],
   371         kx         [Use PostgreSQL libraries already on system, for building the PostgreSQL-SDBC
   371         kx          driver. If pg_config is not in PATH, use PGCONFIG to point to it.]),,
   371         kx     [with_system_postgresql="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(libpq-path,
   371         kx     AS_HELP_STRING([--with-libpq-path=<absolute path to your libpq installation>],
   371         kx         [Use this PostgreSQL C interface (libpq) installation for building
   371         kx          the PostgreSQL-SDBC extension.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(system-firebird,
   371         kx     AS_HELP_STRING([--with-system-firebird],
   371         kx         [Use Firebird libraries already on system, for building the Firebird-SDBC
   371         kx          driver. If fb_config is not in PATH, use FBCONFIG to point to it.]),,
   371         kx     [with_system_firebird="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-libtommath,
   371         kx             AS_HELP_STRING([--with-system-libtommath],
   371         kx                            [Use libtommath already on system]),,
   371         kx             [with_system_libtommath="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-hsqldb,
   371         kx     AS_HELP_STRING([--with-system-hsqldb],
   371         kx         [Use hsqldb already on system.]))
   371         kx 
   371         kx AC_ARG_WITH(hsqldb-jar,
   371         kx     AS_HELP_STRING([--with-hsqldb-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     HSQLDB_JAR=$withval)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(scripting-beanshell,
   371         kx     AS_HELP_STRING([--disable-scripting-beanshell],
   371         kx         [Disable support for scripts in BeanShell.]),
   371         kx ,
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(system-beanshell,
   371         kx     AS_HELP_STRING([--with-system-beanshell],
   371         kx         [Use beanshell already on system.]),,
   371         kx     [with_system_beanshell="$with_system_jars"])
   371         kx 
   371         kx AC_ARG_WITH(beanshell-jar,
   371         kx     AS_HELP_STRING([--with-beanshell-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     BSH_JAR=$withval)
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(scripting-javascript,
   371         kx     AS_HELP_STRING([--disable-scripting-javascript],
   371         kx         [Disable support for scripts in JavaScript.]),
   371         kx ,
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(system-rhino,
   371         kx     AS_HELP_STRING([--with-system-rhino],
   371         kx         [Use rhino already on system.]),,)
   371         kx #    [with_system_rhino="$with_system_jars"])
   371         kx # Above is not used as we have different debug interface
   371         kx # patched into internal rhino. This code needs to be fixed
   371         kx # before we can enable it by default.
   371         kx 
   371         kx AC_ARG_WITH(rhino-jar,
   371         kx     AS_HELP_STRING([--with-rhino-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     RHINO_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(system-jfreereport,
   371         kx     AS_HELP_STRING([--with-system-jfreereport],
   371         kx         [Use JFreeReport already on system.]),,
   371         kx     [with_system_jfreereport="$with_system_jars"])
   371         kx 
   371         kx AC_ARG_WITH(sac-jar,
   371         kx     AS_HELP_STRING([--with-sac-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     SAC_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libxml-jar,
   371         kx     AS_HELP_STRING([--with-libxml-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBXML_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(flute-jar,
   371         kx     AS_HELP_STRING([--with-flute-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     FLUTE_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(jfreereport-jar,
   371         kx     AS_HELP_STRING([--with-jfreereport-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     JFREEREPORT_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(liblayout-jar,
   371         kx     AS_HELP_STRING([--with-liblayout-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBLAYOUT_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libloader-jar,
   371         kx     AS_HELP_STRING([--with-libloader-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBLOADER_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libformula-jar,
   371         kx     AS_HELP_STRING([--with-libformula-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBFORMULA_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(librepository-jar,
   371         kx     AS_HELP_STRING([--with-librepository-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBREPOSITORY_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libfonts-jar,
   371         kx     AS_HELP_STRING([--with-libfonts-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBFONTS_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libserializer-jar,
   371         kx     AS_HELP_STRING([--with-libserializer-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBSERIALIZER_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(libbase-jar,
   371         kx     AS_HELP_STRING([--with-libbase-jar=JARFILE],
   371         kx         [Specify path to jarfile manually.]),
   371         kx     LIBBASE_JAR=$withval)
   371         kx 
   371         kx AC_ARG_WITH(system-odbc,
   371         kx     AS_HELP_STRING([--with-system-odbc],
   371         kx         [Use the odbc headers already on system.]),,
   371         kx     [with_system_odbc="auto"])
   371         kx 
   371         kx AC_ARG_WITH(system-sane,
   371         kx     AS_HELP_STRING([--with-system-sane],
   371         kx         [Use sane.h already on system.]),,
   371         kx     [with_system_sane="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-bluez,
   371         kx     AS_HELP_STRING([--with-system-bluez],
   371         kx         [Use bluetooth.h already on system.]),,
   371         kx     [with_system_bluez="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-boost,
   371         kx     AS_HELP_STRING([--with-system-boost],
   371         kx         [Use boost already on system.]),,
   371         kx     [with_system_boost="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-dragonbox,
   371         kx     AS_HELP_STRING([--with-system-dragonbox],
   371         kx         [Use dragonbox already on system.]),,
   371         kx     [with_system_dragonbox="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-frozen,
   371         kx     AS_HELP_STRING([--with-system-frozen],
   371         kx         [Use frozen already on system.]),,
   371         kx     [with_system_frozen="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-libfixmath,
   371         kx     AS_HELP_STRING([--with-system-libfixmath],
   371         kx         [Use libfixmath already on system.]),,
   371         kx     [with_system_libfixmath="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-glm,
   371         kx     AS_HELP_STRING([--with-system-glm],
   371         kx         [Use glm already on system.]),,
   371         kx     [with_system_glm="$with_system_headers"])
   371         kx 
   371         kx AC_ARG_WITH(system-hunspell,
   371         kx     AS_HELP_STRING([--with-system-hunspell],
   371         kx         [Use libhunspell already on system.]),,
   371         kx     [with_system_hunspell="$with_system_libs"])
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(cairo-rgba,
   371         kx     AS_HELP_STRING([--enable-cairo-rgba],
   371         kx         [Use RGBA order, instead of default BRGA. Not possible with --with-system-cairo]))
   371         kx 
   371         kx libo_FUZZ_ARG_ENABLE(zxing,
   371         kx     AS_HELP_STRING([--disable-zxing],
   371         kx        [Disable use of zxing external library.]))
   371         kx 
   371         kx AC_ARG_WITH(system-zxing,
   371         kx     AS_HELP_STRING([--with-system-zxing],
   371         kx         [Use libzxing already on system.]),,
   371         kx     [with_system_zxing="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-zxcvbn,
   371         kx     AS_HELP_STRING([--with-system-zxcvbn],
   371         kx         [Use libzxcvbn already on system.]),,
   371         kx     [with_system_zxcvbn="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-box2d,
   371         kx     AS_HELP_STRING([--with-system-box2d],
   371         kx         [Use box2d already on system.]),,
   371         kx     [with_system_box2d="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-mythes,
   371         kx     AS_HELP_STRING([--with-system-mythes],
   371         kx         [Use mythes already on system.]),,
   371         kx     [with_system_mythes="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-altlinuxhyph,
   371         kx     AS_HELP_STRING([--with-system-altlinuxhyph],
   371         kx         [Use ALTLinuxhyph already on system.]),,
   371         kx     [with_system_altlinuxhyph="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-lpsolve,
   371         kx     AS_HELP_STRING([--with-system-lpsolve],
   371         kx         [Use lpsolve already on system.]),,
   371         kx     [with_system_lpsolve="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-coinmp,
   371         kx     AS_HELP_STRING([--with-system-coinmp],
   371         kx         [Use CoinMP already on system.]),,
   371         kx     [with_system_coinmp="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-liblangtag,
   371         kx     AS_HELP_STRING([--with-system-liblangtag],
   371         kx         [Use liblangtag library already on system.]),,
   371         kx     [with_system_liblangtag="$with_system_libs"])
   371         kx 
   371         kx AC_ARG_WITH(system-lockfile,
   371         kx     AS_HELP_STRING([--with-system-lockfile[=file]],
   371         kx         [Detect a system lockfile program or use the \$file argument.]))
   371         kx 
   371         kx AC_ARG_WITH(webdav,
   371         kx     AS_HELP_STRING([--without-webdav],
   371         kx         [Disable WebDAV support in the UCB.]))
   371         kx 
   371         kx AC_ARG_WITH(linker-hash-style,
   371         kx     AS_HELP_STRING([--with-linker-hash-style],
   371         kx         [Use linker with --hash-style=<style> when linking shared objects.
   371         kx          Possible values: "sysv", "gnu", "both". The default value is "gnu"
   371         kx          if supported on the build system, and "sysv" otherwise.]))
   371         kx 
   371         kx AC_ARG_WITH(jdk-home,
   371         kx     AS_HELP_STRING([--with-jdk-home=<absolute path to JDK home>],
   371         kx         [If you have installed JDK 17 or later on your system please supply the
   371         kx          path here. Note that this is not the location of the java command but the
   371         kx          location of the entire distribution. In case of cross-compiling, this
   371         kx          is the JDK of the host os. Use --with-build-platform-configure-options
   371         kx          to point to a different build platform JDK.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(help,
   371         kx     AS_HELP_STRING([--with-help],
   371         kx         [Enable the build of help. There is a special parameter "common" that
   371         kx          can be used to bundle only the common part, .e.g help-specific icons.
   371         kx          This is useful when you build the helpcontent separately.])
   371         kx     [
   371         kx                           Usage:     --with-help    build the old local help
   371         kx                                  --without-help     no local help (default)
   371         kx                                  --with-help=html   build the new HTML local help
   371         kx                                  --with-help=online build the new HTML online help
   371         kx     ],
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(omindex,
   371         kx    AS_HELP_STRING([--with-omindex],
   371         kx         [Enable the support of xapian-omega index for online help.])
   371         kx    [
   371         kx                          Usage: --with-omindex=server prepare the pages for omindex
   371         kx                                 but let xapian-omega be built in server.
   371         kx                                 --with-omindex=noxap do not prepare online pages
   371         kx                                 for xapian-omega
   371         kx   ],
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(java,
   371         kx     AS_HELP_STRING([--with-java=<java command>],
   371         kx         [Specify the name of the Java interpreter command. Typically "java"
   371         kx          which is the default.
   371         kx 
   371         kx          To build without support for Java components, applets, accessibility
   371         kx          or the XML filters written in Java, use --without-java or --with-java=no.]),
   371         kx     [ test -z "$with_java" -o "$with_java" = "yes" && with_java=java ],
   371         kx     [ test -z "$with_java" -o "$with_java" = "yes" && with_java=java ]
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(jvm-path,
   371         kx     AS_HELP_STRING([--with-jvm-path=<absolute path to parent of jvm home>],
   371         kx         [Use a specific JVM search path at runtime.
   371         kx          e.g. use --with-jvm-path=/usr/lib/ to find JRE/JDK in /usr/lib/jvm/]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(ant-home,
   371         kx     AS_HELP_STRING([--with-ant-home=<absolute path to Ant home>],
   371         kx         [If you have installed Apache Ant on your system, please supply the path here.
   371         kx          Note that this is not the location of the Ant binary but the location
   371         kx          of the entire distribution.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(symbol-config,
   371         kx     AS_HELP_STRING([--with-symbol-config],
   371         kx         [Configuration for the crashreport symbol upload]),
   371         kx         [],
   371         kx         [with_symbol_config=no])
   371         kx 
   371         kx AC_ARG_WITH(export-validation,
   371         kx     AS_HELP_STRING([--without-export-validation],
   371         kx         [Disable validating OOXML and ODF files as exported from in-tree tests.]),
   371         kx ,with_export_validation=auto)
   371         kx 
   371         kx AC_ARG_WITH(bffvalidator,
   371         kx     AS_HELP_STRING([--with-bffvalidator=<absolute path to BFFValidator>],
   371         kx         [Enables export validation for Microsoft Binary formats (doc, xls, ppt).
   371         kx          Requires installed Microsoft Office Binary File Format Validator.
   371         kx          Note: export-validation (--with-export-validation) is required to be turned on.
   371         kx          See https://web.archive.org/web/20200804155745/https://www.microsoft.com/en-us/download/details.aspx?id=26794]),
   371         kx ,with_bffvalidator=no)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(junit,
   371         kx     AS_HELP_STRING([--with-junit=<absolute path to JUnit 4 jar>],
   371         kx         [Specifies the JUnit 4 jar file to use for JUnit-based tests.
   371         kx          --without-junit disables those tests. Not relevant in the --without-java case.]),
   371         kx ,with_junit=yes)
   371         kx 
   371         kx AC_ARG_WITH(hamcrest,
   371         kx     AS_HELP_STRING([--with-hamcrest=<absolute path to hamcrest jar>],
   371         kx         [Specifies the hamcrest jar file to use for JUnit-based tests.
   371         kx          --without-junit disables those tests. Not relevant in the --without-java case.]),
   371         kx ,with_hamcrest=yes)
   371         kx 
   371         kx AC_ARG_WITH(perl-home,
   371         kx     AS_HELP_STRING([--with-perl-home=<abs. path to Perl 5 home>],
   371         kx         [If you have installed Perl 5 Distribution, on your system, please
   371         kx          supply the path here. Note that this is not the location of the Perl
   371         kx          binary but the location of the entire distribution.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(doxygen,
   371         kx     AS_HELP_STRING(
   371         kx         [--with-doxygen=<absolute path to doxygen executable>],
   371         kx         [Specifies the doxygen executable to use when generating ODK C/C++
   371         kx          documentation. --without-doxygen disables generation of ODK C/C++
   371         kx          documentation. Not relevant in the --disable-odk case.]),
   371         kx ,with_doxygen=yes)
   371         kx 
   371         kx AC_ARG_WITH(visual-studio,
   371         kx     AS_HELP_STRING([--with-visual-studio=<2019/2022/2022preview>],
   371         kx         [Specify which Visual Studio version to use in case several are
   371         kx          installed. Currently 2019 (default) and 2022 are supported.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(windows-sdk,
   371         kx     AS_HELP_STRING([--with-windows-sdk=<8.0(A)/8.1(A)/10.0>],
   371         kx         [Specify which Windows SDK, or "Windows Kit", version to use
   371         kx          in case the one that came with the selected Visual Studio
   371         kx          is not what you want for some reason. Note that not all compiler/SDK
   371         kx          combinations are supported. The intent is that this option should not
   371         kx          be needed.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(lang,
   371         kx     AS_HELP_STRING([--with-lang="es sw tu cs sk"],
   371         kx         [Use this option to build LibreOffice with additional UI language support.
   371         kx          English (US) is always included by default.
   371         kx          Separate multiple languages with space.
   371         kx          For all languages, use --with-lang=ALL.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(locales,
   371         kx     AS_HELP_STRING([--with-locales="en es pt fr zh kr ja"],
   371         kx         [Use this option to limit the locale information built in.
   371         kx          Separate multiple locales with space.
   371         kx          Very experimental and might well break stuff.
   371         kx          Just a desperate measure to shrink code and data size.
   371         kx          By default all the locales available is included.
   371         kx          Just works with --disable-dynloading. Defaults to "ALL".
   371         kx          This option is completely unrelated to --with-lang.])
   371         kx     [
   371         kx                           Affects also our character encoding conversion
   371         kx                           tables for encodings mainly targeted for a
   371         kx                           particular locale, like EUC-CN and EUC-TW for
   371         kx                           zh, ISO-2022-JP for ja.
   371         kx 
   371         kx                           Affects also our add-on break iterator data for
   371         kx                           some languages.
   371         kx 
   371         kx                           For the default, all locales, don't use this switch at all.
   371         kx                           Specifying just the language part of a locale means all matching
   371         kx                           locales will be included.
   371         kx     ],
   371         kx ,)
   371         kx 
   371         kx # Kerberos and GSSAPI used only by PostgreSQL as of LibO 3.5
   371         kx libo_FUZZ_ARG_WITH(krb5,
   371         kx     AS_HELP_STRING([--with-krb5],
   371         kx         [Enable MIT Kerberos 5 support in modules that support it.
   371         kx          By default automatically enabled on platforms
   371         kx          where a good system Kerberos 5 is available.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(gssapi,
   371         kx     AS_HELP_STRING([--with-gssapi],
   371         kx         [Enable GSSAPI support in modules that support it.
   371         kx          By default automatically enabled on platforms
   371         kx          where a good system GSSAPI is available.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(lxml,
   371         kx     AS_HELP_STRING([--without-lxml],
   371         kx         [gla11y will use python lxml when available, potentially building a local copy if necessary.
   371         kx          --without-lxml tells it to not use python lxml at all, which means that gla11y will only
   371         kx          report widget classes and ids.]),
   371         kx ,)
   371         kx 
   371         kx libo_FUZZ_ARG_WITH(latest-c++,
   371         kx     AS_HELP_STRING([--with-latest-c++],
   371         kx         [Try to enable the latest features of the C++ compiler, even if they are not yet part of a
   371         kx          published standard.  This option is ignored when CXXFLAGS_CXX11 is set explicitly.]),,
   371         kx         [with_latest_c__=no])
   371         kx 
   371         kx AC_ARG_WITH(gtk3-build,
   371         kx     AS_HELP_STRING([--with-gtk3-build=<absolute path to GTK3 build>],
   371         kx         [(Windows-only) In order to build GtkTiledViewer on Windows, pass the path
   371         kx          to a GTK3 build, like '--with-gtk3-build=C:/gtk-build/gtk/x64/release'.]))
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Branding
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_ARG_WITH(branding,
   371         kx     AS_HELP_STRING([--with-branding=/path/to/images],
   371         kx         [Use given path to retrieve branding images set.])
   371         kx     [
   371         kx                           Search for intro.png about.svg and logo.svg.
   371         kx                           If any is missing, default ones will be used instead.
   371         kx 
   371         kx                           Search also progress.conf for progress
   371         kx                           settings on intro screen :
   371         kx 
   371         kx                           PROGRESSBARCOLOR="255,255,255" Set color of
   371         kx                           progress bar. Comma separated RGB decimal values.
   371         kx                           PROGRESSSIZE="407,6" Set size of progress bar.
   371         kx                           Comma separated decimal values (width, height).
   371         kx                           PROGRESSPOSITION="61,317" Set position of progress
   371         kx                           bar from left,top. Comma separated decimal values.
   371         kx                           PROGRESSFRAMECOLOR="20,136,3" Set color of progress
   371         kx                           bar frame. Comma separated RGB decimal values.
   371         kx                           PROGRESSTEXTCOLOR="0,0,0" Set color of progress
   371         kx                           bar text. Comma separated RGB decimal values.
   371         kx                           PROGRESSTEXTBASELINE="287" Set vertical position of
   371         kx                           progress bar text from top. Decimal value.
   371         kx 
   371         kx                           Default values will be used if not found.
   371         kx     ],
   371         kx ,)
   371         kx 
   371         kx 
   371         kx AC_ARG_WITH(extra-buildid,
   371         kx     AS_HELP_STRING([--with-extra-buildid="Tinderbox: Win-x86@6, Branch:master, Date:2012-11-26_00.29.34"],
   371         kx         [Show addition build identification in about dialog.]),
   371         kx ,)
   371         kx 
   371         kx 
   371         kx AC_ARG_WITH(vendor,
   371         kx     AS_HELP_STRING([--with-vendor="John the Builder"],
   371         kx         [Set vendor of the build.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(privacy-policy-url,
   371         kx     AS_HELP_STRING([--with-privacy-policy-url="https://yourdomain/privacy-policy"],
   371         kx         [The URL to your privacy policy (needed when
   371         kx          enabling online-update or crashreporting via breakpad)]),
   371         kx         [if test "x$with_privacy_policy_url" = "xyes"; then
   371         kx             AC_MSG_FAILURE([you need to specify an argument when using --with-privacy-policy-url])
   371         kx          elif test "x$with_privacy_policy_url" = "xno"; then
   371         kx             with_privacy_policy_url="undefined"
   371         kx          fi]
   371         kx ,[with_privacy_policy_url="undefined"])
   371         kx 
   371         kx AC_ARG_WITH(android-package-name,
   371         kx     AS_HELP_STRING([--with-android-package-name="org.libreoffice"],
   371         kx         [Set Android package name of the build.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(compat-oowrappers,
   371         kx     AS_HELP_STRING([--with-compat-oowrappers],
   371         kx         [Install oo* wrappers in parallel with
   371         kx          lo* ones to keep backward compatibility.
   371         kx          Has effect only with make distro-pack-install]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(os-version,
   371         kx     AS_HELP_STRING([--with-os-version=<OSVERSION>],
   371         kx         [For FreeBSD users, use this option to override the detected OSVERSION.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(parallelism,
   371         kx     AS_HELP_STRING([--with-parallelism],
   371         kx         [Number of jobs to run simultaneously during build. Parallel builds can
   371         kx         save a lot of time on multi-cpu machines. Defaults to the number of
   371         kx         CPUs on the machine, unless you configure --enable-icecream - then to
   371         kx         40.]),
   371         kx ,)
   371         kx 
   371         kx AC_ARG_WITH(all-tarballs,
   371         kx     AS_HELP_STRING([--with-all-tarballs],
   371         kx         [Download all external tarballs unconditionally]))
   371         kx 
   371         kx AC_ARG_WITH(gdrive-client-id,
   371         kx     AS_HELP_STRING([--with-gdrive-client-id],
   371         kx         [Provides the client id of the application for OAuth2 authentication
   371         kx         on Google Drive. If either this or --with-gdrive-client-secret is
   371         kx         empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(gdrive-client-secret,
   371         kx     AS_HELP_STRING([--with-gdrive-client-secret],
   371         kx         [Provides the client secret of the application for OAuth2
   371         kx         authentication on Google Drive. If either this or
   371         kx         --with-gdrive-client-id is empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(alfresco-cloud-client-id,
   371         kx     AS_HELP_STRING([--with-alfresco-cloud-client-id],
   371         kx         [Provides the client id of the application for OAuth2 authentication
   371         kx         on Alfresco Cloud. If either this or --with-alfresco-cloud-client-secret is
   371         kx         empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(alfresco-cloud-client-secret,
   371         kx     AS_HELP_STRING([--with-alfresco-cloud-client-secret],
   371         kx         [Provides the client secret of the application for OAuth2
   371         kx         authentication on Alfresco Cloud. If either this or
   371         kx         --with-alfresco-cloud-client-id is empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(onedrive-client-id,
   371         kx     AS_HELP_STRING([--with-onedrive-client-id],
   371         kx         [Provides the client id of the application for OAuth2 authentication
   371         kx         on OneDrive. If either this or --with-onedrive-client-secret is
   371         kx         empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx AC_ARG_WITH(onedrive-client-secret,
   371         kx     AS_HELP_STRING([--with-onedrive-client-secret],
   371         kx         [Provides the client secret of the application for OAuth2
   371         kx         authentication on OneDrive. If either this or
   371         kx         --with-onedrive-client-id is empty, the feature will be disabled]),
   371         kx )
   371         kx 
   371         kx dnl Check for coredumpctl support to present information about crashing test processes:
   371         kx AC_ARG_WITH(coredumpctl,
   371         kx     AS_HELP_STRING([--with-coredumpctl],
   371         kx         [Use coredumpctl (together with systemd-run) to retrieve core dumps of crashing test
   371         kx         processes.]))
   371         kx 
   371         kx AC_ARG_WITH(buildconfig-recorded,
   371         kx     AS_HELP_STRING([--with-buildconfig-recorded],
   371         kx         [Put build config into version info reported by LOK. Incompatible with reproducible builds.]),
   371         kx )
   371         kx 
   371         kx AC_MSG_CHECKING([whether to record build config])
   371         kx if test -z "$with_buildconfig_recorded"; then
   371         kx     with_buildconfig_recorded=no
   371         kx fi
   371         kx if test "$with_buildconfig_recorded" = no; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     # replace backslashes, to get a valid c++ string
   371         kx     config_args=$(echo $ac_configure_args | tr '\\' '/')
   371         kx     AC_DEFINE_UNQUOTED([BUILDCONFIG],[["$config_args"]],[Options passed to configure script])
   371         kx     AC_DEFINE([BUILDCONFIG_RECORDED],[1],[Options passed to configure script])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Do we want to use pre-build binary tarball for recompile
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$enable_library_bin_tar" = "yes" ; then
   371         kx     USE_LIBRARY_BIN_TAR=TRUE
   371         kx else
   371         kx     USE_LIBRARY_BIN_TAR=
   371         kx fi
   371         kx AC_SUBST(USE_LIBRARY_BIN_TAR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether build target is Release Build
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether build target is Release Build])
   371         kx if test "$enable_release_build" = "" -o "$enable_release_build" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_RELEASE_BUILD=
   371         kx     dnl Pu the value on one line as make (at least on macOS) seems to ignore
   371         kx     dnl the newlines and then complains about spaces.
   371         kx     GET_TASK_ALLOW_ENTITLEMENT='<!-- We want to be able to debug a hardened process when not building for release --><key>com.apple.security.get-task-allow</key><true/>'
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_RELEASE_BUILD=TRUE
   371         kx     GET_TASK_ALLOW_ENTITLEMENT=
   371         kx fi
   371         kx AC_SUBST(ENABLE_RELEASE_BUILD)
   371         kx AC_SUBST(GET_TASK_ALLOW_ENTITLEMENT)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build a Community flavor])
   371         kx if test -z "$enable_community_flavor" -o "$enable_community_flavor" = "yes"; then
   371         kx     AC_DEFINE(HAVE_FEATURE_COMMUNITY_FLAVOR)
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to sign Windows Build
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to sign windows build])
   371         kx if test "$enable_windows_build_signing" = "yes" -a "$_os" = "WINNT"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     WINDOWS_BUILD_SIGNING="TRUE"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     WINDOWS_BUILD_SIGNING="FALSE"
   371         kx fi
   371         kx AC_SUBST(WINDOWS_BUILD_SIGNING)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl MacOSX build and runtime environment options
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_ARG_WITH(macosx-version-min-required,
   371         kx     AS_HELP_STRING([--with-macosx-version-min-required=<version>],
   371         kx         [set the minimum OS version needed to run the built LibreOffice])
   371         kx     [
   371         kx                           e. g.: --with-macosx-version-min-required=10.15
   371         kx     ],
   371         kx ,)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for incompatible options set by fuzzing, and reset those
   371         kx dnl automatically to working combinations
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$libo_fuzzed_enable_dbus" = yes -a "$libo_fuzzed_enable_avahi" -a \
   371         kx         "$enable_dbus" != "$enable_avahi"; then
   371         kx     AC_MSG_NOTICE([Resetting --enable-avahi=$enable_dbus])
   371         kx     enable_avahi=$enable_dbus
   371         kx fi
   371         kx 
   371         kx add_lopath_after ()
   371         kx {
   371         kx     if ! echo "$LO_PATH" | $EGREP -q "(^|${P_SEP})$1($|${P_SEP})"; then
   371         kx         LO_PATH="${LO_PATH:+$LO_PATH$P_SEP}$1"
   371         kx     fi
   371         kx }
   371         kx 
   371         kx add_lopath_before ()
   371         kx {
   371         kx     local IFS=${P_SEP}
   371         kx     local path_cleanup
   371         kx     local dir
   371         kx     for dir in $LO_PATH ; do
   371         kx         if test "$dir" != "$1" ; then
   371         kx             path_cleanup=${path_cleanup:+$path_cleanup$P_SEP}$dir
   371         kx         fi
   371         kx     done
   371         kx     LO_PATH="$1${path_cleanup:+$P_SEP$path_cleanup}"
   371         kx }
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl check for required programs (grep, awk, sed, bash)
   371         kx dnl ===================================================================
   371         kx 
   371         kx pathmunge ()
   371         kx {
   371         kx     local new_path
   371         kx     if test -n "$1"; then
   371         kx         if test "$build_os" = "cygwin"; then
   371         kx             if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx                 PathFormat "$1"
   371         kx                 new_path=`cygpath -sm "$formatted_path"`
   371         kx             else
   371         kx                 PathFormat "$1"
   371         kx                 new_path=`cygpath -u "$formatted_path"`
   371         kx             fi
   371         kx         else
   371         kx             new_path="$1"
   371         kx         fi
   371         kx         if test "$2" = "after"; then
   371         kx             add_lopath_after "$new_path"
   371         kx         else
   371         kx             add_lopath_before "$new_path"
   371         kx         fi
   371         kx     fi
   371         kx }
   371         kx 
   371         kx AC_PROG_AWK
   371         kx AC_PATH_PROG( AWK, $AWK)
   371         kx if test -z "$AWK"; then
   371         kx     AC_MSG_ERROR([install awk to run this script])
   371         kx fi
   371         kx 
   371         kx AC_PATH_PROG(BASH, bash)
   371         kx if test -z "$BASH"; then
   371         kx     AC_MSG_ERROR([bash not found in \$PATH])
   371         kx fi
   371         kx AC_SUBST(BASH)
   371         kx 
   371         kx # prefer parallel compression tools, if available
   371         kx AC_PATH_PROG(COMPRESSIONTOOL, pigz)
   371         kx if test -z "$COMPRESSIONTOOL"; then
   371         kx     AC_PATH_PROG(COMPRESSIONTOOL, gzip)
   371         kx     if test -z "$COMPRESSIONTOOL"; then
   371         kx         AC_MSG_ERROR([gzip not found in \$PATH])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(COMPRESSIONTOOL)
   371         kx 
   371         kx AC_MSG_CHECKING([for GNU or BSD tar])
   371         kx for a in $GNUTAR gtar gnutar tar bsdtar /usr/sfw/bin/gtar; do
   371         kx     $a --version 2> /dev/null | grep -E "GNU|bsdtar"  2>&1 > /dev/null
   371         kx     if test $? -eq 0;  then
   371         kx         GNUTAR=$a
   371         kx         break
   371         kx     fi
   371         kx done
   371         kx AC_MSG_RESULT($GNUTAR)
   371         kx if test -z "$GNUTAR"; then
   371         kx     AC_MSG_ERROR([not found. install GNU or BSD tar.])
   371         kx fi
   371         kx AC_SUBST(GNUTAR)
   371         kx 
   371         kx AC_MSG_CHECKING([for tar's option to strip components])
   371         kx $GNUTAR --help 2> /dev/null | grep -E "bsdtar|strip-components" 2>&1 >/dev/null
   371         kx if test $? -eq 0; then
   371         kx     STRIP_COMPONENTS="--strip-components"
   371         kx else
   371         kx     $GNUTAR --help 2> /dev/null | grep -E "strip-path" 2>&1 >/dev/null
   371         kx     if test $? -eq 0; then
   371         kx         STRIP_COMPONENTS="--strip-path"
   371         kx     else
   371         kx         STRIP_COMPONENTS="unsupported"
   371         kx     fi
   371         kx fi
   371         kx AC_MSG_RESULT($STRIP_COMPONENTS)
   371         kx if test x$STRIP_COMPONENTS = xunsupported; then
   371         kx     AC_MSG_ERROR([you need a tar that is able to strip components.])
   371         kx fi
   371         kx AC_SUBST(STRIP_COMPONENTS)
   371         kx 
   371         kx dnl It is useful to have a BUILD_TYPE keyword to distinguish "normal"
   371         kx dnl desktop OSes from "mobile" ones.
   371         kx 
   371         kx dnl We assume that a non-DESKTOP build type is also a non-NATIVE one.
   371         kx dnl In other words, that when building for an OS that is not a
   371         kx dnl "desktop" one but a "mobile" one, we are always cross-compiling.
   371         kx 
   371         kx dnl Note the direction of the implication; there is no assumption that
   371         kx dnl cross-compiling would imply a non-desktop OS.
   371         kx 
   371         kx if test $_os != iOS -a $_os != Android -a "$enable_fuzzers" != "yes"; then
   371         kx     BUILD_TYPE="$BUILD_TYPE DESKTOP"
   371         kx     AC_DEFINE(HAVE_FEATURE_DESKTOP)
   371         kx     if test "$_os" != Emscripten; then
   371         kx         AC_DEFINE(HAVE_FEATURE_MULTIUSER_ENVIRONMENT)
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx # explicitly doesn't include enable_gtk3=no and enable_qt5=yes, so it should
   371         kx # also work with the default gtk3 plugin.
   371         kx if test "$enable_wasm_strip" = "yes"; then
   371         kx     enable_avmedia=no
   371         kx     enable_libcmis=no
   371         kx     enable_coinmp=no
   371         kx     enable_cups=no
   371         kx     test "$_os" = Emscripten && enable_curl=no
   371         kx     enable_database_connectivity=no
   371         kx     enable_dbus=no
   371         kx     enable_dconf=no
   371         kx     test "${enable_dynamic_loading+set}" = set -o "$_os" != Emscripten || enable_dynamic_loading=no
   371         kx     enable_extension_integration=no
   371         kx     enable_extensions=no
   371         kx     enable_extension_update=no
   371         kx     enable_gio=no
   371         kx     enable_gpgmepp=no
   371         kx     enable_ldap=no
   371         kx     enable_lotuswordpro=no
   371         kx     enable_lpsolve=no
   371         kx     enable_nss=no
   371         kx     enable_odk=no
   371         kx     enable_online_update=no
   371         kx     enable_opencl=no
   371         kx     enable_pdfimport=no
   371         kx     enable_randr=no
   371         kx     enable_report_builder=no
   371         kx     enable_scripting=no
   371         kx     enable_sdremote_bluetooth=no
   371         kx     enable_skia=no
   371         kx     enable_xmlhelp=no
   371         kx     enable_zxing=no
   371         kx     test_libepubgen=no
   371         kx     test_libcdr=no
   371         kx     test_libcmis=no
   371         kx     test_libetonyek=no
   371         kx     test_libfreehand=no
   371         kx     test_libmspub=no
   371         kx     test_libpagemaker=no
   371         kx     test_libqxp=no
   371         kx     test_libvisio=no
   371         kx     test_libzmf=no
   371         kx     test_webdav=no
   371         kx     with_galleries=no
   371         kx     with_templates=no
   371         kx     with_webdav=no
   371         kx     with_x=no
   371         kx 
   371         kx     test "${with_fonts+set}" = set || with_fonts=yes
   371         kx     test "${with_locales+set}" = set || with_locales=en
   371         kx 
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_ACCESSIBILITY)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_WRITER)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_CALC)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_CANVAS)
   371         kx #    AC_DEFINE(ENABLE_WASM_STRIP_CHART)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_DBACCESS)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_EPUB)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_EXTRA)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_GUESSLANG)
   371         kx #    AC_DEFINE(ENABLE_WASM_STRIP_HUNSPELL)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_LANGUAGETOOL)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_PINGUSER)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_PREMULTIPLY)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_RECENT)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_RECOVERYUI)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_SPLASH)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_SWEXPORTS)
   371         kx     AC_DEFINE(ENABLE_WASM_STRIP_SCEXPORTS)
   371         kx fi
   371         kx 
   371         kx EMSCRIPTEN_NEH_MAJOR=3
   371         kx EMSCRIPTEN_NEH_MINOR=1
   371         kx EMSCRIPTEN_NEH_TINY=3
   371         kx EMSCRIPTEN_NEH_VERSION="${EMSCRIPTEN_NEH_MAJOR}.${EMSCRIPTEN_NEH_MINOR}.${EMSCRIPTEN_NEH_TINY}"
   371         kx 
   371         kx if test "$enable_wasm_exceptions" = yes; then
   371         kx     AC_MSG_CHECKING([if Emscripten version is at least $EMSCRIPTEN_NEH_VERSION for SjLj + native EH])
   371         kx     check_semantic_version_three_prefixed EMSCRIPTEN NEH
   371         kx     if test $? -ne 0; then
   371         kx         AC_MSG_ERROR([no, found $EMSCRIPTEN_VERSION])
   371         kx     else
   371         kx         AC_MSG_RESULT([yes ($EMSCRIPTEN_VERSION)])
   371         kx     fi
   371         kx     ENABLE_WASM_EXCEPTIONS=TRUE
   371         kx fi
   371         kx AC_SUBST(ENABLE_WASM_EXCEPTIONS)
   371         kx 
   371         kx # Whether to build "avmedia" functionality or not.
   371         kx 
   371         kx if test "$enable_avmedia" = yes; then
   371         kx     BUILD_TYPE="$BUILD_TYPE AVMEDIA"
   371         kx     AC_DEFINE(HAVE_FEATURE_AVMEDIA)
   371         kx else
   371         kx     test_gstreamer_1_0=no
   371         kx fi
   371         kx 
   371         kx # Decide whether to build database connectivity stuff (including Base) or not.
   371         kx if test "$enable_database_connectivity" != no; then
   371         kx     BUILD_TYPE="$BUILD_TYPE DBCONNECTIVITY"
   371         kx     AC_DEFINE(HAVE_FEATURE_DBCONNECTIVITY)
   371         kx else
   371         kx     if test "$_os" = iOS; then
   371         kx         AC_MSG_ERROR([Presumly can't disable DB connectivity on iOS.])
   371         kx     fi
   371         kx     disable_database_connectivity_dependencies
   371         kx fi
   371         kx 
   371         kx if test -z "$enable_extensions"; then
   371         kx     # For iOS and Android Viewer, disable extensions unless specifically overridden with --enable-extensions.
   371         kx     if test $_os != iOS && test $_os != Android -o "$ENABLE_ANDROID_LOK" = TRUE ; then
   371         kx         enable_extensions=yes
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx DISABLE_SCRIPTING=''
   371         kx if test "$enable_scripting" = yes; then
   371         kx     BUILD_TYPE="$BUILD_TYPE SCRIPTING"
   371         kx     AC_DEFINE(HAVE_FEATURE_SCRIPTING)
   371         kx else
   371         kx     DISABLE_SCRIPTING='TRUE'
   371         kx     SCPDEFS="$SCPDEFS -DDISABLE_SCRIPTING"
   371         kx fi
   371         kx 
   371         kx if test $_os = iOS -o $_os = Android -o $_os = Emscripten; then
   371         kx     # Disable dynamic_loading always for iOS and Android
   371         kx     enable_dynamic_loading=no
   371         kx elif test -z "$enable_dynamic_loading"; then
   371         kx     # Otherwise enable it unless specifically disabled
   371         kx     enable_dynamic_loading=yes
   371         kx fi
   371         kx 
   371         kx DISABLE_DYNLOADING=''
   371         kx if test "$enable_dynamic_loading" = yes; then
   371         kx     BUILD_TYPE="$BUILD_TYPE DYNLOADING"
   371         kx else
   371         kx     DISABLE_DYNLOADING='TRUE'
   371         kx     if test $_os != iOS -a $_os != Android; then
   371         kx         enable_database_connectivity=no
   371         kx         enable_nss=no
   371         kx         enable_odk=no
   371         kx         enable_python=no
   371         kx         enable_skia=no
   371         kx         with_java=no
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(DISABLE_DYNLOADING)
   371         kx 
   371         kx ENABLE_CUSTOMTARGET_COMPONENTS=
   371         kx if test "$enable_customtarget_components" = yes -a "$DISABLE_DYNLOADING" = TRUE; then
   371         kx     ENABLE_CUSTOMTARGET_COMPONENTS=TRUE
   371         kx     if test -n "$with_locales" -a "$with_locales" != en -a "$with_locales" != ALL; then
   371         kx         AC_MSG_ERROR([Currently just --with-locales=all or en is supported with --enable-customtarget-components])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_CUSTOMTARGET_COMPONENTS)
   371         kx 
   371         kx if test "$enable_extensions" = yes; then
   371         kx     BUILD_TYPE="$BUILD_TYPE EXTENSIONS"
   371         kx     AC_DEFINE(HAVE_FEATURE_EXTENSIONS)
   371         kx else
   371         kx     enable_extension_integration=no
   371         kx     enable_extension_update=no
   371         kx fi
   371         kx 
   371         kx # remember SYSBASE value
   371         kx AC_SUBST(SYSBASE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Sort out various gallery compilation options
   371         kx dnl ===================================================================
   371         kx WITH_GALLERY_BUILD=TRUE
   371         kx AC_MSG_CHECKING([how to build and package galleries])
   371         kx if test -n "${with_galleries}"; then
   371         kx     if test "$with_galleries" = "build"; then
   371         kx         if test "$enable_database_connectivity" = no; then
   371         kx             AC_MSG_ERROR([DB connectivity is needed for gengal / svx])
   371         kx         fi
   371         kx         AC_MSG_RESULT([build from source images internally])
   371         kx     elif test "$with_galleries" = "no"; then
   371         kx         WITH_GALLERY_BUILD=
   371         kx         AC_MSG_RESULT([disable non-internal gallery build])
   371         kx     else
   371         kx         AC_MSG_ERROR([unknown value --with-galleries=$with_galleries])
   371         kx     fi
   371         kx else
   371         kx     if test $_os != iOS -a $_os != Android; then
   371         kx         AC_MSG_RESULT([internal src images for desktop])
   371         kx     else
   371         kx         WITH_GALLERY_BUILD=
   371         kx         AC_MSG_RESULT([disable src image build])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(WITH_GALLERY_BUILD)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Sort out various templates compilation options
   371         kx dnl ===================================================================
   371         kx WITH_TEMPLATES=TRUE
   371         kx AC_MSG_CHECKING([build with or without template files])
   371         kx if test -n "${with_templates}"; then
   371         kx     if test "$with_templates" = "yes"; then
   371         kx         AC_MSG_RESULT([enable all templates])
   371         kx     elif test "$with_templates" = "no"; then
   371         kx         WITH_TEMPLATES=
   371         kx         AC_MSG_RESULT([disable non-internal templates])
   371         kx     else
   371         kx         AC_MSG_ERROR([unknown value --with-templates=$with_templates])
   371         kx     fi
   371         kx else
   371         kx     if test $_os != iOS -a $_os != Android -a $_os != Emscripten; then
   371         kx         AC_MSG_RESULT([enable all templates])
   371         kx     else
   371         kx         WITH_TEMPLATES=
   371         kx         AC_MSG_RESULT([disable non-internal templates])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(WITH_TEMPLATES)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Checks if ccache is available
   371         kx dnl ===================================================================
   371         kx CCACHE_DEPEND_MODE=
   371         kx if test "$enable_ccache" = "no"; then
   371         kx     CCACHE=""
   371         kx elif test -n "$enable_ccache" -o \( "$enable_ccache" = "" -a "$enable_icecream" != "yes" \); then
   371         kx     case "%$CC%$CXX%" in
   371         kx     # If $CC and/or $CXX already contain "ccache" (possibly suffixed with some version number etc),
   371         kx     # assume that's good then
   371         kx     *%ccache[[-_' ']]*|*/ccache[[-_' ']]*)
   371         kx         AC_MSG_NOTICE([ccache seems to be included in a pre-defined CC and/or CXX])
   371         kx         CCACHE_DEPEND_MODE=1
   371         kx         ;;
   371         kx     *)
   371         kx         # try to use our own ccache if it is available and CCACHE was not already defined
   371         kx         if test -z "$CCACHE"; then
   371         kx             if test "$_os" = "WINNT"; then
   371         kx                 ccache_ext=.exe # e.g. openssl build needs ccache.exe, not just ccache
   371         kx             fi
   371         kx             if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/ccache$ccache_ext" ; then
   371         kx                 CCACHE="$LODE_HOME/opt/bin/ccache$ccache_ext"
   371         kx             elif test -x "/opt/lo/bin/ccache$ccache_ext"; then
   371         kx                 CCACHE="/opt/lo/bin/ccache$ccache_ext"
   371         kx             fi
   371         kx         fi
   371         kx         AC_PATH_PROG([CCACHE],[ccache],[not found])
   371         kx         if test "$CCACHE" != "not found" -a "$_os" = "WINNT"; then
   371         kx             CCACHE=`win_short_path_for_make "$CCACHE"`
   371         kx             # check that it has MSVC support (it should recognize it in CCACHE_COMPILERTYPE)
   371         kx             rm -f conftest.txt
   371         kx             AC_MSG_CHECKING([whether $CCACHE has MSVC support])
   371         kx             CCACHE_COMPILERTYPE=cl CCACHE_LOGFILE=conftest.txt $CCACHE echo >/dev/null 2>/dev/null
   371         kx             if grep -q 'Config: (environment) compiler_type = cl' conftest.txt; then
   371         kx                 AC_MSG_RESULT(yes)
   371         kx             else
   371         kx                 AC_MSG_RESULT(no)
   371         kx                 CCACHE="not found"
   371         kx             fi
   371         kx             rm -f conftest.txt
   371         kx         fi
   371         kx         if test "$CCACHE" = "not found" -a "$_os" = "WINNT"; then
   371         kx             # on windows/VC perhaps sccache is around?
   371         kx             case "%$CC%$CXX%" in
   371         kx             # If $CC and/or $CXX already contain "sccache" (possibly suffixed with some version number etc),
   371         kx             # assume that's good then
   371         kx             *%sccache[[-_' ']]*|*/sccache[[-_' ']]*)
   371         kx                 AC_MSG_NOTICE([sccache seems to be included in a pre-defined CC and/or CXX])
   371         kx                 CCACHE_DEPEND_MODE=1
   371         kx                 SCCACHE=1
   371         kx                 ;;
   371         kx             *)
   371         kx                 # for sharing code below, reuse CCACHE env var
   371         kx                 AC_PATH_PROG([CCACHE],[sccache],[not found])
   371         kx                 if test "$CCACHE" != "not found"; then
   371         kx                     CCACHE=`win_short_path_for_make "$CCACHE"`
   371         kx                     SCCACHE=1
   371         kx                     CCACHE_DEPEND_MODE=1
   371         kx                 fi
   371         kx                 ;;
   371         kx             esac
   371         kx         fi
   371         kx         if test "$CCACHE" = "not found"; then
   371         kx             CCACHE=""
   371         kx         fi
   371         kx         if test -n "$CCACHE" -a -z "$SCCACHE"; then
   371         kx             CCACHE_DEPEND_MODE=1
   371         kx             # Need to check for ccache version: otherwise prevents
   371         kx             # caching of the results (like "-x objective-c++" for Mac)
   371         kx             if test $_os = Darwin -o $_os = iOS; then
   371         kx                 # Check ccache version
   371         kx                 AC_MSG_CHECKING([whether version of ccache is suitable])
   371         kx                 CCACHE_VERSION=`"$CCACHE" -V | "$AWK" '/^ccache version/{print $3}'`
   371         kx                 CCACHE_NUMVER=`echo $CCACHE_VERSION | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
   371         kx                 if test "$CCACHE_VERSION" = "2.4_OOo" -o "$CCACHE_NUMVER" -ge "030100"; then
   371         kx                     AC_MSG_RESULT([yes, $CCACHE_VERSION])
   371         kx                 else
   371         kx                     AC_MSG_RESULT([no, $CCACHE_VERSION])
   371         kx                     CCACHE=""
   371         kx                     CCACHE_DEPEND_MODE=
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     CCACHE=""
   371         kx fi
   371         kx if test "$enable_ccache" = "nodepend"; then
   371         kx     CCACHE_DEPEND_MODE=""
   371         kx fi
   371         kx AC_SUBST(CCACHE_DEPEND_MODE)
   371         kx 
   371         kx # sccache defaults are good enough
   371         kx if test "$CCACHE" != "" -a -z "$SCCACHE"; then
   371         kx     # e.g. (/home/rene/.config/ccache/ccache.conf) max_size = 20.0G
   371         kx     # or (...) max_size = 20.0 G
   371         kx     # -p works with both 4.2 and 4.4
   371         kx     ccache_size_msg=$([$CCACHE -p | $AWK /max_size/'{ print $4 $5 }' | sed -e 's/\.[0-9]*//'])
   371         kx     ccache_size=$(echo "$ccache_size_msg" | grep "G" | sed -e 's/G.*$//')
   371         kx     if test "$ccache_size" = ""; then
   371         kx         ccache_size=$(echo "$ccache_size_msg" | grep "M" | sed -e 's/\ M.*$//')
   371         kx         if test "$ccache_size" = ""; then
   371         kx             ccache_size=0
   371         kx         fi
   371         kx         # we could not determine the size or it was less than 1GB -> disable auto-ccache
   371         kx         if test $ccache_size -lt 1024; then
   371         kx             CCACHE=""
   371         kx             AC_MSG_WARN([ccache's cache size is less than 1GB using it is counter-productive: Disabling auto-ccache detection])
   371         kx             add_warning "ccache's cache size is less than 1GB using it is counter-productive: auto-ccache detection disabled"
   371         kx         else
   371         kx             # warn that ccache may be too small for debug build
   371         kx             AC_MSG_WARN([ccache's cache size is less than 5GB using it may be counter-productive for debug or symbol-enabled build])
   371         kx             add_warning "ccache's cache size is less than 5GB using it may be counter-productive for debug or symbol-enabled build"
   371         kx         fi
   371         kx     else
   371         kx         if test $ccache_size -lt 5; then
   371         kx             #warn that ccache may be too small for debug build
   371         kx             AC_MSG_WARN([ccache's cache size is less than 5GB using it may be counter-productive for debug or symbol-enabled build])
   371         kx             add_warning "ccache's cache size is less than 5GB using it may be counter-productive for debug or symbol-enabled build"
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx ENABLE_Z7_DEBUG=
   371         kx if test "$enable_z7_debug" != no; then
   371         kx     if test "$enable_z7_debug" = yes -o -n "$CCACHE"; then
   371         kx         ENABLE_Z7_DEBUG=TRUE
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_WARN([ccache will not work with --disable-z7-debug])
   371         kx     add_warning "ccache will not work with --disable-z7-debug"
   371         kx fi
   371         kx AC_SUBST(ENABLE_Z7_DEBUG)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Checks for C compiler,
   371         kx dnl  The check for the C++ compiler is later on.
   371         kx dnl ===================================================================
   371         kx if test "$_os" != "WINNT"; then
   371         kx     GCC_HOME_SET="true"
   371         kx     AC_MSG_CHECKING([gcc home])
   371         kx     if test -z "$with_gcc_home"; then
   371         kx         if test "$enable_icecream" = "yes"; then
   371         kx             if test -d "/usr/lib/icecc/bin"; then
   371         kx                 GCC_HOME="/usr/lib/icecc/"
   371         kx             elif test -d "/usr/libexec/icecc/bin"; then
   371         kx                 GCC_HOME="/usr/libexec/icecc/"
   371         kx             elif test -d "/opt/icecream/bin"; then
   371         kx                 GCC_HOME="/opt/icecream/"
   371         kx             else
   371         kx                 AC_MSG_ERROR([Could not figure out the location of icecream GCC wrappers, manually use --with-gcc-home])
   371         kx 
   371         kx             fi
   371         kx         else
   371         kx             GCC_HOME=`which gcc | $SED -e s,/bin/gcc,,`
   371         kx             GCC_HOME_SET="false"
   371         kx         fi
   371         kx     else
   371         kx         GCC_HOME="$with_gcc_home"
   371         kx     fi
   371         kx     AC_MSG_RESULT($GCC_HOME)
   371         kx     AC_SUBST(GCC_HOME)
   371         kx 
   371         kx     if test "$GCC_HOME_SET" = "true"; then
   371         kx         if test -z "$CC"; then
   371         kx             CC="$GCC_HOME/bin/gcc"
   371         kx             CC_BASE="gcc"
   371         kx         fi
   371         kx         if test -z "$CXX"; then
   371         kx             CXX="$GCC_HOME/bin/g++"
   371         kx             CXX_BASE="g++"
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx COMPATH=`dirname "$CC"`
   371         kx if test "$COMPATH" = "."; then
   371         kx     AC_PATH_PROGS(COMPATH, $CC)
   371         kx     dnl double square bracket to get single because of M4 quote...
   371         kx     COMPATH=`echo $COMPATH | $SED "s@/[[^/:]]*\\\$@@"`
   371         kx fi
   371         kx COMPATH=`echo $COMPATH | $SED "s@/[[Bb]][[Ii]][[Nn]]\\\$@@"`
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Java support
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to build with Java support])
   371         kx if test "$with_java" != "no"; then
   371         kx     if test "$DISABLE_SCRIPTING" = TRUE; then
   371         kx         AC_MSG_RESULT([no, overridden by --disable-scripting])
   371         kx         ENABLE_JAVA=""
   371         kx         with_java=no
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx         ENABLE_JAVA="TRUE"
   371         kx         AC_DEFINE(HAVE_FEATURE_JAVA)
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_JAVA=""
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_JAVA)
   371         kx 
   371         kx dnl ENABLE_JAVA="TRUE" if we want there to be *run-time* (and build-time) support for Java
   371         kx 
   371         kx dnl ENABLE_JAVA="" indicate no Java support at all
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check macOS SDK and compiler
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test $_os = Darwin; then
   371         kx 
   371         kx     # The SDK in the currently selected Xcode should be found.
   371         kx 
   371         kx     AC_MSG_CHECKING([what macOS SDK to use])
   371         kx     # XCode only ships with a single SDK for a while now, and using older SDKs alongside is not
   371         kx     # really supported anymore, instead you'd use different copies of Xcode, each with their own
   371         kx     # SDK, and thus xcrun will pick the SDK that matches the currently selected Xcode version
   371         kx     # also restricting the SDK version to "known good" versions doesn't seem necessary anymore, the
   371         kx     # problems that existed in the PPC days with target versions not being respected or random
   371         kx     # failures seems to be a thing of the past or rather: limiting either the Xcode version or the
   371         kx     # SDK version is enough, no need to do both...
   371         kx     MACOSX_SDK_PATH=`xcrun --sdk macosx --show-sdk-path 2> /dev/null`
   371         kx     if test ! -d "$MACOSX_SDK_PATH"; then
   371         kx         AC_MSG_ERROR([Could not find an appropriate macOS SDK])
   371         kx     fi
   371         kx     macosx_sdk=`xcodebuild -version -sdk "$MACOSX_SDK_PATH" SDKVersion`
   371         kx     MACOSX_SDK_BUILD_VERSION=$(xcodebuild -version -sdk "$MACOSX_SDK_PATH" ProductBuildVersion)
   371         kx     # format changed between 10.9 and 10.10 - up to 10.9 it was just four digits (1090), starting
   371         kx     # with macOS 10.10 it was switched to account for x.y.z with six digits, 10.10 is 101000,
   371         kx     # 10.10.2 is 101002
   371         kx     # we don't target the lower versions anymore, so it doesn't matter that we don't generate the
   371         kx     # correct version in case such an old SDK is specified, it will be rejected later anyway
   371         kx     MACOSX_SDK_VERSION=$(echo $macosx_sdk | $AWK -F. '{ print $1*10000+$2*100+$3 }')
   371         kx     if test $MACOSX_SDK_VERSION -lt 101500; then
   371         kx         AC_MSG_ERROR([macOS SDK $macosx_sdk is not supported, lowest supported version is 10.15])
   371         kx     fi
   371         kx     if test "$host_cpu" = arm64 -a $MACOSX_SDK_VERSION -lt 110000; then
   371         kx         AC_MSG_ERROR([macOS SDK $macosx_sdk is not supported for Apple Silicon (need at least 11.0)])
   371         kx     fi
   371         kx     AC_MSG_RESULT([macOS SDK $macosx_sdk at $MACOSX_SDK_PATH])
   371         kx 
   371         kx     AC_MSG_CHECKING([what minimum version of macOS to require])
   371         kx     if test "$with_macosx_version_min_required" = "" ; then
   371         kx         if test "$host_cpu" = x86_64; then
   371         kx             with_macosx_version_min_required="10.15";
   371         kx         else
   371         kx             with_macosx_version_min_required="11.0";
   371         kx         fi
   371         kx     fi
   371         kx     # see same notes about MACOSX_SDK_VERSION above
   371         kx     MAC_OS_X_VERSION_MIN_REQUIRED=$(echo $with_macosx_version_min_required | $AWK -F. '{ print $1*10000+$2*100+$3 }')
   371         kx     if test $MAC_OS_X_VERSION_MIN_REQUIRED -lt 101500; then
   371         kx         AC_MSG_ERROR([with-macosx-version-min-required $with_macosx_version_min_required is not a supported value, minimum supported version is 10.15])
   371         kx     fi
   371         kx     AC_MSG_RESULT([$with_macosx_version_min_required])
   371         kx 
   371         kx     AC_MSG_CHECKING([that macosx-version-min-required is coherent with macos-with-sdk])
   371         kx     if test $MAC_OS_X_VERSION_MIN_REQUIRED -gt $MACOSX_SDK_VERSION; then
   371         kx         AC_MSG_ERROR([the version minimum required ($with_macosx_version_min_required) cannot be greater than the sdk level ($macosx_sdk)])
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx     fi
   371         kx 
   371         kx     # export this so that "xcrun" invocations later return matching values
   371         kx     DEVELOPER_DIR="${MACOSX_SDK_PATH%/SDKs*}"
   371         kx     DEVELOPER_DIR="${DEVELOPER_DIR%/Platforms*}"
   371         kx     export DEVELOPER_DIR
   371         kx     FRAMEWORKSHOME="$MACOSX_SDK_PATH/System/Library/Frameworks"
   371         kx     MACOSX_DEPLOYMENT_TARGET="$with_macosx_version_min_required"
   371         kx 
   371         kx     AC_MSG_CHECKING([whether Xcode is new enough])
   371         kx     my_xcode_ver1=$(xcrun xcodebuild -version | head -n 1)
   371         kx     my_xcode_ver2=${my_xcode_ver1#Xcode }
   371         kx     my_xcode_ver3=$(printf %s "$my_xcode_ver2" | $AWK -F. '{ print $1*100+($2<100?$2:99) }')
   371         kx     if test "$my_xcode_ver3" -ge 1205; then
   371         kx         AC_MSG_RESULT([yes ($my_xcode_ver2)])
   371         kx         if test $MAC_OS_X_VERSION_MIN_REQUIRED -lt 120000; then
   371         kx             if test "$my_xcode_ver3" -ge 1600; then
   371         kx                 dnl the Xcode 15 relnotes state that the classic linker will disappear in the next version, but nothing about
   371         kx                 dnl fixing the problem with weak symbols/macOS 11 compatibility, so assume for now that Xcode 16 will break it...
   371         kx                 AC_MSG_ERROR([Check that Xcode 16 still supports the old linker/that it doesn't break macOS 11 compatibility, then remove this check]);
   371         kx             fi
   371         kx             if test "$my_xcode_ver3" -ge 1500; then
   371         kx                 AC_MSG_WARN([Xcode 15 has a new linker that causes runtime crashes on macOS 11])
   371         kx                 add_warning "Xcode 15 has a new linker that causes runtime crashes on macOS 11, forcing the old linker."
   371         kx                 add_warning "see https://developer.apple.com/documentation/xcode-release-notes/xcode-15-release-notes#Linking"
   371         kx                 LDFLAGS="$LDFLAGS -Wl,-ld_classic"
   371         kx                 # if LDFLAGS weren't set already, a check above sets x_LDFLAGS=[#] to comment-out the export LDFLAGS line in config_host.mk
   371         kx                 x_LDFLAGS=
   371         kx             fi
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_ERROR(["$my_xcode_ver1" is too old or unrecognized, must be at least Xcode 12.5])
   371         kx     fi
   371         kx 
   371         kx     my_xcode_ver1=$(xcrun xcodebuild -version | tail -n 1)
   371         kx     MACOSX_XCODE_BUILD_VERSION=${my_xcode_ver1#Build version }
   371         kx 
   371         kx     LIBTOOL=/usr/bin/libtool
   371         kx     INSTALL_NAME_TOOL=install_name_tool
   371         kx     if test -z "$save_CC"; then
   371         kx         stdlib=-stdlib=libc++
   371         kx 
   371         kx         AC_MSG_CHECKING([what C compiler to use])
   371         kx         CC="`xcrun -find clang`"
   371         kx         CC_BASE=`first_arg_basename "$CC"`
   371         kx         if test "$host_cpu" = x86_64; then
   371         kx             CC+=" -target x86_64-apple-macos"
   371         kx         else
   371         kx             CC+=" -target arm64-apple-macos"
   371         kx         fi
   371         kx         CC+=" -mmacosx-version-min=$with_macosx_version_min_required -isysroot $MACOSX_SDK_PATH"
   371         kx         AC_MSG_RESULT([$CC])
   371         kx 
   371         kx         AC_MSG_CHECKING([what C++ compiler to use])
   371         kx         CXX="`xcrun -find clang++`"
   371         kx         CXX_BASE=`first_arg_basename "$CXX"`
   371         kx         if test "$host_cpu" = x86_64; then
   371         kx             CXX+=" -target x86_64-apple-macos"
   371         kx         else
   371         kx             CXX+=" -target arm64-apple-macos"
   371         kx         fi
   371         kx         CXX+=" $stdlib -mmacosx-version-min=$with_macosx_version_min_required -isysroot $MACOSX_SDK_PATH"
   371         kx         AC_MSG_RESULT([$CXX])
   371         kx 
   371         kx         INSTALL_NAME_TOOL=`xcrun -find install_name_tool`
   371         kx         AR=`xcrun -find ar`
   371         kx         NM=`xcrun -find nm`
   371         kx         STRIP=`xcrun -find strip`
   371         kx         LIBTOOL=`xcrun -find libtool`
   371         kx         RANLIB=`xcrun -find ranlib`
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether to do code signing])
   371         kx 
   371         kx     if test -z "$enable_macosx_code_signing" -o "$enable_macosx_code_signing" == "no" ; then
   371         kx         AC_MSG_RESULT([no])
   371         kx     else
   371         kx         if test "$enable_macosx_code_signing" = yes; then
   371         kx             # By default use the first suitable certificate (?).
   371         kx 
   371         kx             # https://stackoverflow.com/questions/13196291/difference-between-mac-developer-and-3rd-party-mac-developer-application
   371         kx             # says that the "Mac Developer" certificate is useful just for self-testing. For distribution
   371         kx             # outside the Mac App Store, use the "Developer ID Application" one, and for distribution in
   371         kx             # the App Store, the "3rd Party Mac Developer" one. I think it works best to the
   371         kx             # "Developer ID Application" one.
   371         kx             identity="Developer ID Application:"
   371         kx         else
   371         kx             identity=$enable_macosx_code_signing
   371         kx         fi
   371         kx         identity=`security find-identity -p codesigning -v 2>/dev/null | $AWK "/$identity/{print \\$2; exit}"`
   371         kx         if test -n "$identity"; then
   371         kx             MACOSX_CODESIGNING_IDENTITY=$identity
   371         kx             pretty_name=`security find-identity -p codesigning -v | grep "$MACOSX_CODESIGNING_IDENTITY" | sed -e 's/^[[^"]]*"//' -e 's/"//'`
   371         kx             AC_MSG_RESULT([yes, using the identity $MACOSX_CODESIGNING_IDENTITY for $pretty_name])
   371         kx         else
   371         kx             AC_MSG_ERROR([cannot determine identity to use])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether to create a Mac App Store package])
   371         kx 
   371         kx     if test -z "$enable_macosx_package_signing" || test "$enable_macosx_package_signing" == no; then
   371         kx         AC_MSG_RESULT([no])
   371         kx     elif test -z "$MACOSX_CODESIGNING_IDENTITY"; then
   371         kx         AC_MSG_ERROR([You forgot --enable-macosx-code-signing])
   371         kx     else
   371         kx         if test "$enable_macosx_package_signing" = yes; then
   371         kx             # By default use the first suitable certificate.
   371         kx             # It should be a "3rd Party Mac Developer Installer" one
   371         kx             identity="3rd Party Mac Developer Installer:"
   371         kx         else
   371         kx             identity=$enable_macosx_package_signing
   371         kx         fi
   371         kx         identity=`security find-identity -v 2>/dev/null | $AWK "/$identity/ {print \\$2; exit}"`
   371         kx         if test -n "$identity"; then
   371         kx             MACOSX_PACKAGE_SIGNING_IDENTITY=$identity
   371         kx             pretty_name=`security find-identity -v | grep "$MACOSX_PACKAGE_SIGNING_IDENTITY" | sed -e 's/^[[^"]]*"//' -e 's/"//'`
   371         kx             AC_MSG_RESULT([yes, using the identity $MACOSX_PACKAGE_SIGNING_IDENTITY for $pretty_name])
   371         kx         else
   371         kx             AC_MSG_ERROR([Could not find any suitable '3rd Party Mac Developer Installer' certificate])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     if test -n "$MACOSX_CODESIGNING_IDENTITY" -a -n "$MACOSX_PACKAGE_SIGNING_IDENTITY" -a "$MACOSX_CODESIGNING_IDENTITY" = "$MACOSX_PACKAGE_SIGNING_IDENTITY"; then
   371         kx         AC_MSG_ERROR([You should not use the same identity for code and package signing])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether to sandbox the application])
   371         kx 
   371         kx     if test -n "$ENABLE_JAVA" -a "$enable_macosx_sandbox" = yes; then
   371         kx         AC_MSG_ERROR([macOS sandboxing (actually App Store rules) disallows use of Java])
   371         kx     elif test "$enable_macosx_sandbox" = yes; then
   371         kx         ENABLE_MACOSX_SANDBOX=TRUE
   371         kx         AC_DEFINE(HAVE_FEATURE_MACOSX_SANDBOX)
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([what macOS app bundle identifier to use])
   371         kx     MACOSX_BUNDLE_IDENTIFIER=$with_macosx_bundle_identifier
   371         kx     AC_MSG_RESULT([$MACOSX_BUNDLE_IDENTIFIER])
   371         kx 
   371         kx     if test -n "$with_macosx_provisioning_profile" ; then
   371         kx         if test ! -f "$with_macosx_provisioning_profile"; then
   371         kx             AC_MSG_ERROR([provisioning profile not found at $with_macosx_provisioning_profile])
   371         kx         else
   371         kx             MACOSX_PROVISIONING_PROFILE=$with_macosx_provisioning_profile
   371         kx             MACOSX_PROVISIONING_INFO=$([security cms -D -i "$MACOSX_PROVISIONING_PROFILE" | \
   371         kx                 xmllint --xpath "//key[.='com.apple.application-identifier' or .='com.apple.developer.team-identifier'] \
   371         kx                     | //key[.='com.apple.application-identifier' or .='com.apple.developer.team-identifier']/following-sibling::string[1]" - | \
   371         kx                 sed -e 's#><#>\n\t<#g' -e 's#^#\t#'])
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(MACOSX_SDK_PATH)
   371         kx AC_SUBST(MACOSX_DEPLOYMENT_TARGET)
   371         kx AC_SUBST(MAC_OS_X_VERSION_MIN_REQUIRED)
   371         kx AC_SUBST(INSTALL_NAME_TOOL)
   371         kx AC_SUBST(LIBTOOL) # Note that the macOS libtool command is unrelated to GNU libtool
   371         kx AC_SUBST(MACOSX_CODESIGNING_IDENTITY)
   371         kx AC_SUBST(MACOSX_PACKAGE_SIGNING_IDENTITY)
   371         kx AC_SUBST(ENABLE_MACOSX_SANDBOX)
   371         kx AC_SUBST(MACOSX_BUNDLE_IDENTIFIER)
   371         kx AC_SUBST(MACOSX_PROVISIONING_INFO)
   371         kx AC_SUBST(MACOSX_PROVISIONING_PROFILE)
   371         kx AC_SUBST(MACOSX_SDK_BUILD_VERSION)
   371         kx AC_SUBST(MACOSX_XCODE_BUILD_VERSION)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check iOS SDK and compiler
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test $_os = iOS; then
   371         kx     AC_MSG_CHECKING([what iOS SDK to use])
   371         kx 
   371         kx     if test "$enable_ios_simulator" = "yes"; then
   371         kx         platformlc=iphonesimulator
   371         kx         versionmin=-mios-simulator-version-min=14.5
   371         kx     else
   371         kx         platformlc=iphoneos
   371         kx         versionmin=-miphoneos-version-min=14.5
   371         kx     fi
   371         kx 
   371         kx     sysroot=`xcrun --sdk $platformlc --show-sdk-path`
   371         kx 
   371         kx     if ! test -d "$sysroot"; then
   371         kx         AC_MSG_ERROR([Could not find iOS SDK $sysroot])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_RESULT($sysroot)
   371         kx 
   371         kx     stdlib="-stdlib=libc++"
   371         kx 
   371         kx     AC_MSG_CHECKING([what C compiler to use])
   371         kx     CC="`xcrun -find clang`"
   371         kx     CC_BASE=`first_arg_basename "$CC"`
   371         kx     CC+=" -arch $host_cpu_for_clang -isysroot $sysroot $versionmin"
   371         kx     AC_MSG_RESULT([$CC])
   371         kx 
   371         kx     AC_MSG_CHECKING([what C++ compiler to use])
   371         kx     CXX="`xcrun -find clang++`"
   371         kx     CXX_BASE=`first_arg_basename "$CXX"`
   371         kx     CXX+=" -arch $host_cpu_for_clang $stdlib -isysroot $sysroot $versionmin"
   371         kx     AC_MSG_RESULT([$CXX])
   371         kx 
   371         kx     INSTALL_NAME_TOOL=`xcrun -find install_name_tool`
   371         kx     AR=`xcrun -find ar`
   371         kx     NM=`xcrun -find nm`
   371         kx     STRIP=`xcrun -find strip`
   371         kx     LIBTOOL=`xcrun -find libtool`
   371         kx     RANLIB=`xcrun -find ranlib`
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to treat the installation as read-only])
   371         kx 
   371         kx if test $_os = Darwin; then
   371         kx     enable_readonly_installset=yes
   371         kx elif test "$enable_extensions" != yes; then
   371         kx     enable_readonly_installset=yes
   371         kx fi
   371         kx if test "$enable_readonly_installset" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     AC_DEFINE(HAVE_FEATURE_READONLY_INSTALLSET)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Structure of install set
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test $_os = Darwin; then
   371         kx     LIBO_BIN_FOLDER=MacOS
   371         kx     LIBO_ETC_FOLDER=Resources
   371         kx     LIBO_LIBEXEC_FOLDER=MacOS
   371         kx     LIBO_LIB_FOLDER=Frameworks
   371         kx     LIBO_LIB_PYUNO_FOLDER=Resources
   371         kx     LIBO_SHARE_FOLDER=Resources
   371         kx     LIBO_SHARE_HELP_FOLDER=Resources/help
   371         kx     LIBO_SHARE_JAVA_FOLDER=Resources/java
   371         kx     LIBO_SHARE_PRESETS_FOLDER=Resources/presets
   371         kx     LIBO_SHARE_READMES_FOLDER=Resources/readmes
   371         kx     LIBO_SHARE_RESOURCE_FOLDER=Resources/resource
   371         kx     LIBO_SHARE_SHELL_FOLDER=Resources/shell
   371         kx     LIBO_URE_BIN_FOLDER=MacOS
   371         kx     LIBO_URE_ETC_FOLDER=Resources/ure/etc
   371         kx     LIBO_URE_LIB_FOLDER=Frameworks
   371         kx     LIBO_URE_MISC_FOLDER=Resources/ure/share/misc
   371         kx     LIBO_URE_SHARE_JAVA_FOLDER=Resources/java
   371         kx elif test $_os = WINNT; then
   371         kx     LIBO_BIN_FOLDER=program
   371         kx     LIBO_ETC_FOLDER=program
   371         kx     LIBO_LIBEXEC_FOLDER=program
   371         kx     LIBO_LIB_FOLDER=program
   371         kx     LIBO_LIB_PYUNO_FOLDER=program
   371         kx     LIBO_SHARE_FOLDER=share
   371         kx     LIBO_SHARE_HELP_FOLDER=help
   371         kx     LIBO_SHARE_JAVA_FOLDER=program/classes
   371         kx     LIBO_SHARE_PRESETS_FOLDER=presets
   371         kx     LIBO_SHARE_READMES_FOLDER=readmes
   371         kx     LIBO_SHARE_RESOURCE_FOLDER=program/resource
   371         kx     LIBO_SHARE_SHELL_FOLDER=program/shell
   371         kx     LIBO_URE_BIN_FOLDER=program
   371         kx     LIBO_URE_ETC_FOLDER=program
   371         kx     LIBO_URE_LIB_FOLDER=program
   371         kx     LIBO_URE_MISC_FOLDER=program
   371         kx     LIBO_URE_SHARE_JAVA_FOLDER=program/classes
   371         kx else
   371         kx     LIBO_BIN_FOLDER=program
   371         kx     LIBO_ETC_FOLDER=program
   371         kx     LIBO_LIBEXEC_FOLDER=program
   371         kx     LIBO_LIB_FOLDER=program
   371         kx     LIBO_LIB_PYUNO_FOLDER=program
   371         kx     LIBO_SHARE_FOLDER=share
   371         kx     LIBO_SHARE_HELP_FOLDER=help
   371         kx     LIBO_SHARE_JAVA_FOLDER=program/classes
   371         kx     LIBO_SHARE_PRESETS_FOLDER=presets
   371         kx     LIBO_SHARE_READMES_FOLDER=readmes
   371         kx     if test "$enable_fuzzers" != yes; then
   371         kx         LIBO_SHARE_RESOURCE_FOLDER=program/resource
   371         kx     else
   371         kx         LIBO_SHARE_RESOURCE_FOLDER=resource
   371         kx     fi
   371         kx     LIBO_SHARE_SHELL_FOLDER=program/shell
   371         kx     LIBO_URE_BIN_FOLDER=program
   371         kx     LIBO_URE_ETC_FOLDER=program
   371         kx     LIBO_URE_LIB_FOLDER=program
   371         kx     LIBO_URE_MISC_FOLDER=program
   371         kx     LIBO_URE_SHARE_JAVA_FOLDER=program/classes
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED(LIBO_BIN_FOLDER,"$LIBO_BIN_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_ETC_FOLDER,"$LIBO_ETC_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_LIBEXEC_FOLDER,"$LIBO_LIBEXEC_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_LIB_FOLDER,"$LIBO_LIB_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_LIB_PYUNO_FOLDER,"$LIBO_LIB_PYUNO_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_FOLDER,"$LIBO_SHARE_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_HELP_FOLDER,"$LIBO_SHARE_HELP_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_JAVA_FOLDER,"$LIBO_SHARE_JAVA_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_PRESETS_FOLDER,"$LIBO_SHARE_PRESETS_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_RESOURCE_FOLDER,"$LIBO_SHARE_RESOURCE_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_SHARE_SHELL_FOLDER,"$LIBO_SHARE_SHELL_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_URE_BIN_FOLDER,"$LIBO_URE_BIN_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_URE_ETC_FOLDER,"$LIBO_URE_ETC_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_URE_LIB_FOLDER,"$LIBO_URE_LIB_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_URE_MISC_FOLDER,"$LIBO_URE_MISC_FOLDER")
   371         kx AC_DEFINE_UNQUOTED(LIBO_URE_SHARE_JAVA_FOLDER,"$LIBO_URE_SHARE_JAVA_FOLDER")
   371         kx 
   371         kx # Not all of them needed in config_host.mk, add more if need arises
   371         kx AC_SUBST(LIBO_BIN_FOLDER)
   371         kx AC_SUBST(LIBO_ETC_FOLDER)
   371         kx AC_SUBST(LIBO_LIB_FOLDER)
   371         kx AC_SUBST(LIBO_LIB_PYUNO_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_HELP_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_JAVA_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_PRESETS_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_READMES_FOLDER)
   371         kx AC_SUBST(LIBO_SHARE_RESOURCE_FOLDER)
   371         kx AC_SUBST(LIBO_URE_BIN_FOLDER)
   371         kx AC_SUBST(LIBO_URE_ETC_FOLDER)
   371         kx AC_SUBST(LIBO_URE_LIB_FOLDER)
   371         kx AC_SUBST(LIBO_URE_MISC_FOLDER)
   371         kx AC_SUBST(LIBO_URE_SHARE_JAVA_FOLDER)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Windows specific tests and stuff
   371         kx dnl ===================================================================
   371         kx 
   371         kx reg_get_value()
   371         kx {
   371         kx     # Return value: $regvalue
   371         kx     unset regvalue
   371         kx 
   371         kx     if test "$build_os" = "wsl"; then
   371         kx         regvalue=$($WSL_LO_HELPER --read-registry $1 "$2" 2>/dev/null)
   371         kx         return
   371         kx     fi
   371         kx 
   371         kx     local _regentry="/proc/registry${1}/${2}"
   371         kx     if test -f "$_regentry"; then
   371         kx         # Stop bash complaining about \0 bytes in input, as it can't handle them.
   371         kx         # Registry keys read via /proc/registry* are always \0 terminated!
   371         kx         local _regvalue=$(tr -d '\0' < "$_regentry")
   371         kx         if test $? -eq 0; then
   371         kx             regvalue=$_regvalue
   371         kx         fi
   371         kx     fi
   371         kx }
   371         kx 
   371         kx # Get a value from the 32-bit side of the Registry
   371         kx reg_get_value_32()
   371         kx {
   371         kx     reg_get_value "32" "$1"
   371         kx }
   371         kx 
   371         kx # Get a value from the 64-bit side of the Registry
   371         kx reg_get_value_64()
   371         kx {
   371         kx     reg_get_value "64" "$1"
   371         kx }
   371         kx 
   371         kx reg_list_values()
   371         kx {
   371         kx     # Return value: $reglist
   371         kx     unset reglist
   371         kx 
   371         kx     if test "$build_os" = "wsl"; then
   371         kx         reglist=$($WSL_LO_HELPER --list-registry $1 "$2" 2>/dev/null | tr -d '\r')
   371         kx         return
   371         kx     fi
   371         kx 
   371         kx     reglist=$(ls "/proc/registry${1}/${2}")
   371         kx }
   371         kx 
   371         kx # List values from the 32-bit side of the Registry
   371         kx reg_list_values_32()
   371         kx {
   371         kx     reg_list_values "32" "$1"
   371         kx }
   371         kx 
   371         kx # List values from the 64-bit side of the Registry
   371         kx reg_list_values_64()
   371         kx {
   371         kx     reg_list_values "64" "$1"
   371         kx }
   371         kx 
   371         kx case "$host_os" in
   371         kx cygwin*|wsl*)
   371         kx     COM=MSC
   371         kx     OS=WNT
   371         kx     RTL_OS=Windows
   371         kx     if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx         P_SEP=";"
   371         kx     else
   371         kx         P_SEP=:
   371         kx     fi
   371         kx     case "$host_cpu" in
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=windows_x86_64
   371         kx         WINDOWS_X64=1
   371         kx         SCPDEFS="$SCPDEFS -DWINDOWS_X64"
   371         kx         WIN_HOST_ARCH="x64"
   371         kx         WIN_MULTI_ARCH="x86"
   371         kx         WIN_HOST_BITS=64
   371         kx         ;;
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=windows_x86
   371         kx         WIN_HOST_ARCH="x86"
   371         kx         WIN_HOST_BITS=32
   371         kx         WIN_OTHER_ARCH="x64"
   371         kx         ;;
   371         kx     aarch64)
   371         kx         CPUNAME=AARCH64
   371         kx         RTL_ARCH=AARCH64
   371         kx         PLATFORMID=windows_aarch64
   371         kx         WINDOWS_X64=1
   371         kx         SCPDEFS="$SCPDEFS -DWINDOWS_AARCH64"
   371         kx         WIN_HOST_ARCH="arm64"
   371         kx         WIN_HOST_BITS=64
   371         kx         with_ucrt_dir=no
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx 
   371         kx     case "$build_cpu" in
   371         kx     x86_64) WIN_BUILD_ARCH="x64" ;;
   371         kx     i*86) WIN_BUILD_ARCH="x86" ;;
   371         kx     aarch64) WIN_BUILD_ARCH="arm64" ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported build_cpu $build_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx 
   371         kx     SCPDEFS="$SCPDEFS -D_MSC_VER"
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx # multi-arch is an arch, which can execute on the host (x86 on x64), while
   371         kx # other-arch won't, but wouldn't break the build (x64 on x86).
   371         kx if test -n "$WIN_MULTI_ARCH" -a -n "$WIN_OTHER_ARCH"; then
   371         kx     AC_MSG_ERROR([Broken configure.ac file: can't have set \$WIN_MULTI_ARCH and $WIN_OTHER_ARCH])
   371         kx fi
   371         kx 
   371         kx 
   371         kx if test "$build_cpu" != "$host_cpu" -o "$DISABLE_DYNLOADING" = TRUE; then
   371         kx     # To allow building Windows multi-arch releases without cross-tooling
   371         kx     if test "$DISABLE_DYNLOADING" = TRUE -o \( -z "$WIN_MULTI_ARCH" -a -z "$WIN_OTHER_ARCH" \); then
   371         kx         cross_compiling="yes"
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test "$cross_compiling" = "yes"; then
   371         kx     export CROSS_COMPILING=TRUE
   371         kx     if test "$enable_dynamic_loading" != yes -a "$enable_wasm_strip" = yes; then
   371         kx         ENABLE_WASM_STRIP=TRUE
   371         kx     fi
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         if test "$with_main_module" = "calc"; then
   371         kx             ENABLE_WASM_STRIP_WRITER=TRUE
   371         kx         elif test "$with_main_module" = "writer"; then
   371         kx             ENABLE_WASM_STRIP_CALC=TRUE
   371         kx         fi
   371         kx     fi
   371         kx else
   371         kx     CROSS_COMPILING=
   371         kx     BUILD_TYPE="$BUILD_TYPE NATIVE"
   371         kx fi
   371         kx AC_SUBST(CROSS_COMPILING)
   371         kx AC_SUBST(ENABLE_WASM_STRIP)
   371         kx AC_SUBST(ENABLE_WASM_STRIP_WRITER)
   371         kx AC_SUBST(ENABLE_WASM_STRIP_CALC)
   371         kx 
   371         kx ISYSTEM=-I
   371         kx AC_SUBST(ISYSTEM)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Check which Visual Studio compiler is used
   371         kx dnl ===================================================================
   371         kx 
   371         kx map_vs_year_to_version()
   371         kx {
   371         kx     # Return value: $vsversion
   371         kx 
   371         kx     unset vsversion
   371         kx 
   371         kx     case $1 in
   371         kx     2019)
   371         kx         vsversion=16;;
   371         kx     2022)
   371         kx         vsversion=17;;
   371         kx     2022preview)
   371         kx         vsversion=17.9;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Assertion failure - invalid argument "$1" to map_vs_year_to_version()]);;
   371         kx     esac
   371         kx }
   371         kx 
   371         kx vs_versions_to_check()
   371         kx {
   371         kx     # Args: $1 (optional) : versions to check, in the order of preference
   371         kx     # Return value: $vsversions
   371         kx 
   371         kx     unset vsversions
   371         kx 
   371         kx     if test -n "$1"; then
   371         kx         map_vs_year_to_version "$1"
   371         kx         vsversions=$vsversion
   371         kx     else
   371         kx         # Default version is 2019
   371         kx         vsversions="16"
   371         kx     fi
   371         kx }
   371         kx 
   371         kx win_get_env_from_vsdevcmdbat()
   371         kx {
   371         kx     local WRAPPERBATCHFILEPATH="`mktemp -t wrpXXXXXX.bat`"
   371         kx     printf '@set VSCMD_SKIP_SENDTELEMETRY=1\r\n' > $WRAPPERBATCHFILEPATH
   371         kx     printf '@call "%s/../Common7/Tools/VsDevCmd.bat" /no_logo\r\n' "$(cygpath -w $VC_PRODUCT_DIR)" >> $WRAPPERBATCHFILEPATH
   371         kx     # use 'echo.%ENV%' syntax (instead of 'echo %ENV%') to avoid outputting "ECHO is off." in case when ENV is empty or a space
   371         kx     printf '@setlocal\r\n@echo.%%%s%%\r\n@endlocal\r\n' "$1" >> $WRAPPERBATCHFILEPATH
   371         kx     local result
   371         kx     if test "$build_os" = "wsl"; then
   371         kx         result=$(cd /mnt/c && cmd.exe /c $(wslpath -w $WRAPPERBATCHFILEPATH) | tr -d '\r')
   371         kx     else
   371         kx         chmod +x $WRAPPERBATCHFILEPATH
   371         kx         result=$("$WRAPPERBATCHFILEPATH" | tr -d '\r')
   371         kx     fi
   371         kx     rm -f $WRAPPERBATCHFILEPATH
   371         kx     printf '%s' "$result"
   371         kx }
   371         kx 
   371         kx find_ucrt()
   371         kx {
   371         kx     reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows/v10.0/InstallationFolder"
   371         kx     if test -n "$regvalue"; then
   371         kx         PathFormat "$regvalue"
   371         kx         UCRTSDKDIR=$formatted_path_unix
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows/v10.0/ProductVersion"
   371         kx         UCRTVERSION=$regvalue
   371         kx         # Rest if not exist
   371         kx         if ! test -d "${UCRTSDKDIR}Include/$UCRTVERSION/ucrt"; then
   371         kx           UCRTSDKDIR=
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$UCRTSDKDIR"; then
   371         kx         ide_env_dir="$VC_PRODUCT_DIR/../Common7/Tools/"
   371         kx         ide_env_file="${ide_env_dir}VsDevCmd.bat"
   371         kx         if test -f "$ide_env_file"; then
   371         kx             PathFormat "$(win_get_env_from_vsdevcmdbat UniversalCRTSdkDir)"
   371         kx             UCRTSDKDIR=$formatted_path
   371         kx             UCRTVERSION=$(win_get_env_from_vsdevcmdbat UCRTVersion)
   371         kx             dnl Hack needed at least by tml:
   371         kx             if test "$UCRTVERSION" = 10.0.15063.0 \
   371         kx                 -a ! -f "${UCRTSDKDIR}Include/10.0.15063.0/um/sqlext.h" \
   371         kx                 -a -f "${UCRTSDKDIR}Include/10.0.14393.0/um/sqlext.h"
   371         kx             then
   371         kx                 UCRTVERSION=10.0.14393.0
   371         kx             fi
   371         kx         else
   371         kx           AC_MSG_ERROR([No UCRT found])
   371         kx         fi
   371         kx     fi
   371         kx }
   371         kx 
   371         kx find_msvc()
   371         kx {
   371         kx     # Find Visual C++
   371         kx     # Args: $1 (optional) : The VS version year
   371         kx     # Return values: $vctest, $vcyear, $vctoolset, $vcnumwithdot, $vcbuildnumber
   371         kx 
   371         kx     unset vctest vctoolset vcnumwithdot vcbuildnumber
   371         kx 
   371         kx     vs_versions_to_check "$1"
   371         kx     if test "$build_os" = wsl; then
   371         kx         vswhere="$PROGRAMFILESX86"
   371         kx         if test -z "$vswhere"; then
   371         kx             vswhere="c:\\Program Files (x86)"
   371         kx         fi
   371         kx     else
   371         kx         vswhere="$(perl -e 'print $ENV{"ProgramFiles(x86)"}')"
   371         kx     fi
   371         kx     vswhere+="\\Microsoft Visual Studio\\Installer\\vswhere.exe"
   371         kx     PathFormat "$vswhere"
   371         kx     vswhere=$formatted_path_unix
   371         kx     for ver in $vsversions; do
   371         kx         vswhereoutput=`$vswhere -version "@<:@ $ver , $(expr ${ver%%.*} + 1) @:}@" -requires Microsoft.VisualStudio.Component.VC.Tools.x86.x64 -property installationPath | head -1`
   371         kx         if test -z "$vswhereoutput"; then
   371         kx             vswhereoutput=`$vswhere -prerelease -version "@<:@ $ver , $(expr ${ver%%.*} + 1) @:}@" -requires Microsoft.VisualStudio.Component.VC.Tools.x86.x64 -property installationPath | head -1`
   371         kx         fi
   371         kx         # Fall back to all MS products (this includes VC++ Build Tools)
   371         kx         if ! test -n "$vswhereoutput"; then
   371         kx             AC_MSG_CHECKING([VC++ Build Tools and similar])
   371         kx             vswhereoutput=`$vswhere -products \* -version "@<:@ $ver , $(expr ${ver%%.*} + 1) @:}@" -requires Microsoft.VisualStudio.Component.VC.Tools.x86.x64 -property installationPath | head -1`
   371         kx         fi
   371         kx         if test -n "$vswhereoutput"; then
   371         kx             PathFormat "$vswhereoutput"
   371         kx             vctest=$formatted_path_unix
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     if test -n "$vctest"; then
   371         kx         vcnumwithdot="$ver"
   371         kx         if test "${vcnumwithdot%%.*}" = "$vcnumwithdot"; then
   371         kx             vcnumwithdot=$vcnumwithdot.0
   371         kx         fi
   371         kx         case "$vcnumwithdot" in
   371         kx         16.0)
   371         kx             vcyear=2019
   371         kx             vctoolset=v142
   371         kx             ;;
   371         kx         17.0 | 17.9)
   371         kx             vcyear=2022
   371         kx             vctoolset=v143
   371         kx             ;;
   371         kx         esac
   371         kx         vcbuildnumber=`ls $vctest/VC/Tools/MSVC -A1r | head -1`
   371         kx 
   371         kx     fi
   371         kx }
   371         kx 
   371         kx test_cl_exe()
   371         kx {
   371         kx     AC_MSG_CHECKING([$1 compiler])
   371         kx 
   371         kx     CL_EXE_PATH="$2/cl.exe"
   371         kx 
   371         kx     if test ! -f "$CL_EXE_PATH"; then
   371         kx         if test "$1" = "multi-arch"; then
   371         kx             AC_MSG_WARN([no compiler (cl.exe) in $2])
   371         kx             return 1
   371         kx         else
   371         kx             AC_MSG_ERROR([no compiler (cl.exe) in $2])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     dnl ===========================================================
   371         kx     dnl  Check for the corresponding mspdb*.dll
   371         kx     dnl ===========================================================
   371         kx 
   371         kx     # MSVC 15.0 has libraries from 14.0?
   371         kx     mspdbnum="140"
   371         kx 
   371         kx     if test ! -e "$2/mspdb${mspdbnum}.dll"; then
   371         kx         AC_MSG_ERROR([No mspdb${mspdbnum}.dll in $2, Visual Studio installation broken?])
   371         kx     fi
   371         kx 
   371         kx     # The compiles has to find its shared libraries
   371         kx     OLD_PATH="$PATH"
   371         kx     TEMP_PATH=`cygpath -d "$2"`
   371         kx     PATH="`cygpath -u "$TEMP_PATH"`:$PATH"
   371         kx 
   371         kx     if ! "$CL_EXE_PATH" -? </dev/null >/dev/null 2>&1; then
   371         kx         AC_MSG_ERROR([no compiler (cl.exe) in $2])
   371         kx     fi
   371         kx 
   371         kx     PATH="$OLD_PATH"
   371         kx 
   371         kx     AC_MSG_RESULT([$CL_EXE_PATH])
   371         kx }
   371         kx 
   371         kx SOLARINC=
   371         kx MSBUILD_PATH=
   371         kx DEVENV=
   371         kx if test "$_os" = "WINNT"; then
   371         kx     AC_MSG_CHECKING([Visual C++])
   371         kx     find_msvc "$with_visual_studio"
   371         kx     if test -z "$vctest"; then
   371         kx         if test -n "$with_visual_studio"; then
   371         kx             AC_MSG_ERROR([no Visual Studio $with_visual_studio installation found])
   371         kx         else
   371         kx             AC_MSG_ERROR([no Visual Studio installation found])
   371         kx         fi
   371         kx     fi
   371         kx     AC_MSG_RESULT([])
   371         kx 
   371         kx     VC_PRODUCT_DIR="$vctest/VC"
   371         kx     COMPATH="$VC_PRODUCT_DIR/Tools/MSVC/$vcbuildnumber"
   371         kx 
   371         kx     # $WIN_OTHER_ARCH is a hack to test the x64 compiler on x86, even if it's not multi-arch
   371         kx     if test -n "$WIN_MULTI_ARCH" -o -n "$WIN_OTHER_ARCH"; then
   371         kx         MSVC_MULTI_PATH="$COMPATH/bin/Host$WIN_BUILD_ARCH/${WIN_MULTI_ARCH}${WIN_OTHER_ARCH}"
   371         kx         test_cl_exe "multi-arch" "$MSVC_MULTI_PATH"
   371         kx         if test $? -ne 0; then
   371         kx             WIN_MULTI_ARCH=""
   371         kx             WIN_OTHER_ARCH=""
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     if test "$WIN_BUILD_ARCH" = "$WIN_HOST_ARCH"; then
   371         kx         MSVC_BUILD_PATH="$COMPATH/bin/Host$WIN_BUILD_ARCH/$WIN_BUILD_ARCH"
   371         kx         test_cl_exe "build" "$MSVC_BUILD_PATH"
   371         kx     fi
   371         kx 
   371         kx     if test "$WIN_BUILD_ARCH" != "$WIN_HOST_ARCH"; then
   371         kx         MSVC_HOST_PATH="$COMPATH/bin/Host$WIN_BUILD_ARCH/$WIN_HOST_ARCH"
   371         kx         test_cl_exe "host" "$MSVC_HOST_PATH"
   371         kx     else
   371         kx         MSVC_HOST_PATH="$MSVC_BUILD_PATH"
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([for short pathname of VC product directory])
   371         kx     VC_PRODUCT_DIR=`win_short_path_for_make "$VC_PRODUCT_DIR"`
   371         kx     AC_MSG_RESULT([$VC_PRODUCT_DIR])
   371         kx 
   371         kx     UCRTSDKDIR=
   371         kx     UCRTVERSION=
   371         kx 
   371         kx     AC_MSG_CHECKING([for UCRT location])
   371         kx     find_ucrt
   371         kx     # find_ucrt errors out if it doesn't find it
   371         kx     AC_MSG_RESULT([$UCRTSDKDIR ($UCRTVERSION)])
   371         kx     PathFormat "${UCRTSDKDIR}Include/$UCRTVERSION/ucrt"
   371         kx     ucrtincpath_formatted=$formatted_path
   371         kx     # SOLARINC is used for external modules and must be set too.
   371         kx     # And no, it's not sufficient to set SOLARINC only, as configure
   371         kx     # itself doesn't honour it.
   371         kx     SOLARINC="$SOLARINC -I$ucrtincpath_formatted"
   371         kx     CFLAGS="$CFLAGS -I$ucrtincpath_formatted"
   371         kx     CXXFLAGS="$CXXFLAGS -I$ucrtincpath_formatted"
   371         kx     CPPFLAGS="$CPPFLAGS -I$ucrtincpath_formatted"
   371         kx 
   371         kx     AC_SUBST(UCRTSDKDIR)
   371         kx     AC_SUBST(UCRTVERSION)
   371         kx 
   371         kx     AC_MSG_CHECKING([for MSBuild.exe location for: $vcnumwithdot])
   371         kx     # Find the proper version of MSBuild.exe to use based on the VS version
   371         kx     reg_get_value_32 HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/MSBuild/$vcnumwithdot/MSBuildOverrideTasksPath
   371         kx     if test -z "$regvalue" ; then
   371         kx         if test "$WIN_BUILD_ARCH" != "x64"; then
   371         kx             regvalue="$VC_PRODUCT_DIR/../MSBuild/Current/Bin"
   371         kx         else
   371         kx             regvalue="$VC_PRODUCT_DIR/../MSBuild/Current/Bin/amd64"
   371         kx         fi
   371         kx     fi
   371         kx     if test -d "$regvalue" ; then
   371         kx         MSBUILD_PATH=`win_short_path_for_make "$regvalue"`
   371         kx         AC_MSG_RESULT([$regvalue])
   371         kx     else
   371         kx         AC_MSG_ERROR([MSBuild.exe location not found])
   371         kx     fi
   371         kx 
   371         kx     # Find the version of devenv.exe
   371         kx     # MSVC 2017 devenv does not start properly from a DOS 8.3 path
   371         kx     DEVENV=$(cygpath -lm "$VC_PRODUCT_DIR/../Common7/IDE/devenv.exe")
   371         kx     DEVENV_unix=$(cygpath -u "$DEVENV")
   371         kx     if test ! -e "$DEVENV_unix"; then
   371         kx         AC_MSG_WARN([No devenv.exe found - this is expected for VC++ Build Tools])
   371         kx     fi
   371         kx 
   371         kx     dnl Save the true MSVC cl.exe for use when CC/CXX is actually clang-cl,
   371         kx     dnl needed when building CLR code:
   371         kx     if test -z "$MSVC_CXX"; then
   371         kx         # This gives us a posix path with 8.3 filename restrictions
   371         kx         MSVC_CXX=`win_short_path_for_make "$MSVC_HOST_PATH/cl.exe"`
   371         kx     fi
   371         kx 
   371         kx     if test -z "$CC"; then
   371         kx         CC=$MSVC_CXX
   371         kx         CC_BASE=`first_arg_basename "$CC"`
   371         kx     fi
   371         kx     if test -z "$CXX"; then
   371         kx         CXX=$MSVC_CXX
   371         kx         CXX_BASE=`first_arg_basename "$CXX"`
   371         kx     fi
   371         kx 
   371         kx     if test -n "$CC"; then
   371         kx         # Remove /cl.exe from CC case insensitive
   371         kx         AC_MSG_NOTICE([found Visual C++ $vcyear])
   371         kx 
   371         kx         main_include_dir=`cygpath -d -m "$COMPATH/Include"`
   371         kx         CPPFLAGS="$CPPFLAGS -I$main_include_dir"
   371         kx 
   371         kx         PathFormat "$COMPATH"
   371         kx         COMPATH=`win_short_path_for_make "$formatted_path"`
   371         kx 
   371         kx         VCVER=$vcnumwithdot
   371         kx         VCTOOLSET=$vctoolset
   371         kx 
   371         kx         # The WINDOWS_SDK_ACCEPTABLE_VERSIONS is mostly an educated guess...  Assuming newer ones
   371         kx         # are always "better", we list them in reverse chronological order.
   371         kx 
   371         kx         case "$vcnumwithdot" in
   371         kx         16.0 | 17.0 | 17.9)
   371         kx             WINDOWS_SDK_ACCEPTABLE_VERSIONS="10.0 8.1A 8.1 8.0"
   371         kx             ;;
   371         kx         esac
   371         kx 
   371         kx         # The expectation is that --with-windows-sdk should not need to be used
   371         kx         if test -n "$with_windows_sdk"; then
   371         kx             case " $WINDOWS_SDK_ACCEPTABLE_VERSIONS " in
   371         kx             *" "$with_windows_sdk" "*)
   371         kx                 WINDOWS_SDK_ACCEPTABLE_VERSIONS=$with_windows_sdk
   371         kx                 ;;
   371         kx             *)
   371         kx                 AC_MSG_ERROR([Windows SDK $with_windows_sdk is not known to work with VS $vcyear])
   371         kx                 ;;
   371         kx             esac
   371         kx         fi
   371         kx 
   371         kx         # Make AC_COMPILE_IFELSE etc. work (set by AC_PROG_C, which we don't use for MSVC)
   371         kx         ac_objext=obj
   371         kx         ac_exeext=exe
   371         kx 
   371         kx     else
   371         kx         AC_MSG_ERROR([Visual C++ not found after all, huh])
   371         kx     fi
   371         kx 
   371         kx     # ERROR if VS version < 16.5
   371         kx     AC_MSG_CHECKING([$CC_BASE is at least Visual Studio 2019 version 16.5])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx         // See <https://docs.microsoft.com/en-us/cpp/preprocessor/predefined-macros> for mapping
   371         kx         // between Visual Studio versions and _MSC_VER:
   371         kx         #if _MSC_VER < 1925
   371         kx         #error
   371         kx         #endif
   371         kx     ]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([no])])
   371         kx 
   371         kx     # WARN if VS version < 16.10
   371         kx     AC_MSG_CHECKING([$CC_BASE is at least Visual Studio 2019 version 16.10])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx         #if _MSC_VER < 1929
   371         kx         #error
   371         kx         #endif
   371         kx     ]])],[vs2019_recommended_version=yes],[vs2019_recommended_version=no])
   371         kx 
   371         kx     if test $vs2019_recommended_version = yes; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_WARN([no])
   371         kx         add_warning "You should have at least Visual Studio 2019 version 16.10 to avoid build problems. Otherwise, you may face problems with the build of some modules including dragonbox."
   371         kx     fi
   371         kx 
   371         kx     # Check for 64-bit (cross-)compiler to use to build the 64-bit
   371         kx     # version of the Explorer extension (and maybe other small
   371         kx     # bits, too) needed when installing a 32-bit LibreOffice on a
   371         kx     # 64-bit OS. The 64-bit Explorer extension is a feature that
   371         kx     # has been present since long in OOo. Don't confuse it with
   371         kx     # building LibreOffice itself as 64-bit code.
   371         kx 
   371         kx     BUILD_X64=
   371         kx     CXX_X64_BINARY=
   371         kx 
   371         kx     if test "$WIN_HOST_ARCH" = "x86" -a -n "$WIN_OTHER_ARCH"; then
   371         kx         AC_MSG_CHECKING([for the libraries to build the 64-bit Explorer extensions])
   371         kx         if test -f "$COMPATH/atlmfc/lib/x64/atls.lib" -o \
   371         kx              -f "$COMPATH/atlmfc/lib/spectre/x64/atls.lib"
   371         kx         then
   371         kx             BUILD_X64=TRUE
   371         kx             CXX_X64_BINARY=`win_short_path_for_make "$MSVC_MULTI_PATH/cl.exe"`
   371         kx             AC_MSG_RESULT([found])
   371         kx         else
   371         kx             AC_MSG_RESULT([not found])
   371         kx             AC_MSG_WARN([Installation set will not contain 64-bit Explorer extensions])
   371         kx         fi
   371         kx     elif test "$WIN_HOST_ARCH" = "x64"; then
   371         kx         CXX_X64_BINARY=$CXX
   371         kx     fi
   371         kx     AC_SUBST(BUILD_X64)
   371         kx 
   371         kx     # These are passed to the environment and then used in gbuild/platform/com_MSC_class.mk
   371         kx     AC_SUBST(CXX_X64_BINARY)
   371         kx 
   371         kx     # Check for 32-bit compiler to use to build the 32-bit TWAIN shim
   371         kx     # needed to support TWAIN scan on both 32- and 64-bit systems
   371         kx 
   371         kx     case "$WIN_HOST_ARCH" in
   371         kx     x64)
   371         kx         AC_MSG_CHECKING([for a x86 compiler and libraries for 32-bit binaries required for TWAIN support])
   371         kx         if test -n "$CXX_X86_BINARY"; then
   371         kx             BUILD_X86=TRUE
   371         kx             AC_MSG_RESULT([preset])
   371         kx         elif test -n "$WIN_MULTI_ARCH"; then
   371         kx             BUILD_X86=TRUE
   371         kx             CXX_X86_BINARY=`win_short_path_for_make "$MSVC_MULTI_PATH/cl.exe"`
   371         kx             AC_MSG_RESULT([found])
   371         kx         else
   371         kx             AC_MSG_RESULT([not found])
   371         kx             AC_MSG_WARN([Installation set will not contain 32-bit binaries required for TWAIN support])
   371         kx         fi
   371         kx         ;;
   371         kx     x86)
   371         kx         BUILD_X86=TRUE
   371         kx         CXX_X86_BINARY=$MSVC_CXX
   371         kx         ;;
   371         kx     esac
   371         kx     AC_SUBST(BUILD_X86)
   371         kx     AC_SUBST(CXX_X86_BINARY)
   371         kx fi
   371         kx AC_SUBST(VCVER)
   371         kx AC_SUBST(VCTOOLSET)
   371         kx AC_SUBST(DEVENV)
   371         kx AC_SUBST(MSVC_CXX)
   371         kx 
   371         kx COM_IS_CLANG=
   371         kx AC_MSG_CHECKING([whether the compiler is actually Clang])
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx     #ifndef __clang__
   371         kx     you lose
   371         kx     #endif
   371         kx     int foo=42;
   371         kx     ]])],
   371         kx     [AC_MSG_RESULT([yes])
   371         kx      COM_IS_CLANG=TRUE],
   371         kx     [AC_MSG_RESULT([no])])
   371         kx AC_SUBST(COM_IS_CLANG)
   371         kx 
   371         kx CLANGVER=
   371         kx if test "$COM_IS_CLANG" = TRUE; then
   371         kx     AC_MSG_CHECKING([whether Clang is new enough])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx         #if !defined __apple_build_version__
   371         kx         #error
   371         kx         #endif
   371         kx         ]])],
   371         kx         [my_apple_clang=yes],[my_apple_clang=])
   371         kx     if test "$my_apple_clang" = yes; then
   371         kx         AC_MSG_RESULT([assumed yes (Apple Clang)])
   371         kx     elif test "$_os" = Emscripten; then
   371         kx         AC_MSG_RESULT([assumed yes (Emscripten Clang)])
   371         kx     else
   371         kx         if test "$_os" = WINNT; then
   371         kx             dnl In which case, assume clang-cl:
   371         kx             my_args="/EP /TC"
   371         kx         else
   371         kx             my_args="-E -P"
   371         kx         fi
   371         kx         clang_version=`echo __clang_major__.__clang_minor__.__clang_patchlevel__ | $CC $my_args - | sed 's/ //g'`
   371         kx         CLANG_FULL_VERSION=`echo __clang_version__ | $CC $my_args -`
   371         kx         CLANGVER=`echo $clang_version \
   371         kx             | $AWK -F. '{ print \$1*10000+(\$2<100?\$2:99)*100+(\$3<100?\$3:99) }'`
   371         kx         if test "$CLANGVER" -ge 120000; then
   371         kx             AC_MSG_RESULT([yes ($clang_version)])
   371         kx         else
   371         kx             AC_MSG_ERROR(["$CLANG_FULL_VERSION" is too old or unrecognized, must be at least Clang 12])
   371         kx         fi
   371         kx         AC_DEFINE_UNQUOTED(CLANG_VERSION,$CLANGVER)
   371         kx         AC_DEFINE_UNQUOTED(CLANG_FULL_VERSION,$CLANG_FULL_VERSION)
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx SHOWINCLUDES_PREFIX=
   371         kx if test "$_os" = WINNT; then
   371         kx     dnl We need to guess the prefix of the -showIncludes output, it can be
   371         kx     dnl localized
   371         kx     AC_MSG_CHECKING([the dependency generation prefix (cl.exe -showIncludes)])
   371         kx     echo "#include <stdlib.h>" > conftest.c
   371         kx     SHOWINCLUDES_PREFIX=`VSLANG=1033 $CC $CFLAGS -c -showIncludes conftest.c 2>/dev/null | \
   371         kx         grep 'stdlib\.h' | head -n1 | sed 's/ [[[:alpha:]]]:.*//'`
   371         kx     rm -f conftest.c conftest.obj
   371         kx     if test -z "$SHOWINCLUDES_PREFIX"; then
   371         kx         AC_MSG_ERROR([cannot determine the -showIncludes prefix])
   371         kx     else
   371         kx         AC_MSG_RESULT(["$SHOWINCLUDES_PREFIX"])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SHOWINCLUDES_PREFIX)
   371         kx 
   371         kx #
   371         kx # prefix C with ccache if needed
   371         kx #
   371         kx if test "$CCACHE" != ""; then
   371         kx     AC_MSG_CHECKING([whether $CC_BASE is already ccached])
   371         kx 
   371         kx     AC_LANG_PUSH([C])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS --ccache-skip -O2"
   371         kx     # msvc does not fail on unknown options, check stdout
   371         kx     if test "$COM" = MSC; then
   371         kx         CFLAGS="$CFLAGS -nologo"
   371         kx     fi
   371         kx     save_ac_c_werror_flag=$ac_c_werror_flag
   371         kx     ac_c_werror_flag=yes
   371         kx     dnl an empty program will do, we're checking the compiler flags
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[])],
   371         kx                       [use_ccache=yes], [use_ccache=no])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     ac_c_werror_flag=$save_ac_c_werror_flag
   371         kx     if test $use_ccache = yes -a "${CCACHE/*sccache*/}" != ""; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         CC="$CCACHE $CC"
   371         kx         CC_BASE="ccache $CC_BASE"
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx     AC_LANG_POP([C])
   371         kx fi
   371         kx 
   371         kx # ===================================================================
   371         kx # check various GCC options that Clang does not support now but maybe
   371         kx # will somewhen in the future, check them even for GCC, so that the
   371         kx # flags are set
   371         kx # ===================================================================
   371         kx 
   371         kx HAVE_GCC_GGDB2=
   371         kx if test "$GCC" = "yes" -a "$_os" != "Emscripten"; then
   371         kx     AC_MSG_CHECKING([whether $CC_BASE supports -ggdb2])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror -ggdb2"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_GCC_GGDB2=TRUE ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test "$HAVE_GCC_GGDB2" = "TRUE"; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx 
   371         kx     if test "$host_cpu" = "m68k"; then
   371         kx         AC_MSG_CHECKING([whether $CC_BASE supports -mlong-jump-table-offsets])
   371         kx         save_CFLAGS=$CFLAGS
   371         kx         CFLAGS="$CFLAGS -Werror -mlong-jump-table-offsets"
   371         kx         AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_GCC_LONG_JUMP_TABLE_OFFSETS=TRUE ],[])
   371         kx         CFLAGS=$save_CFLAGS
   371         kx         if test "$HAVE_GCC_LONG_JUMP_TABLE_OFFSETS" = "TRUE"; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             AC_MSG_ERROR([no])
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(HAVE_GCC_GGDB2)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Test the gcc version
   371         kx dnl ===================================================================
   371         kx if test "$GCC" = "yes" -a -z "$COM_IS_CLANG"; then
   371         kx     AC_MSG_CHECKING([the GCC version])
   371         kx     _gcc_version=`$CC -dumpfullversion`
   371         kx     gcc_full_version=$(printf '%s' "$_gcc_version" | \
   371         kx         $AWK -F. '{ print $1*10000+$2*100+(NF<3?1:$3) }')
   371         kx     GCC_VERSION=`echo $_gcc_version | $AWK -F. '{ print \$1*100+\$2 }'`
   371         kx 
   371         kx     AC_MSG_RESULT([gcc $_gcc_version ($gcc_full_version)])
   371         kx 
   371         kx     if test "$gcc_full_version" -lt 120000; then
   371         kx         AC_MSG_ERROR([GCC $_gcc_version is too old, must be at least GCC 12])
   371         kx     fi
   371         kx else
   371         kx     # Explicitly force GCC_VERSION to be empty, even for Clang, to check incorrect uses.
   371         kx     # GCC version should generally be checked only when handling GCC-specific bugs, for testing
   371         kx     # things like features configure checks should be used, otherwise they may e.g. fail with Clang
   371         kx     # (which reports itself as GCC 4.2.1).
   371         kx     GCC_VERSION=
   371         kx fi
   371         kx AC_SUBST(GCC_VERSION)
   371         kx 
   371         kx dnl Set the ENABLE_DBGUTIL variable
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to build with additional debug utilities])
   371         kx if test -n "$enable_dbgutil" -a "$enable_dbgutil" != "no"; then
   371         kx     ENABLE_DBGUTIL="TRUE"
   371         kx     # this is an extra var so it can have different default on different MSVC
   371         kx     # versions (in case there are version specific problems with it)
   371         kx     MSVC_USE_DEBUG_RUNTIME="TRUE"
   371         kx 
   371         kx     AC_MSG_RESULT([yes])
   371         kx     # cppunit and graphite expose STL in public headers
   371         kx     if test "$with_system_cppunit" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-cppunit conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_cppunit=no
   371         kx     fi
   371         kx     if test "$with_system_graphite" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-graphite conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_graphite=no
   371         kx     fi
   371         kx     if test "$with_system_orcus" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-orcus conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_orcus=no
   371         kx     fi
   371         kx     if test "$with_system_libcmis" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-libcmis conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_libcmis=no
   371         kx     fi
   371         kx     if test "$with_system_hunspell" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-hunspell conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_hunspell=no
   371         kx     fi
   371         kx     if test "$with_system_gpgmepp" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-gpgmepp conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_gpgmepp=no
   371         kx     fi
   371         kx     # As mixing system libwps and non-system libnumbertext or vice versa likely causes trouble (see
   371         kx     # 603074c5f2b84de8a24593faf807da784b040625 "Pass _GLIBCXX_DEBUG into external/libwps" and the
   371         kx     # mail thread starting at <https://gcc.gnu.org/ml/gcc/2018-05/msg00057.html> "libstdc++: ODR
   371         kx     # violation when using std::regex with and without -D_GLIBCXX_DEBUG"), simply make sure neither
   371         kx     # of those two is using the system variant:
   371         kx     if test "$with_system_libnumbertext" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-libnumbertext conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_libnumbertext=no
   371         kx     fi
   371         kx     if test "$with_system_libwps" = "yes"; then
   371         kx         AC_MSG_ERROR([--with-system-libwps conflicts with --enable-dbgutil])
   371         kx     else
   371         kx         with_system_libwps=no
   371         kx     fi
   371         kx else
   371         kx     ENABLE_DBGUTIL=""
   371         kx     MSVC_USE_DEBUG_RUNTIME=""
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_DBGUTIL)
   371         kx AC_SUBST(MSVC_USE_DEBUG_RUNTIME)
   371         kx 
   371         kx dnl Set the ENABLE_DEBUG variable.
   371         kx dnl ===================================================================
   371         kx if test -n "$enable_debug" && test "$enable_debug" != "yes" && test "$enable_debug" != "no"; then
   371         kx     AC_MSG_ERROR([--enable-debug now accepts only yes or no, use --enable-symbols])
   371         kx fi
   371         kx if test -n "$ENABLE_DBGUTIL" -a "$enable_debug" = "no"; then
   371         kx     if test -z "$libo_fuzzed_enable_debug"; then
   371         kx         AC_MSG_ERROR([--disable-debug cannot be used with --enable-dbgutil])
   371         kx     else
   371         kx         AC_MSG_NOTICE([Resetting --enable-debug=yes])
   371         kx         enable_debug=yes
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to do a debug build])
   371         kx if test -n "$ENABLE_DBGUTIL" -o \( -n "$enable_debug" -a "$enable_debug" != "no" \) ; then
   371         kx     ENABLE_DEBUG="TRUE"
   371         kx     if test -n "$ENABLE_DBGUTIL" ; then
   371         kx         AC_MSG_RESULT([yes (dbgutil)])
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx     fi
   371         kx else
   371         kx     ENABLE_DEBUG=""
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_DEBUG)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Select the linker to use (gold/lld/ld.bfd/mold).
   371         kx dnl This is done only after compiler checks (need to know if Clang is
   371         kx dnl used, for different defaults) and after checking if a debug build
   371         kx dnl is wanted (non-debug builds get the default linker if not explicitly
   371         kx dnl specified otherwise).
   371         kx dnl All checks for linker features/options should come after this.
   371         kx dnl ===================================================================
   371         kx check_use_ld()
   371         kx {
   371         kx     use_ld=-fuse-ld=${1%%:*}
   371         kx     use_ld_path=${1#*:}
   371         kx     if test "$use_ld_path" != "$1"; then
   371         kx         if test "$COM_IS_CLANG" = TRUE; then
   371         kx             if test "$CLANGVER" -ge 120000; then
   371         kx                 use_ld="${use_ld} --ld-path=${use_ld_path}"
   371         kx             else
   371         kx                 use_ld="-fuse-ld=${use_ld_path}"
   371         kx             fi
   371         kx         else
   371         kx             # I tried to use gcc's '-B<path>' and a directory + symlink setup in
   371         kx             # $BUILDDIR, but libtool always filtered-out that option, so gcc wouldn't
   371         kx             # pickup the alternative linker, when called by libtool for linking.
   371         kx             # For mold, one can use LD_PRELOAD=/usr/lib/mold/mold-wrapper.so instead.
   371         kx             AC_MSG_ERROR([A linker path is just supported with clang, because of libtool's -B filtering!])
   371         kx         fi
   371         kx     fi
   371         kx     use_ld_fail_if_error=$2
   371         kx     use_ld_ok=
   371         kx     AC_MSG_CHECKING([for $use_ld linker support])
   371         kx     use_ld_ldflags_save="$LDFLAGS"
   371         kx     LDFLAGS="$LDFLAGS $use_ld"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([
   371         kx #include <stdio.h>
   371         kx         ],[
   371         kx printf ("hello world\n");
   371         kx         ])], USE_LD=$use_ld, [])
   371         kx     if test -n "$USE_LD"; then
   371         kx         AC_MSG_RESULT( yes )
   371         kx         use_ld_ok=yes
   371         kx     else
   371         kx         if test -n "$use_ld_fail_if_error"; then
   371         kx             AC_MSG_ERROR( no )
   371         kx         else
   371         kx             AC_MSG_RESULT( no )
   371         kx         fi
   371         kx     fi
   371         kx     if test -n "$use_ld_ok"; then
   371         kx         dnl keep the value of LDFLAGS
   371         kx         return 0
   371         kx     fi
   371         kx     LDFLAGS="$use_ld_ldflags_save"
   371         kx     return 1
   371         kx }
   371         kx USE_LD=
   371         kx if test "$enable_ld" != "no"; then
   371         kx     if test "$GCC" = "yes" -a "$_os" != "Emscripten"; then
   371         kx         if test -n "$enable_ld"; then
   371         kx             check_use_ld "$enable_ld" fail_if_error
   371         kx         elif test -z "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx             dnl non-debug builds default to the default linker
   371         kx             true
   371         kx         elif test -n "$COM_IS_CLANG"; then
   371         kx             check_use_ld lld
   371         kx             if test $? -ne 0; then
   371         kx                 check_use_ld gold
   371         kx                 if test $? -ne 0; then
   371         kx                     check_use_ld mold
   371         kx                 fi
   371         kx             fi
   371         kx         else
   371         kx             # For gcc first try gold, new versions also support lld/mold.
   371         kx             check_use_ld gold
   371         kx             if test $? -ne 0; then
   371         kx                 check_use_ld lld
   371         kx                 if test $? -ne 0; then
   371         kx                     check_use_ld mold
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx         ld_output=$(echo 'int main() { return 0; }' | $CC -Wl,-v -x c -o conftest.out - $CFLAGS $LDFLAGS 2>/dev/null)
   371         kx         rm conftest.out
   371         kx         ld_used=$(echo "$ld_output" | grep -E '(^GNU gold|^GNU ld|^LLD|^mold)')
   371         kx         if test -z "$ld_used"; then
   371         kx             ld_used="unknown"
   371         kx         fi
   371         kx         AC_MSG_CHECKING([for linker that is used])
   371         kx         AC_MSG_RESULT([$ld_used])
   371         kx         if test -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx             if echo "$ld_used" | grep -q "^GNU ld"; then
   371         kx                 AC_MSG_WARN([The default GNU linker is slow, consider using LLD, mold or the GNU gold linker.])
   371         kx                 add_warning "The default GNU linker is slow, consider using LLD, mold or the GNU gold linker."
   371         kx             fi
   371         kx         fi
   371         kx     else
   371         kx         if test "$enable_ld" = "yes"; then
   371         kx             AC_MSG_ERROR([--enable-ld not supported])
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(USE_LD)
   371         kx AC_SUBST(LD)
   371         kx 
   371         kx HAVE_LD_BSYMBOLIC_FUNCTIONS=
   371         kx if test "$GCC" = "yes" -a "$_os" != Emscripten ; then
   371         kx     AC_MSG_CHECKING([for -Bsymbolic-functions linker support])
   371         kx     bsymbolic_functions_ldflags_save=$LDFLAGS
   371         kx     LDFLAGS="$LDFLAGS -Wl,-Bsymbolic-functions"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([
   371         kx #include <stdio.h>
   371         kx         ],[
   371         kx printf ("hello world\n");
   371         kx         ])], HAVE_LD_BSYMBOLIC_FUNCTIONS=TRUE, [])
   371         kx     if test "$HAVE_LD_BSYMBOLIC_FUNCTIONS" = "TRUE"; then
   371         kx         AC_MSG_RESULT( found )
   371         kx     else
   371         kx         AC_MSG_RESULT( not found )
   371         kx     fi
   371         kx     LDFLAGS=$bsymbolic_functions_ldflags_save
   371         kx fi
   371         kx AC_SUBST(HAVE_LD_BSYMBOLIC_FUNCTIONS)
   371         kx 
   371         kx LD_GC_SECTIONS=
   371         kx if test "$GCC" = "yes"; then
   371         kx     for flag in "--gc-sections" "-dead_strip"; do
   371         kx         AC_MSG_CHECKING([for $flag linker support])
   371         kx         ldflags_save=$LDFLAGS
   371         kx         LDFLAGS="$LDFLAGS -Wl,$flag"
   371         kx         AC_LINK_IFELSE([AC_LANG_PROGRAM([
   371         kx #include <stdio.h>
   371         kx             ],[
   371         kx printf ("hello world\n");
   371         kx             ])],[
   371         kx             LD_GC_SECTIONS="-Wl,$flag"
   371         kx             AC_MSG_RESULT( found )
   371         kx             ], [
   371         kx             AC_MSG_RESULT( not found )
   371         kx             ])
   371         kx         LDFLAGS=$ldflags_save
   371         kx         if test -n "$LD_GC_SECTIONS"; then
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx fi
   371         kx AC_SUBST(LD_GC_SECTIONS)
   371         kx 
   371         kx HAVE_EXTERNAL_DWARF=
   371         kx if test "$enable_split_debug" != no; then
   371         kx     use_split_debug=
   371         kx     if test -n "$ENABLE_LTO"; then
   371         kx         : # Inherently incompatible, since no debug info is created while compiling, GCC complains.
   371         kx     elif test "$enable_split_debug" = yes; then
   371         kx         use_split_debug=1
   371         kx     dnl Currently by default enabled only on Linux, feel free to set test_split_debug above also for other platforms.
   371         kx     elif test "$test_split_debug" = "yes" -a -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx         use_split_debug=1
   371         kx     fi
   371         kx     if test -n "$use_split_debug"; then
   371         kx         if test "$_os" = "Emscripten"; then
   371         kx             TEST_CC_FLAG=-gseparate-dwarf
   371         kx         else
   371         kx             TEST_CC_FLAG=-gsplit-dwarf
   371         kx         fi
   371         kx         AC_MSG_CHECKING([whether $CC_BASE supports $TEST_CC_FLAG])
   371         kx         save_CFLAGS=$CFLAGS
   371         kx         CFLAGS="$CFLAGS -Werror $TEST_CC_FLAG"
   371         kx         AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_EXTERNAL_DWARF=TRUE ],[])
   371         kx         CFLAGS=$save_CFLAGS
   371         kx         if test "$HAVE_EXTERNAL_DWARF" = "TRUE"; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             if test "$enable_split_debug" = yes; then
   371         kx                 AC_MSG_ERROR([no])
   371         kx             else
   371         kx                 AC_MSG_RESULT([no])
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$HAVE_EXTERNAL_DWARF" -a "$test_split_debug" = "yes" -a -n "$use_split_debug"; then
   371         kx         AC_MSG_WARN([Compiler is not capable of creating split debug info, linking will require more time and disk space.])
   371         kx         add_warning "Compiler is not capable of creating split debug info, linking will require more time and disk space."
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(HAVE_EXTERNAL_DWARF)
   371         kx 
   371         kx HAVE_CLANG_DEBUG_INFO_KIND_CONSTRUCTOR=
   371         kx AC_MSG_CHECKING([whether $CC_BASE supports -Xclang -debug-info-kind=constructor])
   371         kx save_CFLAGS=$CFLAGS
   371         kx CFLAGS="$CFLAGS -Werror -Xclang -debug-info-kind=constructor"
   371         kx AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_CLANG_DEBUG_INFO_KIND_CONSTRUCTOR=TRUE ],[])
   371         kx CFLAGS=$save_CFLAGS
   371         kx if test "$HAVE_CLANG_DEBUG_INFO_KIND_CONSTRUCTOR" = "TRUE"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(HAVE_CLANG_DEBUG_INFO_KIND_CONSTRUCTOR)
   371         kx 
   371         kx ENABLE_GDB_INDEX=
   371         kx if test "$enable_gdb_index" != "no"; then
   371         kx     dnl Currently by default enabled only on Linux, feel free to set test_gdb_index above also for other platforms.
   371         kx     if test "$enable_gdb_index" = yes -o \( "$test_gdb_index" = "yes" -a -n "$ENABLE_DEBUG$ENABLE_DBGUTIL" \); then
   371         kx         AC_MSG_CHECKING([whether $CC_BASE supports -ggnu-pubnames])
   371         kx         save_CFLAGS=$CFLAGS
   371         kx         CFLAGS="$CFLAGS -Werror -g -ggnu-pubnames"
   371         kx         have_ggnu_pubnames=
   371         kx         AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[have_ggnu_pubnames=TRUE],[have_ggnu_pubnames=])
   371         kx         if test "$have_ggnu_pubnames" != "TRUE"; then
   371         kx             if test "$enable_gdb_index" = "yes"; then
   371         kx                 AC_MSG_ERROR([no, --enable-gdb-index not supported])
   371         kx             else
   371         kx                 AC_MSG_RESULT( no )
   371         kx             fi
   371         kx         else
   371         kx             AC_MSG_RESULT( yes )
   371         kx             AC_MSG_CHECKING([whether $CC_BASE supports -Wl,--gdb-index])
   371         kx             ldflags_save=$LDFLAGS
   371         kx             LDFLAGS="$LDFLAGS -Wl,--gdb-index"
   371         kx             AC_LINK_IFELSE([AC_LANG_PROGRAM([
   371         kx #include <stdio.h>
   371         kx                 ],[
   371         kx printf ("hello world\n");
   371         kx                 ])], ENABLE_GDB_INDEX=TRUE, [])
   371         kx             if test "$ENABLE_GDB_INDEX" = "TRUE"; then
   371         kx                 AC_MSG_RESULT( yes )
   371         kx             else
   371         kx                 if test "$enable_gdb_index" = "yes"; then
   371         kx                     AC_MSG_ERROR( no )
   371         kx                 else
   371         kx                     AC_MSG_RESULT( no )
   371         kx                 fi
   371         kx             fi
   371         kx             LDFLAGS=$ldflags_save
   371         kx         fi
   371         kx         CFLAGS=$save_CFLAGS
   371         kx         fi
   371         kx     if test -z "$ENABLE_GDB_INDEX" -a "$test_gdb_index" = "yes" -a -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx         AC_MSG_WARN([Linker is not capable of creating gdb index, debugger startup will be slow.])
   371         kx         add_warning "Linker is not capable of creating gdb index, debugger startup will be slow."
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_GDB_INDEX)
   371         kx 
   371         kx if test -z "$enable_sal_log" && test "$ENABLE_DEBUG" = TRUE; then
   371         kx     enable_sal_log=yes
   371         kx fi
   371         kx if test "$enable_sal_log" = yes; then
   371         kx     ENABLE_SAL_LOG=TRUE
   371         kx fi
   371         kx AC_SUBST(ENABLE_SAL_LOG)
   371         kx 
   371         kx dnl Check for enable symbols option
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to generate debug information])
   371         kx if test -z "$enable_symbols"; then
   371         kx     if test -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx         enable_symbols=yes
   371         kx     else
   371         kx         enable_symbols=no
   371         kx     fi
   371         kx fi
   371         kx if test "$enable_symbols" = yes; then
   371         kx     ENABLE_SYMBOLS_FOR=all
   371         kx     AC_MSG_RESULT([yes])
   371         kx elif test "$enable_symbols" = no; then
   371         kx     ENABLE_SYMBOLS_FOR=
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     # Selective debuginfo.
   371         kx     ENABLE_SYMBOLS_FOR="$enable_symbols"
   371         kx     AC_MSG_RESULT([for "$enable_symbols"])
   371         kx fi
   371         kx AC_SUBST(ENABLE_SYMBOLS_FOR)
   371         kx 
   371         kx if test -n "$with_android_ndk" -a \( -n "$ENABLE_SYMBOLS" -o -n "$ENABLE_DEBUG" -o -n "$ENABLE_DBGUTIL" \) -a "$ENABLE_DEBUGINFO_FOR" = "all"; then
   371         kx     # Building on Android with full symbols: without enough memory the linker never finishes currently.
   371         kx     AC_MSG_CHECKING([whether enough memory is available for linking])
   371         kx     mem_size=$(grep -o 'MemTotal: *.\+ kB' /proc/meminfo | sed 's/MemTotal: *\(.\+\) kB/\1/')
   371         kx     # Check for 15GB, as Linux reports a bit less than the physical memory size.
   371         kx     if test -n "$mem_size" -a $mem_size -lt 15728640; then
   371         kx         AC_MSG_ERROR([building with full symbols and less than 16GB of memory is not supported])
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx ENABLE_OPTIMIZED=
   371         kx ENABLE_OPTIMIZED_DEBUG=
   371         kx AC_MSG_CHECKING([whether to compile with optimization flags])
   371         kx if test -z "$enable_optimized"; then
   371         kx     if test -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx         enable_optimized=no
   371         kx     else
   371         kx         enable_optimized=yes
   371         kx     fi
   371         kx fi
   371         kx if test "$enable_optimized" = yes; then
   371         kx     ENABLE_OPTIMIZED=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx elif test "$enable_optimized" = debug; then
   371         kx     ENABLE_OPTIMIZED_DEBUG=TRUE
   371         kx     AC_MSG_RESULT([yes (debug)])
   371         kx     HAVE_GCC_OG=
   371         kx     if test "$GCC" = "yes" -a "$_os" != "Emscripten"; then
   371         kx         AC_MSG_CHECKING([whether $CC_BASE supports -Og])
   371         kx         save_CFLAGS=$CFLAGS
   371         kx         CFLAGS="$CFLAGS -Werror -Og"
   371         kx         AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_GCC_OG=TRUE ],[])
   371         kx         CFLAGS=$save_CFLAGS
   371         kx         if test "$HAVE_GCC_OG" = "TRUE"; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             AC_MSG_RESULT([no])
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$HAVE_GCC_OG" -a "$_os" != "Emscripten"; then
   371         kx         AC_MSG_ERROR([The compiler does not support optimizations suitable for debugging.])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_OPTIMIZED)
   371         kx AC_SUBST(ENABLE_OPTIMIZED_DEBUG)
   371         kx 
   371         kx #
   371         kx # determine CPUNAME, OS, ...
   371         kx #
   371         kx case "$host_os" in
   371         kx 
   371         kx cygwin*|wsl*)
   371         kx     # Already handled
   371         kx     ;;
   371         kx 
   371         kx darwin*)
   371         kx     COM=GCC
   371         kx     OS=MACOSX
   371         kx     RTL_OS=MacOSX
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     aarch64|arm64)
   371         kx         if test "$enable_ios_simulator" = "yes"; then
   371         kx             OS=iOS
   371         kx         else
   371         kx             CPUNAME=AARCH64
   371         kx             RTL_ARCH=AARCH64
   371         kx             PLATFORMID=macosx_aarch64
   371         kx         fi
   371         kx         ;;
   371         kx     x86_64)
   371         kx         if test "$enable_ios_simulator" = "yes"; then
   371         kx             OS=iOS
   371         kx         fi
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=macosx_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx ios*)
   371         kx     COM=GCC
   371         kx     OS=iOS
   371         kx     RTL_OS=iOS
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     aarch64|arm64)
   371         kx         if test "$enable_ios_simulator" = "yes"; then
   371         kx             AC_MSG_ERROR([iOS simulator is only available in macOS not iOS])
   371         kx         fi
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     CPUNAME=AARCH64
   371         kx     RTL_ARCH=AARCH64
   371         kx     PLATFORMID=ios_arm64
   371         kx     ;;
   371         kx 
   371         kx dragonfly*)
   371         kx     COM=GCC
   371         kx     OS=DRAGONFLY
   371         kx     RTL_OS=DragonFly
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=dragonfly_x86
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=dragonfly_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx freebsd*)
   371         kx     COM=GCC
   371         kx     RTL_OS=FreeBSD
   371         kx     OS=FREEBSD
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     aarch64)
   371         kx         CPUNAME=AARCH64
   371         kx         PLATFORMID=freebsd_aarch64
   371         kx         RTL_ARCH=AARCH64
   371         kx         ;;
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=freebsd_x86
   371         kx         ;;
   371         kx     x86_64|amd64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=freebsd_x86_64
   371         kx         ;;
   371         kx     powerpc64)
   371         kx         CPUNAME=POWERPC64
   371         kx         RTL_ARCH=PowerPC_64
   371         kx         PLATFORMID=freebsd_powerpc64
   371         kx         ;;
   371         kx     powerpc|powerpcspe)
   371         kx         CPUNAME=POWERPC
   371         kx         RTL_ARCH=PowerPC
   371         kx         PLATFORMID=freebsd_powerpc
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx haiku*)
   371         kx     COM=GCC
   371         kx     GUIBASE=haiku
   371         kx     RTL_OS=Haiku
   371         kx     OS=HAIKU
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=haiku_x86
   371         kx         ;;
   371         kx     x86_64|amd64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=haiku_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx kfreebsd*)
   371         kx     COM=GCC
   371         kx     OS=LINUX
   371         kx     RTL_OS=kFreeBSD
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx 
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=kfreebsd_x86
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=kfreebsd_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx linux-gnu*|linux-musl*)
   371         kx     COM=GCC
   371         kx     OS=LINUX
   371         kx     RTL_OS=Linux
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx 
   371         kx     aarch64)
   371         kx         CPUNAME=AARCH64
   371         kx         PLATFORMID=linux_aarch64
   371         kx         RTL_ARCH=AARCH64
   371         kx         EPM_FLAGS="-a arm64"
   371         kx         ;;
   371         kx     alpha)
   371         kx         CPUNAME=AXP
   371         kx         RTL_ARCH=ALPHA
   371         kx         PLATFORMID=linux_alpha
   371         kx         ;;
   371         kx     arm*)
   371         kx         CPUNAME=ARM
   371         kx         EPM_FLAGS="-a arm"
   371         kx         RTL_ARCH=ARM_EABI
   371         kx         PLATFORMID=linux_arm_eabi
   371         kx         case "$host_cpu" in
   371         kx         arm*-linux)
   371         kx             RTL_ARCH=ARM_OABI
   371         kx             PLATFORMID=linux_arm_oabi
   371         kx             ;;
   371         kx         esac
   371         kx         ;;
   371         kx     hppa)
   371         kx         CPUNAME=HPPA
   371         kx         RTL_ARCH=HPPA
   371         kx         EPM_FLAGS="-a hppa"
   371         kx         PLATFORMID=linux_hppa
   371         kx         ;;
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=linux_x86
   371         kx         ;;
   371         kx     ia64)
   371         kx         CPUNAME=IA64
   371         kx         RTL_ARCH=IA64
   371         kx         PLATFORMID=linux_ia64
   371         kx         ;;
   371         kx     mips)
   371         kx         CPUNAME=MIPS
   371         kx         RTL_ARCH=MIPS_EB
   371         kx         EPM_FLAGS="-a mips"
   371         kx         PLATFORMID=linux_mips_eb
   371         kx         ;;
   371         kx     mips64)
   371         kx         CPUNAME=MIPS64
   371         kx         RTL_ARCH=MIPS64_EB
   371         kx         EPM_FLAGS="-a mips64"
   371         kx         PLATFORMID=linux_mips64_eb
   371         kx         ;;
   371         kx     mips64el)
   371         kx         CPUNAME=MIPS64
   371         kx         RTL_ARCH=MIPS64_EL
   371         kx         EPM_FLAGS="-a mips64el"
   371         kx         PLATFORMID=linux_mips64_el
   371         kx         ;;
   371         kx     mipsel)
   371         kx         CPUNAME=MIPS
   371         kx         RTL_ARCH=MIPS_EL
   371         kx         EPM_FLAGS="-a mipsel"
   371         kx         PLATFORMID=linux_mips_el
   371         kx         ;;
   371         kx     riscv64)
   371         kx         CPUNAME=RISCV64
   371         kx         RTL_ARCH=RISCV64
   371         kx         EPM_FLAGS="-a riscv64"
   371         kx         PLATFORMID=linux_riscv64
   371         kx         ;;
   371         kx     m68k)
   371         kx         CPUNAME=M68K
   371         kx         RTL_ARCH=M68K
   371         kx         PLATFORMID=linux_m68k
   371         kx         ;;
   371         kx     powerpc)
   371         kx         CPUNAME=POWERPC
   371         kx         RTL_ARCH=PowerPC
   371         kx         PLATFORMID=linux_powerpc
   371         kx         ;;
   371         kx     powerpc64)
   371         kx         CPUNAME=POWERPC64
   371         kx         RTL_ARCH=PowerPC_64
   371         kx         PLATFORMID=linux_powerpc64
   371         kx         ;;
   371         kx     powerpc64le)
   371         kx         CPUNAME=POWERPC64
   371         kx         RTL_ARCH=PowerPC_64_LE
   371         kx         PLATFORMID=linux_powerpc64_le
   371         kx         ;;
   371         kx     sparc)
   371         kx         CPUNAME=SPARC
   371         kx         RTL_ARCH=SPARC
   371         kx         PLATFORMID=linux_sparc
   371         kx         ;;
   371         kx     sparc64)
   371         kx         CPUNAME=SPARC64
   371         kx         RTL_ARCH=SPARC64
   371         kx         PLATFORMID=linux_sparc64
   371         kx         ;;
   371         kx     s390x)
   371         kx         CPUNAME=S390X
   371         kx         RTL_ARCH=S390x
   371         kx         PLATFORMID=linux_s390x
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=linux_x86_64
   371         kx         ;;
   371         kx     loongarch64)
   371         kx         CPUNAME=LOONGARCH64
   371         kx         RTL_ARCH=LOONGARCH64
   371         kx         PLATFORMID=linux_loongarch64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx linux-android*)
   371         kx     COM=GCC
   371         kx     OS=ANDROID
   371         kx     RTL_OS=Android
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx 
   371         kx     arm|armel)
   371         kx         CPUNAME=ARM
   371         kx         RTL_ARCH=ARM_EABI
   371         kx         PLATFORMID=android_arm_eabi
   371         kx         ;;
   371         kx     aarch64)
   371         kx         CPUNAME=AARCH64
   371         kx         RTL_ARCH=AARCH64
   371         kx         PLATFORMID=android_aarch64
   371         kx         ;;
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=android_x86
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=android_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx *netbsd*)
   371         kx     COM=GCC
   371         kx     OS=NETBSD
   371         kx     RTL_OS=NetBSD
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=netbsd_x86
   371         kx         ;;
   371         kx     powerpc)
   371         kx         CPUNAME=POWERPC
   371         kx         RTL_ARCH=PowerPC
   371         kx         PLATFORMID=netbsd_powerpc
   371         kx         ;;
   371         kx     sparc)
   371         kx         CPUNAME=SPARC
   371         kx         RTL_ARCH=SPARC
   371         kx         PLATFORMID=netbsd_sparc
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=netbsd_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     ;;
   371         kx 
   371         kx openbsd*)
   371         kx     COM=GCC
   371         kx     OS=OPENBSD
   371         kx     RTL_OS=OpenBSD
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=openbsd_x86
   371         kx         ;;
   371         kx     x86_64)
   371         kx         CPUNAME=X86_64
   371         kx         RTL_ARCH=X86_64
   371         kx         PLATFORMID=openbsd_x86_64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     SOLARINC="$SOLARINC -I/usr/local/include"
   371         kx     ;;
   371         kx 
   371         kx solaris*)
   371         kx     COM=GCC
   371         kx     OS=SOLARIS
   371         kx     RTL_OS=Solaris
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     i*86)
   371         kx         CPUNAME=INTEL
   371         kx         RTL_ARCH=x86
   371         kx         PLATFORMID=solaris_x86
   371         kx         ;;
   371         kx     sparc)
   371         kx         CPUNAME=SPARC
   371         kx         RTL_ARCH=SPARC
   371         kx         PLATFORMID=solaris_sparc
   371         kx         ;;
   371         kx     sparc64)
   371         kx         CPUNAME=SPARC64
   371         kx         RTL_ARCH=SPARC64
   371         kx         PLATFORMID=solaris_sparc64
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     SOLARINC="$SOLARINC -I/usr/local/include"
   371         kx     ;;
   371         kx 
   371         kx emscripten*)
   371         kx     COM=GCC
   371         kx     OS=EMSCRIPTEN
   371         kx     RTL_OS=Emscripten
   371         kx     P_SEP=:
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     wasm32|wasm64)
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unsupported host_cpu $host_cpu for host_os $host_os])
   371         kx         ;;
   371         kx     esac
   371         kx     CPUNAME=INTEL
   371         kx     RTL_ARCH=x86
   371         kx     PLATFORMID=linux_x86
   371         kx     ;;
   371         kx 
   371         kx *)
   371         kx     AC_MSG_ERROR([$host_os operating system is not suitable to build LibreOffice for!])
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx DISABLE_GUI=""
   371         kx if test "$enable_gui" = "no"; then
   371         kx     if test "$using_x11" != yes; then
   371         kx         AC_MSG_ERROR([$host_os operating system is not suitable to build LibreOffice with --disable-gui.])
   371         kx     fi
   371         kx     USING_X11=
   371         kx     DISABLE_GUI=TRUE
   371         kx     test_epoxy=no
   371         kx else
   371         kx     AC_DEFINE(HAVE_FEATURE_UI)
   371         kx fi
   371         kx AC_SUBST(DISABLE_GUI)
   371         kx 
   371         kx if test "$with_x" = "no"; then
   371         kx     USING_X11=
   371         kx fi
   371         kx 
   371         kx if test -z "$USING_X11" -a "$enable_qt5" = "yes" -a "$enable_gen" = "yes"; then
   371         kx     AC_MSG_ERROR([Can't select gen VCL plugin, if --without-x is used!])
   371         kx fi
   371         kx 
   371         kx if test "$using_x11" = yes; then
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         AC_DEFINE(USING_X11)
   371         kx     else
   371         kx         disable_x11_tests
   371         kx         if test "$DISABLE_DYNLOADING" = TRUE; then
   371         kx             test_qt5=yes
   371         kx         fi
   371         kx     fi
   371         kx else
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         AC_MSG_ERROR([Platform doesn't support X11 (\$using_x11), but \$USING_X11 is set!])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx WORKDIR="${BUILDDIR}/workdir"
   371         kx INSTDIR="${BUILDDIR}/instdir"
   371         kx INSTROOTBASE=${INSTDIR}${INSTROOTBASESUFFIX}
   371         kx INSTROOT=${INSTROOTBASE}${INSTROOTCONTENTSUFFIX}
   371         kx AC_SUBST(COM)
   371         kx AC_SUBST(CPUNAME)
   371         kx AC_SUBST(RTL_OS)
   371         kx AC_SUBST(RTL_ARCH)
   371         kx AC_SUBST(EPM_FLAGS)
   371         kx AC_SUBST(USING_X11)
   371         kx AC_SUBST([INSTDIR])
   371         kx AC_SUBST([INSTROOT])
   371         kx AC_SUBST([INSTROOTBASE])
   371         kx AC_SUBST(OS)
   371         kx AC_SUBST(P_SEP)
   371         kx AC_SUBST(WORKDIR)
   371         kx AC_SUBST(PLATFORMID)
   371         kx AC_SUBST(WINDOWS_X64)
   371         kx AC_DEFINE_UNQUOTED(SDKDIR, "$INSTDIR/$SDKDIRNAME")
   371         kx AC_DEFINE_UNQUOTED(WORKDIR,"$WORKDIR")
   371         kx 
   371         kx if test "$OS" = WNT -a "$COM" = MSC; then
   371         kx     case "$CPUNAME" in
   371         kx     INTEL) CPPU_ENV=msci ;;
   371         kx     X86_64) CPPU_ENV=mscx ;;
   371         kx     AARCH64) CPPU_ENV=msca ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unknown \$CPUNAME '$CPUNAME' for $OS / $COM"])
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     CPPU_ENV=gcc3
   371         kx fi
   371         kx AC_SUBST(CPPU_ENV)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test which package format to use
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which package format to use])
   371         kx if test -n "$with_package_format" -a "$with_package_format" != no; then
   371         kx     for i in $with_package_format; do
   371         kx         case "$i" in
   371         kx         bsd | deb | pkg | rpm | archive | dmg | installed | msi)
   371         kx             ;;
   371         kx         *)
   371         kx             AC_MSG_ERROR([unsupported format $i. Supported by EPM are:
   371         kx bsd - FreeBSD, NetBSD, or OpenBSD software distribution
   371         kx deb - Debian software distribution
   371         kx pkg - Solaris software distribution
   371         kx rpm - RedHat software distribution
   371         kx 
   371         kx LibreOffice additionally supports:
   371         kx archive - .tar.gz or .zip
   371         kx dmg - macOS .dmg
   371         kx installed - installation tree
   371         kx msi - Windows .msi
   371         kx         ])
   371         kx             ;;
   371         kx         esac
   371         kx     done
   371         kx     # fakeroot is needed to ensure correct file ownerships/permissions
   371         kx     # inside deb packages and tar archives created on Linux and Solaris.
   371         kx     if test "$OS" = "LINUX" || test "$OS" = "SOLARIS"; then
   371         kx         AC_PATH_PROG(FAKEROOT, fakeroot, no)
   371         kx         if test "$FAKEROOT" = "no"; then
   371         kx             AC_MSG_ERROR(
   371         kx                 [--with-package-format='$with_package_format' requires fakeroot. Install fakeroot.])
   371         kx         fi
   371         kx     fi
   371         kx     PKGFORMAT="$with_package_format"
   371         kx     AC_MSG_RESULT([$PKGFORMAT])
   371         kx else
   371         kx     PKGFORMAT=
   371         kx     AC_MSG_RESULT([none])
   371         kx fi
   371         kx AC_SUBST(PKGFORMAT)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl handle help related options
   371         kx dnl
   371         kx dnl If you change help related options, please update README.help
   371         kx dnl ===================================================================
   371         kx 
   371         kx ENABLE_HTMLHELP=
   371         kx HELP_OMINDEX_PAGE=
   371         kx HELP_ONLINE=
   371         kx WITH_HELPPACKS=
   371         kx 
   371         kx AC_MSG_CHECKING([which help to build])
   371         kx if test -n "$with_help" -a "$with_help" != "no"; then
   371         kx     GIT_NEEDED_SUBMODULES="helpcontent2 $GIT_NEEDED_SUBMODULES"
   371         kx     BUILD_TYPE="$BUILD_TYPE HELP"
   371         kx     case "$with_help" in
   371         kx     "html")
   371         kx         ENABLE_HTMLHELP=TRUE
   371         kx         WITH_HELPPACKS=TRUE
   371         kx         SCPDEFS="$SCPDEFS -DWITH_HELPPACKS"
   371         kx         AC_MSG_RESULT([HTML (local)])
   371         kx         ;;
   371         kx     "online")
   371         kx         ENABLE_HTMLHELP=TRUE
   371         kx         HELP_ONLINE=TRUE
   371         kx         AC_MSG_RESULT([HTML (online)])
   371         kx         ;;
   371         kx     yes)
   371         kx         WITH_HELPPACKS=TRUE
   371         kx         SCPDEFS="$SCPDEFS -DWITH_HELPPACKS"
   371         kx         AC_MSG_RESULT([XML (local)])
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unknown --with-help=$with_help])
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([if we need to build the help index tooling])
   371         kx if test \( "$with_help" = yes -o "$enable_extension_integration" != no \) -a -z "$DISABLE_DYNLOADING"; then
   371         kx     BUILD_TYPE="$BUILD_TYPE HELPTOOLS"
   371         kx     test_clucene=yes
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable xapian-omega support for online help])
   371         kx if test -n "$with_omindex" -a "$with_omindex" != "no"; then
   371         kx     if test "$HELP_ONLINE" != TRUE; then
   371         kx         AC_MSG_ERROR([Can't build xapian-omega index without --help=online])
   371         kx     fi
   371         kx     case "$with_omindex" in
   371         kx     "server")
   371         kx         HELP_OMINDEX_PAGE=TRUE
   371         kx         AC_MSG_RESULT([SERVER])
   371         kx         ;;
   371         kx     "noxap")
   371         kx         AC_MSG_RESULT([NOXAP])
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([Unknown --with-omindex=$with_omindex])
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to include the XML-help support])
   371         kx if test "$enable_xmlhelp" = yes; then
   371         kx     BUILD_TYPE="$BUILD_TYPE XMLHELP"
   371         kx     test_clucene=yes
   371         kx     AC_DEFINE(HAVE_FEATURE_XMLHELP)
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     if test "$with_help" = yes; then
   371         kx         add_warning "Building the XML help, but LO with disabled xmlhelp support. Generated help can't be accessed from this LO build!"
   371         kx     fi
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx dnl Test whether to integrate helppacks into the product's installer
   371         kx AC_MSG_CHECKING([for helppack integration])
   371         kx if test -z "$WITH_HELPPACKS" -o "$with_helppack_integration" = no; then
   371         kx     AC_MSG_RESULT([no integration])
   371         kx else
   371         kx     SCPDEFS="$SCPDEFS -DWITH_HELPPACK_INTEGRATION"
   371         kx     AC_MSG_RESULT([integration])
   371         kx fi
   371         kx 
   371         kx AC_SUBST([ENABLE_HTMLHELP])
   371         kx AC_SUBST([HELP_OMINDEX_PAGE])
   371         kx AC_SUBST([HELP_ONLINE])
   371         kx # WITH_HELPPACKS is used only in configure
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Set up a different compiler to produce tools to run on the build
   371         kx dnl machine when doing cross-compilation
   371         kx dnl ===================================================================
   371         kx 
   371         kx m4_pattern_allow([PKG_CONFIG_FOR_BUILD])
   371         kx m4_pattern_allow([PKG_CONFIG_LIBDIR])
   371         kx if test "$cross_compiling" = "yes"; then
   371         kx     AC_MSG_CHECKING([for BUILD platform configuration])
   371         kx     echo
   371         kx     rm -rf CONF-FOR-BUILD config_build.mk
   371         kx     mkdir CONF-FOR-BUILD
   371         kx     # Here must be listed all files needed when running the configure script. In particular, also
   371         kx     # those expanded by the AC_CONFIG_FILES() call near the end of this configure.ac. For clarity,
   371         kx     # keep them in the same order as there.
   371         kx     (cd $SRC_ROOT && tar cf - \
   371         kx         config.guess \
   371         kx         bin/get_config_variables \
   371         kx         solenv/bin/getcompver.awk \
   371         kx         solenv/inc/langlist.mk \
   371         kx         download.lst \
   371         kx         config_host.mk.in \
   371         kx         config_host_lang.mk.in \
   371         kx         Makefile.in \
   371         kx         bin/bffvalidator.sh.in \
   371         kx         bin/odfvalidator.sh.in \
   371         kx         bin/officeotron.sh.in \
   371         kx         instsetoo_native/util/openoffice.lst.in \
   371         kx         config_host/*.in \
   371         kx         sysui/desktop/macosx/Info.plist.in \
   371         kx         sysui/desktop/macosx/hardened_runtime.xcent.in \
   371         kx         sysui/desktop/macosx/lo.xcent.in \
   371         kx         .vscode/vs-code-template.code-workspace.in \
   371         kx         solenv/lockfile/autoconf.h.in \
   371         kx         ) \
   371         kx     | (cd CONF-FOR-BUILD && tar xf -)
   371         kx     cp configure CONF-FOR-BUILD
   371         kx     test -d config_build && cp -p config_build/*.h CONF-FOR-BUILD/config_host 2>/dev/null
   371         kx     (
   371         kx     unset COM USING_X11 OS CPUNAME
   371         kx     unset CC CXX SYSBASE CFLAGS
   371         kx     unset AR LD NM OBJDUMP PKG_CONFIG RANLIB READELF STRIP
   371         kx     unset CPPUNIT_CFLAGS CPPUNIT_LIBS
   371         kx     unset LIBXML_CFLAGS LIBXML_LIBS LIBXSLT_CFLAGS LIBXSLT_LIBS XSLTPROC
   371         kx     unset PKG_CONFIG_LIBDIR PKG_CONFIG_PATH
   371         kx     if test -n "$CC_FOR_BUILD"; then
   371         kx         export CC="$CC_FOR_BUILD"
   371         kx         CC_BASE=`first_arg_basename "$CC"`
   371         kx     fi
   371         kx     if test -n "$CXX_FOR_BUILD"; then
   371         kx         export CXX="$CXX_FOR_BUILD"
   371         kx         CXX_BASE=`first_arg_basename "$CXX"`
   371         kx     fi
   371         kx     test -n "$PKG_CONFIG_FOR_BUILD" && export PKG_CONFIG="$PKG_CONFIG_FOR_BUILD"
   371         kx     cd CONF-FOR-BUILD
   371         kx 
   371         kx     # Handle host configuration, which affects the cross-toolset too
   371         kx     sub_conf_opts=""
   371         kx     test -n "$enable_ccache" && sub_conf_opts="$sub_conf_opts --enable-ccache=$enable_ccache"
   371         kx     test -n "$with_ant_home" && sub_conf_opts="$sub_conf_opts --with-ant-home=$with_ant_home"
   371         kx     test "$with_junit" = "no" && sub_conf_opts="$sub_conf_opts --without-junit"
   371         kx     # While we don't need scripting support, we don't have a PYTHON_FOR_BUILD Java equivalent, so must enable scripting for Java
   371         kx     if test -n "$ENABLE_JAVA"; then
   371         kx         case "$_os" in
   371         kx         Android)
   371         kx             # Hack for Android - the build doesn't need a host JDK, so just forward to build for convenience
   371         kx             test -n "$with_jdk_home" && sub_conf_opts="$sub_conf_opts --with-jdk-home=$with_jdk_home"
   371         kx             ;;
   371         kx         *)
   371         kx             if test -z "$with_jdk_home"; then
   371         kx                 AC_MSG_ERROR([Missing host JDK! This can't be detected for the build OS, so you have to specify it with --with-jdk-home.])
   371         kx             fi
   371         kx             ;;
   371         kx         esac
   371         kx     else
   371         kx         sub_conf_opts="$sub_conf_opts --without-java"
   371         kx     fi
   371         kx     test -n "$TARFILE_LOCATION" && sub_conf_opts="$sub_conf_opts --with-external-tar=$TARFILE_LOCATION"
   371         kx     test "$with_galleries" = "no" -o -z "$WITH_GALLERY_BUILD" && sub_conf_opts="$sub_conf_opts --with-galleries=no --disable-database-connectivity"
   371         kx     test "$with_templates" = "no" -o -z "$WITH_TEMPLATES" && sub_conf_opts="$sub_conf_opts --with-templates=no"
   371         kx     test -n "$with_help" -a "$with_help" != "no" && sub_conf_opts="$sub_conf_opts --with-help=$with_help"
   371         kx     test "$enable_extensions" = yes || sub_conf_opts="$sub_conf_opts --disable-extensions"
   371         kx     test "${enable_ld+set}" = set -a "$build_cpu" = "$host_cpu" && sub_conf_opts="$sub_conf_opts --enable-ld=${enable_ld}"
   371         kx     test "${enable_pch+set}" = set && sub_conf_opts="$sub_conf_opts --enable-pch=${enable_pch}"
   371         kx     test "$enable_wasm_strip" = "yes" && sub_conf_opts="$sub_conf_opts --enable-wasm-strip"
   371         kx     test "${with_system_lockfile+set}" = set && sub_conf_opts="$sub_conf_opts --with-system-lockfile=${with_system_lockfile}"
   371         kx     test "${enable_fuzzers}" = yes && sub_conf_opts="$sub_conf_opts --without-system-libxml"
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         sub_conf_opts="$sub_conf_opts --without-system-libxml --without-system-fontconfig --without-system-freetype --without-system-zlib"
   371         kx         if test "${with_main_module+set}" = set; then
   371         kx             sub_conf_opts="$sub_conf_opts --with-main-module=${with_main_module}"
   371         kx         else
   371         kx             sub_conf_opts="$sub_conf_opts --with-main-module=writer"
   371         kx         fi
   371         kx     fi
   371         kx     # windows uses full-internal python and that in turn relies on openssl, so also enable openssl
   371         kx     # when cross-compiling for aarch64, overriding the defaults below
   371         kx     test "${PLATFORMID}" = "windows_aarch64" && sub_conf_opts="$sub_conf_opts --enable-openssl --with-tls=openssl"
   371         kx 
   371         kx     # Don't bother having configure look for stuff not needed for the build platform anyway
   371         kx     # WARNING: any option with an argument containing spaces must be handled separately (see --with-theme)
   371         kx     sub_conf_defaults=" \
   371         kx         --build="$build_alias" \
   371         kx         --disable-cairo-canvas \
   371         kx         --disable-cups \
   371         kx         --disable-customtarget-components \
   371         kx         --disable-firebird-sdbc \
   371         kx         --disable-gpgmepp \
   371         kx         --disable-gstreamer-1-0 \
   371         kx         --disable-gtk3 \
   371         kx         --disable-gtk4 \
   371         kx         --disable-libcmis \
   371         kx         --disable-mariadb-sdbc \
   371         kx         --disable-nss \
   371         kx         --disable-online-update \
   371         kx         --disable-opencl \
   371         kx         --disable-openssl \
   371         kx         --disable-pdfimport \
   371         kx         --disable-postgresql-sdbc \
   371         kx         --disable-skia \
   371         kx         --disable-xmlhelp \
   371         kx         --enable-dynamic-loading \
   371         kx         --enable-icecream="$enable_icecream" \
   371         kx         --without-doxygen \
   371         kx         --without-tls \
   371         kx         --without-webdav \
   371         kx         --without-x \
   371         kx "
   371         kx     # single quotes added for better readability in case of spaces
   371         kx     echo "    Running CONF-FOR-BUILD/configure" \
   371         kx         $sub_conf_defaults \
   371         kx         --with-parallelism="'$with_parallelism'" \
   371         kx         --with-theme="'$with_theme'" \
   371         kx         --with-vendor="'$with_vendor'" \
   371         kx         $sub_conf_opts \
   371         kx         $with_build_platform_configure_options \
   371         kx         --srcdir=$srcdir
   371         kx 
   371         kx     ./configure \
   371         kx         $sub_conf_defaults \
   371         kx         --with-parallelism="$with_parallelism" \
   371         kx         --with-theme="$with_theme" \
   371         kx         "--with-vendor=$with_vendor" \
   371         kx         $sub_conf_opts \
   371         kx         $with_build_platform_configure_options \
   371         kx         --srcdir=$srcdir \
   371         kx         2>&1 | sed -e 's/^/    /'
   371         kx     if test [${PIPESTATUS[0]}] -ne 0; then
   371         kx         AC_MSG_ERROR([Running the configure script for BUILD side failed, see CONF-FOR-BUILD/config.log])
   371         kx     fi
   371         kx 
   371         kx     # filter permitted build targets
   371         kx     PERMITTED_BUILD_TARGETS="
   371         kx         ARGON2
   371         kx         AVMEDIA
   371         kx         BOOST
   371         kx         BZIP2
   371         kx         CAIRO
   371         kx         CLUCENE
   371         kx         CURL
   371         kx         DBCONNECTIVITY
   371         kx         DESKTOP
   371         kx         DRAGONBOX
   371         kx         DYNLOADING
   371         kx         EPOXY
   371         kx         EXPAT
   371         kx         FROZEN
   371         kx         GLM
   371         kx         GRAPHITE
   371         kx         HARFBUZZ
   371         kx         HELPTOOLS
   371         kx         ICU
   371         kx         LCMS2
   371         kx         LIBJPEG_TURBO
   371         kx         LIBLANGTAG
   371         kx         LibO
   371         kx         LIBFFI
   371         kx         LIBPN
   371         kx         LIBTIFF
   371         kx         LIBWEBP
   371         kx         LIBXML2
   371         kx         LIBXSLT
   371         kx         MDDS
   371         kx         NATIVE
   371         kx         OPENSSL
   371         kx         ORCUS
   371         kx         PYTHON
   371         kx         SCRIPTING
   371         kx         ZLIB
   371         kx         ZXCVBN
   371         kx "
   371         kx     # converts BUILD_TYPE and PERMITTED_BUILD_TARGETS into non-whitespace,
   371         kx     # newlined lists, to use grep as a filter
   371         kx     PERMITTED_BUILD_TARGETS=$(echo "$PERMITTED_BUILD_TARGETS" | sed -e '/^ *$/d' -e 's/ *//')
   371         kx     BUILD_TARGETS="$(sed -n -e '/^export BUILD_TYPE=/ s/.*=//p' config_host.mk | tr ' ' '\n')"
   371         kx     BUILD_TARGETS="$(echo "$BUILD_TARGETS" | grep -F "$PERMITTED_BUILD_TARGETS" | tr '\n' ' ')"
   371         kx     sed -i -e "s/ BUILD_TYPE=.*$/ BUILD_TYPE=$BUILD_TARGETS/" config_host.mk
   371         kx 
   371         kx     cp config_host.mk ../config_build.mk
   371         kx     cp config_host_lang.mk ../config_build_lang.mk
   371         kx     mv config.log ../config.Build.log
   371         kx     mkdir -p ../config_build
   371         kx     mv config_host/*.h ../config_build
   371         kx     test -f "$WARNINGS_FILE" && mv "$WARNINGS_FILE" "../$WARNINGS_FILE_FOR_BUILD"
   371         kx 
   371         kx     # all these will get a _FOR_BUILD postfix
   371         kx     DIRECT_FOR_BUILD_SETTINGS="
   371         kx         CC
   371         kx         CPPU_ENV
   371         kx         CXX
   371         kx         ILIB
   371         kx         JAVA_HOME
   371         kx         JAVAIFLAGS
   371         kx         JDK
   371         kx         JDK_SECURITYMANAGER_DISALLOWED
   371         kx         LIBO_BIN_FOLDER
   371         kx         LIBO_LIB_FOLDER
   371         kx         LIBO_URE_LIB_FOLDER
   371         kx         LIBO_URE_MISC_FOLDER
   371         kx         OS
   371         kx         SDKDIRNAME
   371         kx         SYSTEM_LIBXML
   371         kx         SYSTEM_LIBXSLT
   371         kx "
   371         kx     # these overwrite host config with build config
   371         kx     OVERWRITING_SETTINGS="
   371         kx         ANT
   371         kx         ANT_HOME
   371         kx         ANT_LIB
   371         kx         JAVA_SOURCE_VER
   371         kx         JAVA_TARGET_VER
   371         kx         JAVACFLAGS
   371         kx         JAVACOMPILER
   371         kx         JAVADOC
   371         kx         JAVADOCISGJDOC
   371         kx         LOCKFILE
   371         kx         SYSTEM_GENBRK
   371         kx         SYSTEM_GENCCODE
   371         kx         SYSTEM_GENCMN
   371         kx "
   371         kx     # these need some special handling
   371         kx     EXTRA_HANDLED_SETTINGS="
   371         kx         INSTDIR
   371         kx         INSTROOT
   371         kx         PATH
   371         kx         WORKDIR
   371         kx "
   371         kx     OLD_PATH=$PATH
   371         kx     . ./bin/get_config_variables $DIRECT_FOR_BUILD_SETTINGS $OVERWRITING_SETTINGS $EXTRA_HANDLED_SETTINGS
   371         kx     BUILD_PATH=$PATH
   371         kx     PATH=$OLD_PATH
   371         kx 
   371         kx     line=`echo "LO_PATH_FOR_BUILD='${BUILD_PATH}'" | sed -e 's,/CONF-FOR-BUILD,,g'`
   371         kx     echo "$line" >>build-config
   371         kx 
   371         kx     for V in $DIRECT_FOR_BUILD_SETTINGS; do
   371         kx         VV='$'$V
   371         kx         VV=`eval "echo $VV"`
   371         kx         if test -n "$VV"; then
   371         kx             line=${V}_FOR_BUILD='${'${V}_FOR_BUILD:-$VV'}'
   371         kx             echo "$line" >>build-config
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     for V in $OVERWRITING_SETTINGS; do
   371         kx         VV='$'$V
   371         kx         VV=`eval "echo $VV"`
   371         kx         if test -n "$VV"; then
   371         kx             line=${V}='${'${V}:-$VV'}'
   371         kx             echo "$line" >>build-config
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     for V in INSTDIR INSTROOT WORKDIR; do
   371         kx         VV='$'$V
   371         kx         VV=`eval "echo $VV"`
   371         kx         VV=`echo $VV | sed -e "s,/CONF-FOR-BUILD/\([[a-z]]*\),/\1_for_build,g"`
   371         kx         if test -n "$VV"; then
   371         kx             line="${V}_FOR_BUILD='$VV'"
   371         kx             echo "$line" >>build-config
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     )
   371         kx     test -f CONF-FOR-BUILD/build-config || AC_MSG_ERROR([setup/configure for BUILD side failed, see CONF-FOR-BUILD/config.log])
   371         kx     test -f config_build.mk || AC_MSG_ERROR([A file called config_build.mk was supposed to have been copied here, but it isn't found])
   371         kx     perl -pi -e 's,/(workdir|instdir)(/|$),/\1_for_build\2,g;' \
   371         kx              -e 's,/CONF-FOR-BUILD,,g;' config_build.mk
   371         kx 
   371         kx     eval `cat CONF-FOR-BUILD/build-config`
   371         kx 
   371         kx     AC_MSG_RESULT([checking for BUILD platform configuration... done])
   371         kx 
   371         kx     rm -rf CONF-FOR-BUILD
   371         kx else
   371         kx     OS_FOR_BUILD="$OS"
   371         kx     CC_FOR_BUILD="$CC"
   371         kx     CPPU_ENV_FOR_BUILD="$CPPU_ENV"
   371         kx     CXX_FOR_BUILD="$CXX"
   371         kx     INSTDIR_FOR_BUILD="$INSTDIR"
   371         kx     INSTROOT_FOR_BUILD="$INSTROOT"
   371         kx     LIBO_BIN_FOLDER_FOR_BUILD="$LIBO_BIN_FOLDER"
   371         kx     LIBO_LIB_FOLDER_FOR_BUILD="$LIBO_LIB_FOLDER"
   371         kx     LIBO_URE_LIB_FOLDER_FOR_BUILD="$LIBO_URE_LIB_FOLDER"
   371         kx     LIBO_URE_MISC_FOLDER_FOR_BUILD="$LIBO_URE_MISC_FOLDER"
   371         kx     SDKDIRNAME_FOR_BUILD="$SDKDIRNAME"
   371         kx     WORKDIR_FOR_BUILD="$WORKDIR"
   371         kx fi
   371         kx AC_SUBST(OS_FOR_BUILD)
   371         kx AC_SUBST(INSTDIR_FOR_BUILD)
   371         kx AC_SUBST(INSTROOT_FOR_BUILD)
   371         kx AC_SUBST(LIBO_BIN_FOLDER_FOR_BUILD)
   371         kx AC_SUBST(LIBO_LIB_FOLDER_FOR_BUILD)
   371         kx AC_SUBST(LIBO_URE_LIB_FOLDER_FOR_BUILD)
   371         kx AC_SUBST(LIBO_URE_MISC_FOLDER_FOR_BUILD)
   371         kx AC_SUBST(SDKDIRNAME_FOR_BUILD)
   371         kx AC_SUBST(WORKDIR_FOR_BUILD)
   371         kx AC_SUBST(CC_FOR_BUILD)
   371         kx AC_SUBST(CXX_FOR_BUILD)
   371         kx AC_SUBST(CPPU_ENV_FOR_BUILD)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for lockfile deps
   371         kx dnl ===================================================================
   371         kx if test -z "$CROSS_COMPILING"; then
   371         kx     test -n "$LOCKFILE" -a "${with_system_lockfile+set}" != set && with_system_lockfile="$LOCKFILE"
   371         kx     test "${with_system_lockfile+set}" = set || with_system_lockfile=no
   371         kx     AC_MSG_CHECKING([which lockfile binary to use])
   371         kx     case "$with_system_lockfile" in
   371         kx     yes)
   371         kx         AC_MSG_RESULT([external])
   371         kx         AC_PATH_PROGS([LOCKFILE],[dotlockfile lockfile])
   371         kx         ;;
   371         kx     no)
   371         kx         AC_MSG_RESULT([internal])
   371         kx         ;;
   371         kx     *)
   371         kx         if test -x "$with_system_lockfile"; then
   371         kx             LOCKFILE="$with_system_lockfile"
   371         kx         else
   371         kx             AC_MSG_ERROR(['$with_system_lockfile' is not executable.])
   371         kx         fi
   371         kx         AC_MSG_RESULT([$with_system_lockfile])
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx if test -n "$LOCKFILE" -a "$DISABLE_DYNLOADING" = TRUE; then
   371         kx     add_warning "The default system lockfile has increasing poll intervals up to 60s, so linking executables may be delayed."
   371         kx fi
   371         kx 
   371         kx AC_CHECK_HEADERS([getopt.h paths.h sys/param.h])
   371         kx AC_CHECK_FUNCS([utime utimes])
   371         kx AC_SUBST(LOCKFILE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for syslog header
   371         kx dnl ===================================================================
   371         kx AC_CHECK_HEADER(syslog.h, AC_DEFINE(HAVE_SYSLOG_H))
   371         kx 
   371         kx dnl Set the ENABLE_WERROR variable. (Activate --enable-werror)
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to turn warnings to errors])
   371         kx if test -n "$enable_werror" -a "$enable_werror" != "no"; then
   371         kx     ENABLE_WERROR="TRUE"
   371         kx     PYTHONWARNINGS="error"
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     if test -n "$LODE_HOME" -a -z "$enable_werror"; then
   371         kx         ENABLE_WERROR="TRUE"
   371         kx         PYTHONWARNINGS="error"
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_WERROR)
   371         kx AC_SUBST(PYTHONWARNINGS)
   371         kx 
   371         kx dnl Check for --enable-assert-always-abort, set ASSERT_ALWAYS_ABORT
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to have assert() failures abort even without --enable-debug])
   371         kx if test -z "$enable_assert_always_abort"; then
   371         kx    if test "$ENABLE_DEBUG" = TRUE; then
   371         kx        enable_assert_always_abort=yes
   371         kx    else
   371         kx        enable_assert_always_abort=no
   371         kx    fi
   371         kx fi
   371         kx if test "$enable_assert_always_abort" = "yes"; then
   371         kx     ASSERT_ALWAYS_ABORT="TRUE"
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     ASSERT_ALWAYS_ABORT="FALSE"
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ASSERT_ALWAYS_ABORT)
   371         kx 
   371         kx # Determine whether to use ooenv for the instdir installation
   371         kx # ===================================================================
   371         kx if test $_os != "WINNT" -a $_os != "Darwin"; then
   371         kx     AC_MSG_CHECKING([whether to use ooenv for the instdir installation])
   371         kx     if test -z "$enable_ooenv"; then
   371         kx         if test -n "$ENABLE_DEBUG$ENABLE_DBGUTIL"; then
   371         kx             enable_ooenv=yes
   371         kx         else
   371         kx             enable_ooenv=no
   371         kx         fi
   371         kx     fi
   371         kx     if test "$enable_ooenv" = "no"; then
   371         kx         AC_MSG_RESULT([no])
   371         kx     else
   371         kx         ENABLE_OOENV="TRUE"
   371         kx         AC_MSG_RESULT([yes])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_OOENV)
   371         kx 
   371         kx if test "$test_kf5" = "yes" -a "$enable_kf5" = "yes"; then
   371         kx     if test "$enable_qt5" = "no"; then
   371         kx         AC_MSG_ERROR([KF5 support depends on QT5, so it conflicts with --disable-qt5])
   371         kx     else
   371         kx         enable_qt5=yes
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test "$test_kf6" = "yes" -a "$enable_kf6" = "yes"; then
   371         kx     if test "$enable_qt6" = "no"; then
   371         kx         AC_MSG_ERROR([KF6 support depends on QT6, so it conflicts with --disable-qt6])
   371         kx     else
   371         kx         enable_qt6=yes
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build the pagein binaries for oosplash])
   371         kx if test "${enable_pagein}" != no -a -z "$DISABLE_DYNLOADING"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_PAGEIN=TRUE
   371         kx     AC_DEFINE(HAVE_FEATURE_PAGEIN)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_PAGEIN)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl check for cups support
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable CUPS support])
   371         kx if test "$test_cups" = yes -a "$enable_cups" != no; then
   371         kx     ENABLE_CUPS=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether cups support is present])
   371         kx     AC_CHECK_LIB([cups], [cupsPrintFiles], [:])
   371         kx     AC_CHECK_HEADER(cups/cups.h, AC_DEFINE(HAVE_CUPS_H))
   371         kx     if test "$ac_cv_lib_cups_cupsPrintFiles" != "yes" -o "$ac_cv_header_cups_cups_h" != "yes"; then
   371         kx         AC_MSG_ERROR([Could not find CUPS. Install libcups2-dev or cups-devel.])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_CUPS)
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([fontconfig],[FONTCONFIG],[fontconfig >= 2.12.0],,system,TRUE)
   371         kx 
   371         kx dnl whether to find & fetch external tarballs?
   371         kx dnl ===================================================================
   371         kx if test -z "$TARFILE_LOCATION" -a -n "$LODE_HOME" ; then
   371         kx    if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx        TARFILE_LOCATION="`cygpath -m $LODE_HOME/ext_tar`"
   371         kx    else
   371         kx        TARFILE_LOCATION="$LODE_HOME/ext_tar"
   371         kx    fi
   371         kx fi
   371         kx if test -z "$TARFILE_LOCATION"; then
   371         kx     if test -d "$SRC_ROOT/src" ; then
   371         kx         mv "$SRC_ROOT/src" "$SRC_ROOT/external/tarballs"
   371         kx         ln -s "$SRC_ROOT/external/tarballs" "$SRC_ROOT/src"
   371         kx     fi
   371         kx     TARFILE_LOCATION="$SRC_ROOT/external/tarballs"
   371         kx else
   371         kx     AbsolutePath "$TARFILE_LOCATION"
   371         kx     PathFormat "${absolute_path}"
   371         kx     TARFILE_LOCATION="${formatted_path_unix}"
   371         kx fi
   371         kx AC_SUBST(TARFILE_LOCATION)
   371         kx 
   371         kx AC_MSG_CHECKING([whether we want to fetch tarballs])
   371         kx if test "$enable_fetch_external" != "no"; then
   371         kx     if test "$with_all_tarballs" = "yes"; then
   371         kx         AC_MSG_RESULT([yes, all of them])
   371         kx         DO_FETCH_TARBALLS="ALL"
   371         kx     else
   371         kx         AC_MSG_RESULT([yes, if we use them])
   371         kx         DO_FETCH_TARBALLS="TRUE"
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     DO_FETCH_TARBALLS=
   371         kx fi
   371         kx AC_SUBST(DO_FETCH_TARBALLS)
   371         kx 
   371         kx dnl Test whether to include MySpell dictionaries
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to include MySpell dictionaries])
   371         kx if test "$with_myspell_dicts" = "yes"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     WITH_MYSPELL_DICTS=TRUE
   371         kx     BUILD_TYPE="$BUILD_TYPE DICTIONARIES"
   371         kx     GIT_NEEDED_SUBMODULES="dictionaries $GIT_NEEDED_SUBMODULES"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     WITH_MYSPELL_DICTS=
   371         kx fi
   371         kx AC_SUBST(WITH_MYSPELL_DICTS)
   371         kx 
   371         kx # There are no "system" myspell, hyphen or mythes dictionaries on macOS, Windows, Android or iOS.
   371         kx if test $_os = Darwin -o $_os = WINNT -o $_os = iOS -o $_os = Android; then
   371         kx     if test "$with_system_dicts" = yes; then
   371         kx         AC_MSG_ERROR([There are no system dicts on this OS in the formats the 3rd-party libs we use expect]);
   371         kx     fi
   371         kx     with_system_dicts=no
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to use dicts from external paths])
   371         kx if test -z "$with_system_dicts" -o "$with_system_dicts" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     SYSTEM_DICTS=TRUE
   371         kx     AC_MSG_CHECKING([for spelling dictionary directory])
   371         kx     if test -n "$with_external_dict_dir"; then
   371         kx         DICT_SYSTEM_DIR=file://$with_external_dict_dir
   371         kx     else
   371         kx         DICT_SYSTEM_DIR=file:///usr/share/hunspell
   371         kx         if test ! -d /usr/share/hunspell -a -d /usr/share/myspell; then
   371         kx             DICT_SYSTEM_DIR=file:///usr/share/myspell
   371         kx         fi
   371         kx     fi
   371         kx     AC_MSG_RESULT([$DICT_SYSTEM_DIR])
   371         kx     AC_MSG_CHECKING([for hyphenation patterns directory])
   371         kx     if test -n "$with_external_hyph_dir"; then
   371         kx         HYPH_SYSTEM_DIR=file://$with_external_hyph_dir
   371         kx     else
   371         kx         HYPH_SYSTEM_DIR=file:///usr/share/hyphen
   371         kx     fi
   371         kx     AC_MSG_RESULT([$HYPH_SYSTEM_DIR])
   371         kx     AC_MSG_CHECKING([for thesaurus directory])
   371         kx     if test -n "$with_external_thes_dir"; then
   371         kx         THES_SYSTEM_DIR=file://$with_external_thes_dir
   371         kx     else
   371         kx         THES_SYSTEM_DIR=file:///usr/share/mythes
   371         kx     fi
   371         kx     AC_MSG_RESULT([$THES_SYSTEM_DIR])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     SYSTEM_DICTS=
   371         kx fi
   371         kx AC_SUBST(SYSTEM_DICTS)
   371         kx AC_SUBST(DICT_SYSTEM_DIR)
   371         kx AC_SUBST(HYPH_SYSTEM_DIR)
   371         kx AC_SUBST(THES_SYSTEM_DIR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Precompiled headers.
   371         kx ENABLE_PCH=""
   371         kx AC_MSG_CHECKING([whether to enable pch feature])
   371         kx if test -z "$enable_pch"; then
   371         kx     if test "$_os" = "WINNT"; then
   371         kx         # Enabled by default on Windows.
   371         kx         enable_pch=yes
   371         kx         # never use sccache on auto-enabled PCH builds, except if requested explicitly
   371         kx         if test -z "$enable_ccache" -a "$SCCACHE"; then
   371         kx             CCACHE=""
   371         kx         fi
   371         kx     else
   371         kx         enable_pch=no
   371         kx     fi
   371         kx fi
   371         kx if test "$enable_pch" != no -a "$_os" = Emscripten -a "$ENABLE_WASM_EXCEPTIONS" = TRUE; then
   371         kx     AC_MSG_ERROR([PCH currently isn't supported for Emscripten with native EH (nEH) because of missing Sj/Lj support with nEH in clang.])
   371         kx fi
   371         kx if test "$enable_pch" != "no" -a "$_os" != "WINNT" -a "$GCC" != "yes" ; then
   371         kx     AC_MSG_ERROR([Precompiled header not yet supported for your platform/compiler])
   371         kx fi
   371         kx if test "$enable_pch" = "system"; then
   371         kx     ENABLE_PCH="1"
   371         kx     AC_MSG_RESULT([yes (system headers)])
   371         kx elif test "$enable_pch" = "base"; then
   371         kx     ENABLE_PCH="2"
   371         kx     AC_MSG_RESULT([yes (system and base headers)])
   371         kx elif test "$enable_pch" = "normal"; then
   371         kx     ENABLE_PCH="3"
   371         kx     AC_MSG_RESULT([yes (normal)])
   371         kx elif test "$enable_pch" = "full"; then
   371         kx     ENABLE_PCH="4"
   371         kx     AC_MSG_RESULT([yes (full)])
   371         kx elif test "$enable_pch" = "yes"; then
   371         kx     # Pick a suitable default.
   371         kx     if test "$GCC" = "yes"; then
   371         kx         # With Clang and GCC higher levels do not seem to make a noticeable improvement,
   371         kx         # while making the PCHs larger and rebuilds more likely.
   371         kx         ENABLE_PCH="2"
   371         kx         AC_MSG_RESULT([yes (system and base headers)])
   371         kx     else
   371         kx         # With MSVC the highest level makes a significant difference,
   371         kx         # and it was the default when there used to be no PCH levels.
   371         kx         ENABLE_PCH="4"
   371         kx         AC_MSG_RESULT([yes (full)])
   371         kx     fi
   371         kx elif test "$enable_pch" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     AC_MSG_ERROR([Unknown value for --enable-pch])
   371         kx fi
   371         kx AC_SUBST(ENABLE_PCH)
   371         kx # ccache 3.7.1 and older do not properly detect/handle -include .gch in CCACHE_DEPEND mode
   371         kx if test -n "$ENABLE_PCH" -a -n "$CCACHE_DEPEND_MODE" -a "$GCC" = "yes" -a "$COM_IS_CLANG" != "TRUE"; then
   371         kx     AC_PATH_PROG([CCACHE_BIN],[ccache],[not found])
   371         kx     if test "$CCACHE_BIN" != "not found"; then
   371         kx         AC_MSG_CHECKING([ccache version])
   371         kx         CCACHE_VERSION=`"$CCACHE_BIN" -V | "$AWK" '/^ccache version/{print $3}'`
   371         kx         CCACHE_NUMVER=`echo $CCACHE_VERSION | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
   371         kx         AC_MSG_RESULT([$CCACHE_VERSION])
   371         kx         AC_MSG_CHECKING([whether ccache depend mode works properly with GCC PCH])
   371         kx         if test "$CCACHE_NUMVER" -gt "030701"; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             AC_MSG_RESULT([no (not newer than 3.7.1)])
   371         kx             CCACHE_DEPEND_MODE=
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx PCH_INSTANTIATE_TEMPLATES=
   371         kx if test -n "$ENABLE_PCH"; then
   371         kx     AC_MSG_CHECKING([whether $CC supports -fpch-instantiate-templates])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror -fpch-instantiate-templates"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ PCH_INSTANTIATE_TEMPLATES="-fpch-instantiate-templates" ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test -n "$PCH_INSTANTIATE_TEMPLATES"; then
   371         kx         AC_MSG_RESULT(yes)
   371         kx     else
   371         kx         AC_MSG_RESULT(no)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(PCH_INSTANTIATE_TEMPLATES)
   371         kx 
   371         kx BUILDING_PCH_WITH_OBJ=
   371         kx if test -n "$ENABLE_PCH"; then
   371         kx     AC_MSG_CHECKING([whether $CC supports -Xclang -building-pch-with-obj])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror -Xclang -building-pch-with-obj"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ BUILDING_PCH_WITH_OBJ="-Xclang -building-pch-with-obj" ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test -n "$BUILDING_PCH_WITH_OBJ"; then
   371         kx         AC_MSG_RESULT(yes)
   371         kx     else
   371         kx         AC_MSG_RESULT(no)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(BUILDING_PCH_WITH_OBJ)
   371         kx 
   371         kx PCH_CODEGEN=
   371         kx PCH_NO_CODEGEN=
   371         kx fpch_prefix=
   371         kx if test "$COM" = MSC; then
   371         kx     fpch_prefix="-Xclang "
   371         kx fi
   371         kx if test -n "$BUILDING_PCH_WITH_OBJ"; then
   371         kx     AC_MSG_CHECKING([whether $CC supports ${fpch_prefix}-fpch-codegen])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror ${fpch_prefix}-fpch-codegen"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],
   371         kx         [ PCH_CODEGEN="${fpch_prefix}-fpch-codegen" ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror ${fpch_prefix}-fno-pch-codegen"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],
   371         kx         [ PCH_NO_CODEGEN="${fpch_prefix}-fno-pch-codegen" ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test -n "$PCH_CODEGEN"; then
   371         kx         AC_MSG_RESULT(yes)
   371         kx     else
   371         kx         AC_MSG_RESULT(no)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(PCH_CODEGEN)
   371         kx AC_SUBST(PCH_NO_CODEGEN)
   371         kx PCH_DEBUGINFO=
   371         kx if test -n "$BUILDING_PCH_WITH_OBJ"; then
   371         kx     AC_MSG_CHECKING([whether $CC supports ${fpch_prefix}-fpch-debuginfo])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror ${fpch_prefix}-fpch-debuginfo"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ PCH_DEBUGINFO="${fpch_prefix}-fpch-debuginfo" ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test -n "$PCH_DEBUGINFO"; then
   371         kx         AC_MSG_RESULT(yes)
   371         kx     else
   371         kx         AC_MSG_RESULT(no)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(PCH_DEBUGINFO)
   371         kx 
   371         kx TAB=`printf '\t'`
   371         kx 
   371         kx AC_MSG_CHECKING([the GNU Make version])
   371         kx _make_version=`$GNUMAKE --version | grep GNU | $GREP -v GPL | $SED -e 's@^[[^0-9]]*@@' -e 's@ .*@@' -e 's@,.*@@'`
   371         kx _make_longver=`echo $_make_version | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
   371         kx if test "$_make_longver" -ge "040000"; then
   371         kx     AC_MSG_RESULT([$GNUMAKE $_make_version])
   371         kx else
   371         kx     AC_MSG_ERROR([failed ($GNUMAKE version >= 4.0 needed)])
   371         kx fi
   371         kx 
   371         kx _make_ver_check=`$GNUMAKE --version | grep "Built for Windows"`
   371         kx STALE_MAKE=
   371         kx if test "$_make_ver_check" = ""; then
   371         kx    STALE_MAKE=TRUE
   371         kx fi
   371         kx 
   371         kx HAVE_LD_HASH_STYLE=FALSE
   371         kx WITH_LINKER_HASH_STYLE=
   371         kx AC_MSG_CHECKING([for --hash-style gcc linker support])
   371         kx if test "$GCC" = "yes"; then
   371         kx     if test -z "$with_linker_hash_style" -o "$with_linker_hash_style" = "yes"; then
   371         kx         hash_styles="gnu sysv"
   371         kx     elif test "$with_linker_hash_style" = "no"; then
   371         kx         hash_styles=
   371         kx     else
   371         kx         hash_styles="$with_linker_hash_style"
   371         kx     fi
   371         kx 
   371         kx     for hash_style in $hash_styles; do
   371         kx         test "$HAVE_LD_HASH_STYLE" = "TRUE" && continue
   371         kx         hash_style_ldflags_save=$LDFLAGS
   371         kx         LDFLAGS="$LDFLAGS -Wl,--hash-style=$hash_style"
   371         kx 
   371         kx         AC_RUN_IFELSE([AC_LANG_PROGRAM(
   371         kx             [
   371         kx #include <stdio.h>
   371         kx             ],[
   371         kx printf ("");
   371         kx             ])],
   371         kx             [
   371         kx                   HAVE_LD_HASH_STYLE=TRUE
   371         kx                   WITH_LINKER_HASH_STYLE=$hash_style
   371         kx             ],
   371         kx             [HAVE_LD_HASH_STYLE=FALSE],
   371         kx             [HAVE_LD_HASH_STYLE=FALSE])
   371         kx         LDFLAGS=$hash_style_ldflags_save
   371         kx     done
   371         kx 
   371         kx     if test "$HAVE_LD_HASH_STYLE" = "TRUE"; then
   371         kx         AC_MSG_RESULT( $WITH_LINKER_HASH_STYLE )
   371         kx     else
   371         kx         AC_MSG_RESULT( no )
   371         kx     fi
   371         kx     LDFLAGS=$hash_style_ldflags_save
   371         kx else
   371         kx     AC_MSG_RESULT( no )
   371         kx fi
   371         kx AC_SUBST(HAVE_LD_HASH_STYLE)
   371         kx AC_SUBST(WITH_LINKER_HASH_STYLE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check whether there's a Perl version available.
   371         kx dnl ===================================================================
   371         kx if test -z "$with_perl_home"; then
   371         kx     AC_PATH_PROG(PERL, perl)
   371         kx else
   371         kx     test "$build_os" = "cygwin" && with_perl_home=`cygpath -u "$with_perl_home"`
   371         kx     _perl_path="$with_perl_home/bin/perl"
   371         kx     if test -x "$_perl_path"; then
   371         kx         PERL=$_perl_path
   371         kx     else
   371         kx         AC_MSG_ERROR([$_perl_path not found])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Testing for Perl version 5 or greater.
   371         kx dnl $] is the Perl version variable, it is returned as an integer
   371         kx dnl ===================================================================
   371         kx if test "$PERL"; then
   371         kx     AC_MSG_CHECKING([the Perl version])
   371         kx     ${PERL} -e "exit($]);"
   371         kx     _perl_version=$?
   371         kx     if test "$_perl_version" -lt 5; then
   371         kx         AC_MSG_ERROR([found Perl $_perl_version, use Perl 5])
   371         kx     fi
   371         kx     AC_MSG_RESULT([Perl $_perl_version])
   371         kx else
   371         kx     AC_MSG_ERROR([Perl not found, install Perl 5])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Testing for required Perl modules
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([for required Perl modules])
   371         kx perl_use_string="use Cwd ; use Digest::MD5"
   371         kx if test "$_os" = "WINNT"; then
   371         kx     if test -n "$PKGFORMAT"; then
   371         kx         for i in $PKGFORMAT; do
   371         kx             case "$i" in
   371         kx             msi)
   371         kx                 # for getting fonts versions to use in MSI
   371         kx                 perl_use_string="$perl_use_string ; use Font::TTF::Font"
   371         kx                 ;;
   371         kx             esac
   371         kx         done
   371         kx     fi
   371         kx fi
   371         kx if test "$with_system_hsqldb" = "yes"; then
   371         kx     perl_use_string="$perl_use_string ; use Archive::Zip"
   371         kx fi
   371         kx if test "$enable_openssl" = "yes" -a "$with_system_openssl" != "yes"; then
   371         kx     # OpenSSL needs that to build
   371         kx     perl_use_string="$perl_use_string ; use FindBin"
   371         kx fi
   371         kx if $PERL -e "$perl_use_string">/dev/null 2>&1; then
   371         kx     AC_MSG_RESULT([all modules found])
   371         kx else
   371         kx     AC_MSG_RESULT([failed to find some modules])
   371         kx     # Find out which modules are missing.
   371         kx     for i in $perl_use_string; do
   371         kx         if test "$i" != "use" -a "$i" != ";"; then
   371         kx             if ! $PERL -e "use $i;">/dev/null 2>&1; then
   371         kx                 missing_perl_modules="$missing_perl_modules $i"
   371         kx             fi
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_ERROR([
   371         kx     The missing Perl modules are: $missing_perl_modules
   371         kx     Install them as superuser/administrator with "cpan -i $missing_perl_modules"])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for pkg-config
   371         kx dnl ===================================================================
   371         kx if test "$_os" != "WINNT"; then
   371         kx     PKG_PROG_PKG_CONFIG
   371         kx fi
   371         kx AC_SUBST(PKG_CONFIG)
   371         kx AC_SUBST(PKG_CONFIG_PATH)
   371         kx AC_SUBST(PKG_CONFIG_LIBDIR)
   371         kx 
   371         kx if test "$_os" != "WINNT"; then
   371         kx 
   371         kx     # If you use CC=/path/to/compiler/foo-gcc or even CC="ccache
   371         kx     # /path/to/compiler/foo-gcc" you need to set the AR etc env vars
   371         kx     # explicitly. Or put /path/to/compiler in PATH yourself.
   371         kx 
   371         kx     toolprefix=gcc
   371         kx     if test "$COM_IS_CLANG" = "TRUE"; then
   371         kx         toolprefix=llvm
   371         kx     fi
   371         kx     AC_CHECK_TOOLS(AR,$toolprefix-ar ar)
   371         kx     AC_CHECK_TOOLS(NM,$toolprefix-nm nm)
   371         kx     AC_CHECK_TOOLS(RANLIB,$toolprefix-ranlib ranlib)
   371         kx     AC_CHECK_TOOLS(OBJDUMP,$toolprefix-objdump objdump)
   371         kx     AC_CHECK_TOOLS(READELF,$toolprefix-readelf readelf)
   371         kx     AC_CHECK_TOOLS(STRIP,$toolprefix-strip strip)
   371         kx fi
   371         kx AC_SUBST(AR)
   371         kx AC_SUBST(NM)
   371         kx AC_SUBST(OBJDUMP)
   371         kx AC_SUBST(RANLIB)
   371         kx AC_SUBST(READELF)
   371         kx AC_SUBST(STRIP)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl pkg-config checks on macOS
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test $_os = Darwin; then
   371         kx     AC_MSG_CHECKING([for bogus pkg-config])
   371         kx     if test -n "$PKG_CONFIG"; then
   371         kx         if test "$PKG_CONFIG" = /usr/bin/pkg-config && ls -l /usr/bin/pkg-config | $GREP -q Mono.framework; then
   371         kx             AC_MSG_ERROR([yes, from Mono. This *will* break the build. Please remove or hide $PKG_CONFIG])
   371         kx         else
   371         kx             if test "$enable_bogus_pkg_config" = "yes"; then
   371         kx                 AC_MSG_RESULT([yes, user-approved from unknown origin.])
   371         kx             else
   371         kx                 AC_MSG_ERROR([yes, from unknown origin. This *will* break the build. Please modify your PATH variable so that $PKG_CONFIG is no longer found by configure scripts.])
   371         kx             fi
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([no, good])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx find_csc()
   371         kx {
   371         kx     # Return value: $csctest
   371         kx 
   371         kx     unset csctest
   371         kx 
   371         kx     reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/NET Framework Setup/NDP/v4/Client/InstallPath"
   371         kx     if test -n "$regvalue"; then
   371         kx         csctest=$regvalue
   371         kx         return
   371         kx     fi
   371         kx }
   371         kx 
   371         kx find_al()
   371         kx {
   371         kx     # Return value: $altest
   371         kx 
   371         kx     unset altest
   371         kx 
   371         kx     # We need this check to detect 4.6.1 or above.
   371         kx     for ver in 4.8.1 4.8 4.7.2 4.7.1 4.7 4.6.2 4.6.1; do
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/NETFXSDK/$ver/WinSDK-NetFx40Tools/InstallationFolder"
   371         kx         PathFormat "$regvalue"
   371         kx         if test -n "$regvalue" -a \( -f "$formatted_path_unix/al.exe" -o -f "$formatted_path_unix/bin/al.exe" \); then
   371         kx             altest=$regvalue
   371         kx             return
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     reg_list_values_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows"
   371         kx     for x in $reglist; do
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows/$x/WinSDK-NetFx40Tools/InstallationFolder"
   371         kx         PathFormat "$regvalue"
   371         kx         if test -n "$regvalue" -a \( -f "$formatted_path_unix/al.exe" -o -f "$formatted_path_unix/bin/al.exe" \); then
   371         kx             altest=$regvalue
   371         kx             return
   371         kx         fi
   371         kx     done
   371         kx }
   371         kx 
   371         kx find_dotnetsdk()
   371         kx {
   371         kx     unset frametest
   371         kx 
   371         kx     for ver in 4.8.1 4.8 4.7.2 4.7.1 4.7 4.6.2 4.6.1 4.6; do
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/NETFXSDK/$ver/KitsInstallationFolder"
   371         kx         if test -n "$regvalue"; then
   371         kx             frametest=$regvalue
   371         kx             return
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_ERROR([The Windows NET SDK (minimum 4.6) not found, check the installation])
   371         kx }
   371         kx 
   371         kx find_winsdk_version()
   371         kx {
   371         kx     # Args: $1 : SDK version as in "8.0", "8.1A" etc
   371         kx     # Return values: $winsdktest, $winsdkbinsubdir, $winsdklibsubdir
   371         kx 
   371         kx     unset winsdktest winsdkbinsubdir winsdklibsubdir
   371         kx 
   371         kx     case "$1" in
   371         kx     8.0|8.0A)
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows Kits/Installed Roots/KitsRoot"
   371         kx         if test -n "$regvalue"; then
   371         kx             winsdktest=$regvalue
   371         kx             winsdklibsubdir=win8
   371         kx             return
   371         kx         fi
   371         kx         ;;
   371         kx     8.1|8.1A)
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows Kits/Installed Roots/KitsRoot81"
   371         kx         if test -n "$regvalue"; then
   371         kx             winsdktest=$regvalue
   371         kx             winsdklibsubdir=winv6.3
   371         kx             return
   371         kx         fi
   371         kx         ;;
   371         kx     10.0)
   371         kx         reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows/v${1}/InstallationFolder"
   371         kx         if test -n "$regvalue"; then
   371         kx             winsdktest=$regvalue
   371         kx             reg_get_value_32 "HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Microsoft SDKs/Windows/v${1}/ProductVersion"
   371         kx             if test -n "$regvalue"; then
   371         kx                 winsdkbinsubdir="$regvalue".0
   371         kx                 winsdklibsubdir=$winsdkbinsubdir
   371         kx                 local tmppath="$winsdktest\\Include\\$winsdklibsubdir"
   371         kx                 local tmppath_unix=$(cygpath -u "$tmppath")
   371         kx                 # test exist the SDK path
   371         kx                 if test -d "$tmppath_unix"; then
   371         kx                    # when path is convertible to a short path then path is okay
   371         kx                    cygpath -d "$tmppath" >/dev/null 2>&1
   371         kx                    if test $? -ne 0; then
   371         kx                       AC_MSG_ERROR([Windows SDK doesn't have a 8.3 name, see NtfsDisable8dot3NameCreation])
   371         kx                    fi
   371         kx                 else
   371         kx                    AC_MSG_ERROR([The Windows SDK not found, check the installation])
   371         kx                 fi
   371         kx             fi
   371         kx             return
   371         kx         fi
   371         kx         ;;
   371         kx     esac
   371         kx }
   371         kx 
   371         kx find_winsdk()
   371         kx {
   371         kx     # Return value: From find_winsdk_version
   371         kx 
   371         kx     unset winsdktest
   371         kx 
   371         kx     for ver in $WINDOWS_SDK_ACCEPTABLE_VERSIONS; do
   371         kx         find_winsdk_version $ver
   371         kx         if test -n "$winsdktest"; then
   371         kx             return
   371         kx         fi
   371         kx     done
   371         kx }
   371         kx 
   371         kx find_msms()
   371         kx {
   371         kx     # Return value: $msmdir
   371         kx     local version="$1"
   371         kx 
   371         kx     AC_MSG_CHECKING([for MSVC $version merge modules directory])
   371         kx     local my_msm_file="Microsoft_VC${version}_CRT_x86.msm"
   371         kx     local my_msm_dir
   371         kx 
   371         kx     echo "$as_me:$LINENO: searching for $my_msm_file" >&5
   371         kx 
   371         kx     msmdir=
   371         kx     case "$VCVER" in
   371         kx     16.0 | 17.0 | 17.9)
   371         kx         for l in `ls -1 $VC_PRODUCT_DIR/redist/MSVC/`; do
   371         kx             my_msm_dir="$VC_PRODUCT_DIR/redist/MSVC/$l/MergeModules/"
   371         kx             echo "$as_me:$LINENO: looking for $my_msm_dir${my_msm_file}])" >&5
   371         kx             if test -e "$my_msm_dir${my_msm_file}"; then
   371         kx                 msmdir=$my_msm_dir
   371         kx             fi
   371         kx         done
   371         kx         ;;
   371         kx     esac
   371         kx 
   371         kx     if test -n "$msmdir"; then
   371         kx         msmdir=`cygpath -m "$msmdir"`
   371         kx         AC_MSG_RESULT([$msmdir])
   371         kx     else
   371         kx         if test "$ENABLE_RELEASE_BUILD" = "TRUE" ; then
   371         kx             AC_MSG_FAILURE([not found])
   371         kx         else
   371         kx             AC_MSG_WARN([not found (check config.log)])
   371         kx             add_warning "MSM ${my_msm_file} not found"
   371         kx         fi
   371         kx     fi
   371         kx }
   371         kx 
   371         kx find_msvc_x64_dlls()
   371         kx {
   371         kx     # Return value: $msvcdllpath, $msvcdlls
   371         kx 
   371         kx     AC_MSG_CHECKING([for MSVC x64 DLL path])
   371         kx 
   371         kx     dnl Order crtver in increasing order. Then check the directories returned by
   371         kx     dnl ls in an inner loop; assuming they are also ordered in increasing order,
   371         kx     dnl the result will be the highest CRT version found in the highest directory.
   371         kx 
   371         kx     msvcdllpath="$VC_PRODUCT_DIR/redist/x64/Microsoft.VC${VCVER}.CRT"
   371         kx     case "$VCVER" in
   371         kx     16.0 | 17.0 | 17.9)
   371         kx         for crtver in 141 142 143; do
   371         kx             for l in `ls -1 $VC_PRODUCT_DIR/redist/MSVC/`; do
   371         kx                 echo "$as_me:$LINENO: testing $VC_PRODUCT_DIR/redist/MSVC/$l/x64/Microsoft.VC$crtver.CRT" >&5
   371         kx                 if test -d "$VC_PRODUCT_DIR/redist/MSVC/$l/x64/Microsoft.VC$crtver.CRT"; then
   371         kx                     msvcdllpath="$VC_PRODUCT_DIR/redist/MSVC/$l/x64/Microsoft.VC$crtver.CRT"
   371         kx                 fi
   371         kx             done
   371         kx         done
   371         kx         ;;
   371         kx     esac
   371         kx     AC_MSG_RESULT([$msvcdllpath])
   371         kx     AC_MSG_CHECKING([for MSVC x64 DLLs])
   371         kx     msvcdlls="msvcp140.dll vcruntime140.dll"
   371         kx     for dll in $msvcdlls; do
   371         kx         if ! test -f "$msvcdllpath/$dll"; then
   371         kx             AC_MSG_FAILURE([missing $dll])
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([found all ($msvcdlls)])
   371         kx }
   371         kx 
   371         kx dnl =========================================
   371         kx dnl Check for the Windows  SDK.
   371         kx dnl =========================================
   371         kx if test "$_os" = "WINNT"; then
   371         kx     AC_MSG_CHECKING([for Windows SDK])
   371         kx     if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx         find_winsdk
   371         kx         WINDOWS_SDK_HOME=$winsdktest
   371         kx 
   371         kx         # normalize if found
   371         kx         if test -n "$WINDOWS_SDK_HOME"; then
   371         kx             WINDOWS_SDK_HOME=`cygpath -d "$WINDOWS_SDK_HOME"`
   371         kx             WINDOWS_SDK_HOME=`cygpath -u "$WINDOWS_SDK_HOME"`
   371         kx         fi
   371         kx 
   371         kx         WINDOWS_SDK_LIB_SUBDIR=$winsdklibsubdir
   371         kx     fi
   371         kx 
   371         kx     if test -n "$WINDOWS_SDK_HOME"; then
   371         kx         # Remove a possible trailing backslash
   371         kx         WINDOWS_SDK_HOME=`echo $WINDOWS_SDK_HOME | $SED 's/\/$//'`
   371         kx 
   371         kx         if test -f "$WINDOWS_SDK_HOME/Include/adoint.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/SqlUcode.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/usp10.h"; then
   371         kx             have_windows_sdk_headers=yes
   371         kx         elif test -f "$WINDOWS_SDK_HOME/Include/um/adoint.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/um/SqlUcode.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/um/usp10.h"; then
   371         kx             have_windows_sdk_headers=yes
   371         kx         elif test -f "$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/um/adoint.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/um/SqlUcode.h" \
   371         kx              -a -f "$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/um/usp10.h"; then
   371         kx             have_windows_sdk_headers=yes
   371         kx         else
   371         kx             have_windows_sdk_headers=no
   371         kx         fi
   371         kx 
   371         kx         if test -f "$WINDOWS_SDK_HOME/lib/user32.lib"; then
   371         kx             have_windows_sdk_libs=yes
   371         kx         elif test -f "$WINDOWS_SDK_HOME/lib/$winsdklibsubdir/um/$WIN_BUILD_ARCH/user32.lib"; then
   371         kx             have_windows_sdk_libs=yes
   371         kx         else
   371         kx             have_windows_sdk_libs=no
   371         kx         fi
   371         kx 
   371         kx         if test $have_windows_sdk_headers = no -o $have_windows_sdk_libs = no; then
   371         kx             AC_MSG_ERROR([Some (all?) Windows SDK files not found, please check if all needed parts of
   371         kx the  Windows SDK are installed.])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     if test -z "$WINDOWS_SDK_HOME"; then
   371         kx         AC_MSG_RESULT([no, hoping the necessary headers and libraries will be found anyway!?])
   371         kx     elif echo $WINDOWS_SDK_HOME | grep "8.0" >/dev/null 2>/dev/null; then
   371         kx         WINDOWS_SDK_VERSION=80
   371         kx         AC_MSG_RESULT([found Windows SDK 8.0 ($WINDOWS_SDK_HOME)])
   371         kx     elif echo $WINDOWS_SDK_HOME | grep "8.1" >/dev/null 2>/dev/null; then
   371         kx         WINDOWS_SDK_VERSION=81
   371         kx         AC_MSG_RESULT([found Windows SDK 8.1 ($WINDOWS_SDK_HOME)])
   371         kx     elif echo $WINDOWS_SDK_HOME | grep "/10" >/dev/null 2>/dev/null; then
   371         kx         WINDOWS_SDK_VERSION=10
   371         kx         AC_MSG_RESULT([found Windows SDK 10.0 ($WINDOWS_SDK_HOME)])
   371         kx     else
   371         kx         AC_MSG_ERROR([Found legacy Windows Platform SDK ($WINDOWS_SDK_HOME)])
   371         kx     fi
   371         kx     PathFormat "$WINDOWS_SDK_HOME"
   371         kx     WINDOWS_SDK_HOME="$formatted_path"
   371         kx     WINDOWS_SDK_HOME_unix="$formatted_path_unix"
   371         kx     if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx         SOLARINC="$SOLARINC -I$WINDOWS_SDK_HOME/include -I$COMPATH/Include"
   371         kx         if test -d "$WINDOWS_SDK_HOME/include/um"; then
   371         kx             SOLARINC="$SOLARINC -I$WINDOWS_SDK_HOME/include/um -I$WINDOWS_SDK_HOME/include/shared"
   371         kx         elif test -d "$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/um"; then
   371         kx             SOLARINC="$SOLARINC -I$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/um -I$WINDOWS_SDK_HOME/Include/$winsdklibsubdir/shared"
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     dnl TODO: solenv/bin/modules/installer/windows/msiglobal.pm wants to use a
   371         kx     dnl WiLangId.vbs that is included only in some SDKs (e.g., included in v7.1
   371         kx     dnl but not in v8.0), so allow this to be overridden with a
   371         kx     dnl WINDOWS_SDK_WILANGID for now; a full-blown --with-windows-sdk-wilangid
   371         kx     dnl and configuration error if no WiLangId.vbs is found would arguably be
   371         kx     dnl better, but I do not know under which conditions exactly it is needed by
   371         kx     dnl msiglobal.pm:
   371         kx     if test -z "$WINDOWS_SDK_WILANGID" -a -n "$WINDOWS_SDK_HOME"; then
   371         kx         WINDOWS_SDK_WILANGID=$WINDOWS_SDK_HOME/Samples/sysmgmt/msi/scripts/WiLangId.vbs
   371         kx         WINDOWS_SDK_WILANGID_unix=$(cygpath -u "$WINDOWS_SDK_WILANGID")
   371         kx         if ! test -e "$WINDOWS_SDK_WILANGID_unix" ; then
   371         kx             WINDOWS_SDK_WILANGID="${WINDOWS_SDK_HOME}/bin/${WINDOWS_SDK_LIB_SUBDIR}/${WIN_BUILD_ARCH}/WiLangId.vbs"
   371         kx             WINDOWS_SDK_WILANGID_unix=$(cygpath -u "$WINDOWS_SDK_WILANGID")
   371         kx         fi
   371         kx         if ! test -e "$WINDOWS_SDK_WILANGID_unix" ; then
   371         kx             WINDOWS_SDK_WILANGID=$WINDOWS_SDK_HOME/bin/$WIN_BUILD_ARCH/WiLangId.vbs
   371         kx             WINDOWS_SDK_WILANGID_unix=$(cygpath -u "$WINDOWS_SDK_WILANGID")
   371         kx         fi
   371         kx         if ! test -e "$WINDOWS_SDK_WILANGID_unix" ; then
   371         kx             WINDOWS_SDK_WILANGID=$(cygpath -sm "C:/Program Files (x86)/Windows Kits/8.1/bin/$WIN_BUILD_ARCH/WiLangId.vbs")
   371         kx             WINDOWS_SDK_WILANGID_unix=$(cygpath -u "$WINDOWS_SDK_WILANGID")
   371         kx         fi
   371         kx     fi
   371         kx     if test -n "$with_lang" -a "$with_lang" != "en-US"; then
   371         kx         if test -n "$with_package_format" -a "$with_package_format" != no; then
   371         kx             for i in "$with_package_format"; do
   371         kx                 if test "$i" = "msi"; then
   371         kx                     if ! test -e "$WINDOWS_SDK_WILANGID_unix" ; then
   371         kx                         AC_MSG_ERROR([WiLangId.vbs not found - building translated packages will fail])
   371         kx                     fi
   371         kx                 fi
   371         kx             done
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(WINDOWS_SDK_HOME)
   371         kx AC_SUBST(WINDOWS_SDK_LIB_SUBDIR)
   371         kx AC_SUBST(WINDOWS_SDK_VERSION)
   371         kx AC_SUBST(WINDOWS_SDK_WILANGID)
   371         kx 
   371         kx if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx     dnl Check midl.exe; this being the first check for a tool in the SDK bin
   371         kx     dnl dir, it also determines that dir's path w/o an arch segment if any,
   371         kx     dnl WINDOWS_SDK_BINDIR_NO_ARCH:
   371         kx     AC_MSG_CHECKING([for midl.exe])
   371         kx 
   371         kx     find_winsdk
   371         kx     PathFormat "$winsdktest"
   371         kx     winsdktest_unix="$formatted_path_unix"
   371         kx 
   371         kx     if test -n "$winsdkbinsubdir" \
   371         kx         -a -f "$winsdktest_unix/Bin/$winsdkbinsubdir/$WIN_BUILD_ARCH/midl.exe"
   371         kx     then
   371         kx         MIDL_PATH=$winsdktest/Bin/$winsdkbinsubdir/$WIN_BUILD_ARCH
   371         kx         WINDOWS_SDK_BINDIR_NO_ARCH=$WINDOWS_SDK_HOME_unix/Bin/$winsdkbinsubdir
   371         kx     elif test -f "$winsdktest_unix/Bin/$WIN_BUILD_ARCH/midl.exe"; then
   371         kx         MIDL_PATH=$winsdktest/Bin/$WIN_BUILD_ARCH
   371         kx         WINDOWS_SDK_BINDIR_NO_ARCH=$WINDOWS_SDK_HOME_unix/Bin
   371         kx     elif test -f "$winsdktest_unix/Bin/midl.exe"; then
   371         kx         MIDL_PATH=$winsdktest/Bin
   371         kx         WINDOWS_SDK_BINDIR_NO_ARCH=$WINDOWS_SDK_HOME_unix/Bin
   371         kx     fi
   371         kx     PathFormat "$MIDL_PATH"
   371         kx     if test ! -f "$formatted_path_unix/midl.exe"; then
   371         kx         AC_MSG_ERROR([midl.exe not found in $winsdktest/Bin/$WIN_BUILD_ARCH, Windows SDK installation broken?])
   371         kx     else
   371         kx         AC_MSG_RESULT([$MIDL_PATH/midl.exe])
   371         kx     fi
   371         kx 
   371         kx     # Convert to posix path with 8.3 filename restrictions ( No spaces )
   371         kx     MIDL_PATH=`win_short_path_for_make "$MIDL_PATH"`
   371         kx 
   371         kx     if test -f "$WINDOWS_SDK_BINDIR_NO_ARCH/msiinfo.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/msidb.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/uuidgen.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/msitran.exe"; then :
   371         kx     elif test -f "$WINDOWS_SDK_BINDIR_NO_ARCH/x86/msiinfo.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/x86/msidb.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/x86/uuidgen.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/x86/msitran.exe"; then :
   371         kx     elif test -f "$WINDOWS_SDK_HOME/bin/x86/msiinfo.exe" \
   371         kx          -a -f "$WINDOWS_SDK_HOME/bin/x86/msidb.exe" \
   371         kx          -a -f "$WINDOWS_SDK_BINDIR_NO_ARCH/x86/uuidgen.exe" \
   371         kx          -a -f "$WINDOWS_SDK_HOME/bin/x86/msitran.exe"; then :
   371         kx     else
   371         kx         AC_MSG_ERROR([Some (all?) Windows Installer tools in the Windows SDK are missing, please install.])
   371         kx     fi
   371         kx 
   371         kx     dnl Check csc.exe
   371         kx     AC_MSG_CHECKING([for csc.exe])
   371         kx     find_csc
   371         kx     PathFormat "$csctest"
   371         kx     csctest_unix="$formatted_path_unix"
   371         kx     if test -f "$csctest_unix/csc.exe"; then
   371         kx         CSC_PATH="$csctest"
   371         kx     fi
   371         kx     if test ! -f "$csctest_unix/csc.exe"; then
   371         kx         AC_MSG_ERROR([csc.exe not found as $CSC_PATH/csc.exe])
   371         kx     else
   371         kx         AC_MSG_RESULT([$CSC_PATH/csc.exe])
   371         kx     fi
   371         kx 
   371         kx     CSC_PATH=`win_short_path_for_make "$CSC_PATH"`
   371         kx 
   371         kx     dnl Check al.exe
   371         kx     AC_MSG_CHECKING([for al.exe])
   371         kx     if test -n "$winsdkbinsubdir" \
   371         kx         -a -f "$winsdktest_unix/Bin/$winsdkbinsubdir/$WIN_BUILD_ARCH/al.exe"
   371         kx     then
   371         kx         AL_PATH="$winsdktest/Bin/$winsdkbinsubdir/$WIN_BUILD_ARCH"
   371         kx     elif test -f "$winsdktest_unix/Bin/$WIN_BUILD_ARCH/al.exe"; then
   371         kx         AL_PATH="$winsdktest/Bin/$WIN_BUILD_ARCH"
   371         kx     elif test -f "$winsdktest_unix/Bin/al.exe"; then
   371         kx         AL_PATH="$winsdktest/Bin"
   371         kx     fi
   371         kx 
   371         kx     if test -z "$AL_PATH"; then
   371         kx         find_al
   371         kx         PathFormat "$altest"
   371         kx         altest_unix="$formatted_path_unix"
   371         kx         if test -f "$altest_unix/bin/al.exe"; then
   371         kx             AL_PATH="$altest/bin"
   371         kx         elif test -f "$altest_unix/al.exe"; then
   371         kx             AL_PATH="$altest"
   371         kx         fi
   371         kx     fi
   371         kx     PathFormat "$AL_PATH"
   371         kx     if test ! -f "$formatted_path_unix/al.exe"; then
   371         kx         AC_MSG_ERROR([al.exe not found as $AL_PATH/al.exe])
   371         kx     else
   371         kx         AC_MSG_RESULT([$AL_PATH/al.exe])
   371         kx     fi
   371         kx 
   371         kx     AL_PATH=`win_short_path_for_make "$AL_PATH"`
   371         kx 
   371         kx     dnl Check mscoree.lib / .NET Framework dir
   371         kx     AC_MSG_CHECKING(.NET Framework)
   371         kx     find_dotnetsdk
   371         kx     PathFormat "$frametest"
   371         kx     frametest="$formatted_path_unix"
   371         kx     if test -f "$frametest/Lib/um/$WIN_BUILD_ARCH/mscoree.lib"; then
   371         kx         DOTNET_FRAMEWORK_HOME="$frametest"
   371         kx     else
   371         kx         if test -f "$winsdktest_unix/lib/mscoree.lib" -o -f "$winsdktest_unix/lib/$winsdklibsubdir/um/$WIN_BUILD_ARCH/mscoree.lib"; then
   371         kx             DOTNET_FRAMEWORK_HOME="$winsdktest"
   371         kx         fi
   371         kx     fi
   371         kx     PathFormat "$DOTNET_FRAMEWORK_HOME"
   371         kx     if test ! -f "$formatted_path_unix/lib/mscoree.lib" -a ! -f "$formatted_path_unix/lib/$winsdklibsubdir/um/$WIN_BUILD_ARCH/mscoree.lib" -a ! -f "$formatted_path_unix/Lib/um/$WIN_BUILD_ARCH/mscoree.lib"; then
   371         kx         AC_MSG_ERROR([mscoree.lib not found])
   371         kx     fi
   371         kx     AC_MSG_RESULT([found: $DOTNET_FRAMEWORK_HOME])
   371         kx 
   371         kx     PathFormat "$MIDL_PATH"
   371         kx     MIDL_PATH="$formatted_path"
   371         kx 
   371         kx     PathFormat "$AL_PATH"
   371         kx     AL_PATH="$formatted_path"
   371         kx 
   371         kx     PathFormat "$DOTNET_FRAMEWORK_HOME"
   371         kx     DOTNET_FRAMEWORK_HOME="$formatted_path"
   371         kx 
   371         kx     PathFormat "$CSC_PATH"
   371         kx     CSC_PATH="$formatted_path"
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Testing for C++ compiler and version...
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$_os" != "WINNT"; then
   371         kx     # AC_PROG_CXX sets CXXFLAGS to -g -O2 if not set, avoid that
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     AC_PROG_CXX
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     if test -z "$CXX_BASE"; then
   371         kx         CXX_BASE=`first_arg_basename "$CXX"`
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl check for GNU C++ compiler version
   371         kx if test "$GXX" = "yes" -a -z "$COM_IS_CLANG"; then
   371         kx     AC_MSG_CHECKING([the GNU C++ compiler version])
   371         kx 
   371         kx     _gpp_version=`$CXX -dumpversion`
   371         kx     _gpp_majmin=`echo $_gpp_version | $AWK -F. '{ print \$1*100+\$2 }'`
   371         kx 
   371         kx     if test "$_gpp_majmin" -lt "700"; then
   371         kx         AC_MSG_ERROR([You need to use GNU C++ compiler version >= 7.0 to build LibreOffice, you have $_gpp_version.])
   371         kx     else
   371         kx         AC_MSG_RESULT([ok (g++ $_gpp_version)])
   371         kx     fi
   371         kx 
   371         kx     dnl see https://issuetracker.google.com/issues/36962819
   371         kx         glibcxx_threads=no
   371         kx         AC_LANG_PUSH([C++])
   371         kx         AC_REQUIRE_CPP
   371         kx         AC_MSG_CHECKING([whether $CXX_BASE is broken with boost.thread])
   371         kx         AC_PREPROC_IFELSE([AC_LANG_PROGRAM([[
   371         kx             #include <bits/c++config.h>]],[[
   371         kx             #if !defined(_GLIBCXX_HAVE_GTHR_DEFAULT) \
   371         kx             && !defined(_GLIBCXX__PTHREADS) \
   371         kx             && !defined(_GLIBCXX_HAS_GTHREADS)
   371         kx             choke me
   371         kx             #endif
   371         kx         ]])],[AC_MSG_RESULT([yes])
   371         kx         glibcxx_threads=yes],[AC_MSG_RESULT([no])])
   371         kx         AC_LANG_POP([C++])
   371         kx         if test $glibcxx_threads = yes; then
   371         kx             BOOST_CXXFLAGS="-D_GLIBCXX_HAS_GTHREADS"
   371         kx         fi
   371         kx fi
   371         kx AC_SUBST(BOOST_CXXFLAGS)
   371         kx 
   371         kx #
   371         kx # prefx CXX with ccache if needed
   371         kx #
   371         kx if test "$CCACHE" != ""; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE is already ccached])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS --ccache-skip -O2"
   371         kx     # msvc does not fail on unknown options, check stdout
   371         kx     if test "$COM" = MSC; then
   371         kx         CXXFLAGS="$CXXFLAGS -nologo"
   371         kx     fi
   371         kx     save_ac_cxx_werror_flag=$ac_cxx_werror_flag
   371         kx     ac_cxx_werror_flag=yes
   371         kx     dnl an empty program will do, we're checking the compiler flags
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[])],
   371         kx                       [use_ccache=yes], [use_ccache=no])
   371         kx     if test $use_ccache = yes -a "${CCACHE/*sccache*/}" != ""; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         CXX="$CCACHE $CXX"
   371         kx         CXX_BASE="ccache $CXX_BASE"
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     ac_cxx_werror_flag=$save_ac_cxx_werror_flag
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Find pre-processors.(should do that _after_ messing with CC/CXX)
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$_os" != "WINNT"; then
   371         kx     AC_PROG_CXXCPP
   371         kx 
   371         kx     dnl Check whether there's a C pre-processor.
   371         kx     AC_PROG_CPP
   371         kx fi
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Find integral type sizes and alignments
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$_os" != "WINNT"; then
   371         kx 
   371         kx     AC_CHECK_SIZEOF(long)
   371         kx     AC_CHECK_SIZEOF(short)
   371         kx     AC_CHECK_SIZEOF(int)
   371         kx     AC_CHECK_SIZEOF(long long)
   371         kx     AC_CHECK_SIZEOF(double)
   371         kx     AC_CHECK_SIZEOF(void*)
   371         kx     AC_CHECK_SIZEOF(size_t)
   371         kx 
   371         kx     SAL_TYPES_SIZEOFSHORT=$ac_cv_sizeof_short
   371         kx     SAL_TYPES_SIZEOFINT=$ac_cv_sizeof_int
   371         kx     SAL_TYPES_SIZEOFLONG=$ac_cv_sizeof_long
   371         kx     SAL_TYPES_SIZEOFLONGLONG=$ac_cv_sizeof_long_long
   371         kx     SAL_TYPES_SIZEOFPOINTER=$ac_cv_sizeof_voidp
   371         kx     SIZEOF_SIZE_T=$ac_cv_sizeof_size_t
   371         kx 
   371         kx     dnl Allow build without AC_CHECK_ALIGNOF, grrr
   371         kx     m4_pattern_allow([AC_CHECK_ALIGNOF])
   371         kx     m4_ifdef([AC_CHECK_ALIGNOF],
   371         kx         [
   371         kx             AC_CHECK_ALIGNOF(short,[#include <stddef.h>])
   371         kx             AC_CHECK_ALIGNOF(int,[#include <stddef.h>])
   371         kx             AC_CHECK_ALIGNOF(long,[#include <stddef.h>])
   371         kx             AC_CHECK_ALIGNOF(double,[#include <stddef.h>])
   371         kx         ],
   371         kx         [
   371         kx             case "$_os-$host_cpu" in
   371         kx             Linux-i686)
   371         kx                 test -z "$ac_cv_alignof_short" && ac_cv_alignof_short=2
   371         kx                 test -z "$ac_cv_alignof_int" && ac_cv_alignof_int=4
   371         kx                 test -z "$ac_cv_alignof_long" && ac_cv_alignof_long=4
   371         kx                 test -z "$ac_cv_alignof_double" && ac_cv_alignof_double=4
   371         kx                 ;;
   371         kx             Linux-x86_64)
   371         kx                 test -z "$ac_cv_alignof_short" && ac_cv_alignof_short=2
   371         kx                 test -z "$ac_cv_alignof_int" && ac_cv_alignof_int=4
   371         kx                 test -z "$ac_cv_alignof_long" && ac_cv_alignof_long=8
   371         kx                 test -z "$ac_cv_alignof_double" && ac_cv_alignof_double=8
   371         kx                 ;;
   371         kx             *)
   371         kx                 if test -z "$ac_cv_alignof_short" -o \
   371         kx                         -z "$ac_cv_alignof_int" -o \
   371         kx                         -z "$ac_cv_alignof_long" -o \
   371         kx                         -z "$ac_cv_alignof_double"; then
   371         kx                    AC_MSG_ERROR([Your Autoconf doesn't have [AC_][CHECK_ALIGNOF]. You need to set the environment variables ac_cv_alignof_short, ac_cv_alignof_int, ac_cv_alignof_long and ac_cv_alignof_double.])
   371         kx                 fi
   371         kx                 ;;
   371         kx             esac
   371         kx         ])
   371         kx 
   371         kx     SAL_TYPES_ALIGNMENT2=$ac_cv_alignof_short
   371         kx     SAL_TYPES_ALIGNMENT4=$ac_cv_alignof_int
   371         kx     if test $ac_cv_sizeof_long -eq 8; then
   371         kx         SAL_TYPES_ALIGNMENT8=$ac_cv_alignof_long
   371         kx     elif test $ac_cv_sizeof_double -eq 8; then
   371         kx         SAL_TYPES_ALIGNMENT8=$ac_cv_alignof_double
   371         kx     else
   371         kx         AC_MSG_ERROR([Cannot find alignment of 8 byte types.])
   371         kx     fi
   371         kx 
   371         kx     dnl Check for large file support
   371         kx     AC_SYS_LARGEFILE
   371         kx     if test -n "$ac_cv_sys_file_offset_bits" -a "$ac_cv_sys_file_offset_bits" != "no"; then
   371         kx         LFS_CFLAGS="-D_FILE_OFFSET_BITS=$ac_cv_sys_file_offset_bits"
   371         kx     fi
   371         kx     if test -n "$ac_cv_sys_large_files" -a "$ac_cv_sys_large_files" != "no"; then
   371         kx         LFS_CFLAGS="$LFS_CFLAGS -D_LARGE_FILES"
   371         kx     fi
   371         kx else
   371         kx     # Hardcode for MSVC
   371         kx     SAL_TYPES_SIZEOFSHORT=2
   371         kx     SAL_TYPES_SIZEOFINT=4
   371         kx     SAL_TYPES_SIZEOFLONG=4
   371         kx     SAL_TYPES_SIZEOFLONGLONG=8
   371         kx     if test $WIN_HOST_BITS -eq 32; then
   371         kx         SAL_TYPES_SIZEOFPOINTER=4
   371         kx         SIZEOF_SIZE_T=4
   371         kx     else
   371         kx         SAL_TYPES_SIZEOFPOINTER=8
   371         kx         SIZEOF_SIZE_T=8
   371         kx     fi
   371         kx     SAL_TYPES_ALIGNMENT2=2
   371         kx     SAL_TYPES_ALIGNMENT4=4
   371         kx     SAL_TYPES_ALIGNMENT8=8
   371         kx     LFS_CFLAGS=''
   371         kx fi
   371         kx AC_SUBST(LFS_CFLAGS)
   371         kx AC_SUBST(SIZEOF_SIZE_T)
   371         kx 
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_SIZEOFSHORT,$SAL_TYPES_SIZEOFSHORT)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_SIZEOFINT,$SAL_TYPES_SIZEOFINT)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_SIZEOFLONG,$SAL_TYPES_SIZEOFLONG)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_SIZEOFLONGLONG,$SAL_TYPES_SIZEOFLONGLONG)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_SIZEOFPOINTER,$SAL_TYPES_SIZEOFPOINTER)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_ALIGNMENT2,$SAL_TYPES_ALIGNMENT2)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_ALIGNMENT4,$SAL_TYPES_ALIGNMENT4)
   371         kx AC_DEFINE_UNQUOTED(SAL_TYPES_ALIGNMENT8,$SAL_TYPES_ALIGNMENT8)
   371         kx 
   371         kx dnl Calc jumbo sheets (1m+ rows) depend on 64 bit tools::Long .
   371         kx AC_MSG_CHECKING([whether jumbo sheets are supported])
   371         kx if test "$_os" != "WINNT"; then
   371         kx     if test $SAL_TYPES_SIZEOFLONG -gt 4; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         ENABLE_JUMBO_SHEETS=TRUE
   371         kx         AC_DEFINE(HAVE_FEATURE_JUMBO_SHEETS)
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx else
   371         kx     if test $WIN_HOST_BITS -gt 32; then
   371         kx         # 64bit windows is special-cased for tools::Long because long is 32bit
   371         kx         AC_MSG_RESULT([yes])
   371         kx         ENABLE_JUMBO_SHEETS=TRUE
   371         kx         AC_DEFINE(HAVE_FEATURE_JUMBO_SHEETS)
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_JUMBO_SHEETS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check whether to enable runtime optimizations
   371         kx dnl ===================================================================
   371         kx ENABLE_RUNTIME_OPTIMIZATIONS=
   371         kx AC_MSG_CHECKING([whether to enable runtime optimizations])
   371         kx if test -z "$enable_runtime_optimizations"; then
   371         kx     for i in $CC; do
   371         kx         case $i in
   371         kx         -fsanitize=*)
   371         kx             enable_runtime_optimizations=no
   371         kx             break
   371         kx             ;;
   371         kx         esac
   371         kx     done
   371         kx fi
   371         kx if test "$enable_runtime_optimizations" != no; then
   371         kx     ENABLE_RUNTIME_OPTIMIZATIONS=TRUE
   371         kx     AC_DEFINE(ENABLE_RUNTIME_OPTIMIZATIONS)
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST([ENABLE_RUNTIME_OPTIMIZATIONS])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check if valgrind headers are available
   371         kx dnl ===================================================================
   371         kx ENABLE_VALGRIND=
   371         kx if test "$cross_compiling" != yes -a "$with_valgrind" != no; then
   371         kx     prev_cppflags=$CPPFLAGS
   371         kx     # Is VALGRIND_CFLAGS something one is supposed to have in the environment,
   371         kx     # or where does it come from?
   371         kx     CPPFLAGS="$CPPFLAGS $VALGRIND_CFLAGS"
   371         kx     AC_CHECK_HEADER([valgrind/valgrind.h],
   371         kx         [ENABLE_VALGRIND=TRUE])
   371         kx     CPPFLAGS=$prev_cppflags
   371         kx fi
   371         kx AC_SUBST([ENABLE_VALGRIND])
   371         kx if test -z "$ENABLE_VALGRIND"; then
   371         kx     if test "$with_valgrind" = yes; then
   371         kx         AC_MSG_ERROR([--with-valgrind specified but no Valgrind headers found])
   371         kx     fi
   371         kx     VALGRIND_CFLAGS=
   371         kx fi
   371         kx AC_SUBST([VALGRIND_CFLAGS])
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check if SDT probes (for systemtap, gdb, dtrace) are available
   371         kx dnl ===================================================================
   371         kx 
   371         kx # We need at least the sys/sdt.h include header.
   371         kx AC_CHECK_HEADER([sys/sdt.h], [SDT_H_FOUND='TRUE'], [SDT_H_FOUND='FALSE'])
   371         kx if test "$SDT_H_FOUND" = "TRUE"; then
   371         kx     # Found sys/sdt.h header, now make sure the c++ compiler works.
   371         kx     # Old g++ versions had problems with probes in constructors/destructors.
   371         kx     AC_MSG_CHECKING([working sys/sdt.h and c++ support])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([[
   371         kx     #include <sys/sdt.h>
   371         kx     class ProbeClass
   371         kx     {
   371         kx     private:
   371         kx       int& ref;
   371         kx       const char *name;
   371         kx 
   371         kx     public:
   371         kx       ProbeClass(int& v, const char *n) : ref(v), name(n)
   371         kx       {
   371         kx         DTRACE_PROBE2(_test_, cons, name, ref);
   371         kx       }
   371         kx 
   371         kx       void method(int min)
   371         kx       {
   371         kx         DTRACE_PROBE3(_test_, meth, name, ref, min);
   371         kx         ref -= min;
   371         kx       }
   371         kx 
   371         kx       ~ProbeClass()
   371         kx       {
   371         kx         DTRACE_PROBE2(_test_, dest, name, ref);
   371         kx       }
   371         kx     };
   371         kx     ]],[[
   371         kx     int i = 64;
   371         kx     DTRACE_PROBE1(_test_, call, i);
   371         kx     ProbeClass inst = ProbeClass(i, "call");
   371         kx     inst.method(24);
   371         kx     ]])], [AC_MSG_RESULT([yes]); AC_DEFINE([USE_SDT_PROBES])],
   371         kx           [AC_MSG_RESULT([no, sdt.h or c++ compiler too old])])
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_CONFIG_HEADERS([config_host/config_probes.h])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl GCC features
   371         kx dnl ===================================================================
   371         kx HAVE_GCC_STACK_CLASH_PROTECTION=
   371         kx if test "$GCC" = "yes" -o "$COM_IS_CLANG" = TRUE; then
   371         kx     AC_MSG_CHECKING([whether $CC_BASE supports -fstack-clash-protection])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror -fstack-clash-protection"
   371         kx     AC_LINK_IFELSE(
   371         kx         [AC_LANG_PROGRAM(, [[return 0;]])],
   371         kx         [AC_MSG_RESULT([yes]); HAVE_GCC_STACK_CLASH_PROTECTION=TRUE],
   371         kx         [AC_MSG_RESULT([no])])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CC_BASE supports -mno-avx])
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS -Werror -mno-avx"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_GCC_AVX=TRUE ],[])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     if test "$HAVE_GCC_AVX" = "TRUE"; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CC_BASE supports atomic functions])
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[
   371         kx     int v = 0;
   371         kx     if (__sync_add_and_fetch(&v, 1) != 1 ||
   371         kx         __sync_sub_and_fetch(&v, 1) != 0)
   371         kx         return 1;
   371         kx     __sync_synchronize();
   371         kx     if (__sync_val_compare_and_swap(&v, 0, 1) != 0 ||
   371         kx         v != 1)
   371         kx         return 1;
   371         kx     return 0;
   371         kx ]])],[HAVE_GCC_BUILTIN_ATOMIC=TRUE],[])
   371         kx     if test "$HAVE_GCC_BUILTIN_ATOMIC" = "TRUE"; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         AC_DEFINE(HAVE_GCC_BUILTIN_ATOMIC)
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __base_class_type_info in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__base_class_type_info); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_BASE_CLASS_TYPE_INFO],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __class_type_info in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__class_type_info); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CLASS_TYPE_INFO],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE declares __cxa_allocate_exception in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cxxabi.h>
   371         kx             void * f() { return __cxxabiv1::__cxa_allocate_exception(0); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_ALLOCATE_EXCEPTION],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __cxa_eh_globals in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__cxa_eh_globals); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_EH_GLOBALS],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __cxa_exception in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__cxa_exception); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_EXCEPTION],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE declares __cxa_get_globals in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cxxabi.h>
   371         kx             void * f() { return __cxxabiv1::__cxa_get_globals(); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_GET_GLOBALS],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE declares __cxa_current_exception_type in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cxxabi.h>
   371         kx             void * f() { return __cxxabiv1::__cxa_current_exception_type(); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_CURRENT_EXCEPTION_TYPE],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE declares __cxa_throw in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cxxabi.h>
   371         kx             void f() { __cxxabiv1::__cxa_throw(0, 0, 0); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_CXA_THROW],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __si_class_type_info in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__si_class_type_info); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_SI_CLASS_TYPE_INFO],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE defines __vmi_class_type_info in cxxabi.h])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <cstddef>
   371         kx             #include <cxxabi.h>
   371         kx             std::size_t f() { return sizeof(__cxxabiv1::__vmi_class_type_info); }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_CXXABI_H_VMI_CLASS_TYPE_INFO],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(HAVE_GCC_AVX)
   371         kx AC_SUBST(HAVE_GCC_BUILTIN_ATOMIC)
   371         kx AC_SUBST(HAVE_GCC_STACK_CLASH_PROTECTION)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Identify the C++ library
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([what the C++ library is])
   371         kx HAVE_LIBSTDCPP=
   371         kx HAVE_LIBCPP=
   371         kx AC_LANG_PUSH([C++])
   371         kx AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx #include <utility>
   371         kx #ifndef __GLIBCXX__
   371         kx foo bar
   371         kx #endif
   371         kx ]])],
   371         kx     [CPP_LIBRARY=GLIBCXX
   371         kx      cpp_library_name="GNU libstdc++"
   371         kx      HAVE_LIBSTDCPP=TRUE
   371         kx     ],
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx #include <utility>
   371         kx #ifndef _LIBCPP_VERSION
   371         kx foo bar
   371         kx #endif
   371         kx ]])],
   371         kx     [CPP_LIBRARY=LIBCPP
   371         kx      cpp_library_name="LLVM libc++"
   371         kx      AC_DEFINE([HAVE_LIBCPP])
   371         kx      HAVE_LIBCPP=TRUE
   371         kx     ],
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx #include <utility>
   371         kx #ifndef _MSC_VER
   371         kx foo bar
   371         kx #endif
   371         kx ]])],
   371         kx     [CPP_LIBRARY=MSVCRT
   371         kx      cpp_library_name="Microsoft"
   371         kx     ],
   371         kx     AC_MSG_ERROR([Could not figure out what C++ library this is]))))
   371         kx AC_MSG_RESULT([$cpp_library_name])
   371         kx AC_LANG_POP([C++])
   371         kx AC_SUBST([HAVE_LIBSTDCPP])
   371         kx AC_SUBST([HAVE_LIBCPP])
   371         kx 
   371         kx if test -z "${LIBCPP_DEBUG+x}" -a -z "$CROSS_COMPILING" -a -n "$HAVE_LIBCPP" -a -n "$ENABLE_DBGUTIL"
   371         kx then
   371         kx     # Libc++ has two levels of debug mode, assertions mode enabled with -D_LIBCPP_DEBUG=0,
   371         kx     # and actual debug mode enabled with -D_LIBCPP_DEBUG=1 (and starting with LLVM15
   371         kx     # assertions mode will be separate and controlled by -D_LIBCPP_ENABLE_ASSERTIONS=1,
   371         kx     # although there will be backwards compatibility).
   371         kx     # Debug mode is supported by libc++ only if built for it, e.g. Mac libc++ isn't,
   371         kx     # and there would be undefined references to debug functions.
   371         kx     # Moreover std::to_string() has a bug (https://reviews.llvm.org/D125184).
   371         kx     # So check if debug mode can be used and disable or downgrade it to assertions
   371         kx     # if needed.
   371         kx     AC_MSG_CHECKING([if libc++ has a usable debug mode])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     libcpp_debug_links=
   371         kx     AC_LINK_IFELSE([AC_LANG_SOURCE([[
   371         kx #define _LIBCPP_DEBUG 0 // only assertions
   371         kx #include <vector>
   371         kx int main()
   371         kx {
   371         kx     std::vector<int> v;
   371         kx     v.push_back( 1 );
   371         kx     return v[ 3 ];
   371         kx }
   371         kx ]])], [libcpp_debug_links=1])
   371         kx     if test -n "$libcpp_debug_links"; then
   371         kx         # we can use at least assertions, check if debug mode works
   371         kx         AC_RUN_IFELSE([AC_LANG_SOURCE([[
   371         kx #define _LIBCPP_DEBUG 1 // debug mode
   371         kx #include <string>
   371         kx #include <vector>
   371         kx int foo(const std::vector<int>& v) { return *v.begin(); }
   371         kx int main()
   371         kx {
   371         kx     std::vector<int> v;
   371         kx     v.push_back( 1 );
   371         kx     std::string s = "xxxxxxxxxxxxxxxxxxxxxxxxx" + std::to_string(10);
   371         kx     return (foo(v) + s.size()) != 0 ? 0 : 1;
   371         kx }
   371         kx ]])],
   371         kx         [AC_MSG_RESULT(yes)
   371         kx          LIBCPP_DEBUG=-D_LIBCPP_DEBUG=1
   371         kx         ],
   371         kx         [AC_MSG_RESULT(no, using only assertions)
   371         kx          LIBCPP_DEBUG=-D_LIBCPP_DEBUG=0
   371         kx         ]
   371         kx         )
   371         kx     else
   371         kx         AC_MSG_RESULT(no)
   371         kx     fi
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST([LIBCPP_DEBUG])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for gperf
   371         kx dnl ===================================================================
   371         kx AC_PATH_PROG(GPERF, gperf)
   371         kx if test -z "$GPERF"; then
   371         kx     AC_MSG_ERROR([gperf not found but needed. Install it.])
   371         kx fi
   371         kx if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx     GPERF=`cygpath -m $GPERF`
   371         kx fi
   371         kx AC_MSG_CHECKING([whether gperf is new enough])
   371         kx my_gperf_ver1=$($GPERF --version | head -n 1)
   371         kx my_gperf_ver2=${my_gperf_ver1#GNU gperf }
   371         kx my_gperf_ver3=$(printf %s "$my_gperf_ver2" | $AWK -F. '{ print $1*100+($2<100?$2:99) }')
   371         kx if test "$my_gperf_ver3" -ge 301; then
   371         kx     AC_MSG_RESULT([yes ($my_gperf_ver2)])
   371         kx else
   371         kx     AC_MSG_ERROR(["$my_gperf_ver1" is too old or unrecognized, must be at least gperf 3.1])
   371         kx fi
   371         kx AC_SUBST(GPERF)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system libcmis
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([libcmis],[LIBCMIS],[libcmis-0.6 >= 0.6.1],enabled)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl C++11
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test -z "${CXXFLAGS_CXX11+x}"; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE supports C++20])
   371         kx     if test "$COM" = MSC -a "$COM_IS_CLANG" != TRUE; then
   371         kx         if test "$with_latest_c__" = yes; then
   371         kx             CXXFLAGS_CXX11=-std:c++latest
   371         kx         else
   371         kx             CXXFLAGS_CXX11=-std:c++20
   371         kx         fi
   371         kx         CXXFLAGS_CXX11="$CXXFLAGS_CXX11 -permissive- -Zc:__cplusplus,preprocessor"
   371         kx     elif test "$GCC" = "yes" -o "$COM_IS_CLANG" = TRUE; then
   371         kx         my_flags='-std=c++20 -std=c++2a'
   371         kx         if test "$with_latest_c__" = yes; then
   371         kx             my_flags="-std=c++26 -std=c++2c -std=c++23 -std=c++2b $my_flags"
   371         kx         fi
   371         kx         for flag in $my_flags; do
   371         kx             if test "$COM" = MSC; then
   371         kx                 flag="-Xclang $flag"
   371         kx             fi
   371         kx             save_CXXFLAGS=$CXXFLAGS
   371         kx             CXXFLAGS="$CXXFLAGS $flag -Werror"
   371         kx             AC_LANG_PUSH([C++])
   371         kx             AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx                 #include <algorithm>
   371         kx                 #include <functional>
   371         kx                 #include <vector>
   371         kx 
   371         kx                 void f(std::vector<int> & v, std::function<bool(int, int)> fn) {
   371         kx                     std::sort(v.begin(), v.end(), fn);
   371         kx                 }
   371         kx                 ]])],[CXXFLAGS_CXX11=$flag])
   371         kx             AC_LANG_POP([C++])
   371         kx             CXXFLAGS=$save_CXXFLAGS
   371         kx             if test -n "$CXXFLAGS_CXX11"; then
   371         kx                 break
   371         kx             fi
   371         kx         done
   371         kx     fi
   371         kx     if test -n "$CXXFLAGS_CXX11"; then
   371         kx         AC_MSG_RESULT([yes ($CXXFLAGS_CXX11)])
   371         kx     else
   371         kx         AC_MSG_ERROR(no)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(CXXFLAGS_CXX11)
   371         kx 
   371         kx if test "$GCC" = "yes"; then
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx     CHECK_L_ATOMIC
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_SUBST(ATOMIC_LIB)
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX_BASE supports C++11 without Language Defect 757])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx AC_LANG_PUSH([C++])
   371         kx 
   371         kx AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx #include <stddef.h>
   371         kx 
   371         kx template <typename T, size_t S> char (&sal_n_array_size( T(&)[S] ))[S];
   371         kx 
   371         kx namespace
   371         kx {
   371         kx         struct b
   371         kx         {
   371         kx                 int i;
   371         kx                 int j;
   371         kx         };
   371         kx }
   371         kx ]], [[
   371         kx struct a
   371         kx {
   371         kx         int i;
   371         kx         int j;
   371         kx };
   371         kx a thinga[]={{0,0}, {1,1}};
   371         kx b thingb[]={{0,0}, {1,1}};
   371         kx size_t i = sizeof(sal_n_array_size(thinga));
   371         kx size_t j = sizeof(sal_n_array_size(thingb));
   371         kx return !(i != 0 && j != 0);
   371         kx ]])
   371         kx     ], [ AC_MSG_RESULT(yes) ],
   371         kx     [ AC_MSG_ERROR(no)])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx 
   371         kx HAVE_GCC_FNO_SIZED_DEALLOCATION=
   371         kx if test "$GCC" = yes; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE supports -fno-sized-deallocation])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS -fno-sized-deallocation"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM()],[HAVE_GCC_FNO_SIZED_DEALLOCATION=TRUE])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx     if test "$HAVE_GCC_FNO_SIZED_DEALLOCATION" = TRUE; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([HAVE_GCC_FNO_SIZED_DEALLOCATION])
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX_BASE supports C++2a constinit sorted vectors])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx         #include <algorithm>
   371         kx         #include <initializer_list>
   371         kx         #include <vector>
   371         kx         template<typename T> class S {
   371         kx         private:
   371         kx             std::vector<T> v_;
   371         kx         public:
   371         kx             constexpr S(std::initializer_list<T> i): v_(i) { std::sort(v_.begin(), v_.end()); }
   371         kx         };
   371         kx         constinit S<int> s{3, 2, 1};
   371         kx     ])], [
   371         kx         AC_DEFINE([HAVE_CPP_CONSTINIT_SORTED_VECTOR],[1])
   371         kx         AC_MSG_RESULT([yes])
   371         kx     ], [AC_MSG_RESULT([no])])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_LANG_POP([C++])
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX_BASE implements C++ DR P1155R3])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx         struct S1 { S1(S1 &&); };
   371         kx         struct S2: S1 {};
   371         kx         S1 f(S2 s) { return s; }
   371         kx     ])], [
   371         kx         AC_DEFINE([HAVE_P1155R3],[1])
   371         kx         AC_MSG_RESULT([yes])
   371         kx     ], [AC_MSG_RESULT([no])])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_LANG_POP([C++])
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX_BASE supports C++20 std::atomic_ref])
   371         kx HAVE_CXX20_ATOMIC_REF=
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx         #include <atomic>
   371         kx         int x;
   371         kx         std::atomic_ref<int> y(x);
   371         kx     ])], [
   371         kx         HAVE_CXX20_ATOMIC_REF=TRUE
   371         kx         AC_MSG_RESULT([yes])
   371         kx     ], [AC_MSG_RESULT([no])])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_LANG_POP([C++])
   371         kx AC_SUBST([HAVE_CXX20_ATOMIC_REF])
   371         kx 
   371         kx dnl Supported since GCC 9 and Clang 10 (which each also started to support -Wdeprecated-copy, but
   371         kx dnl which is included in -Wextra anyway):
   371         kx HAVE_WDEPRECATED_COPY_DTOR=
   371         kx if test "$GCC" = yes; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE supports -Wdeprecated-copy-dtor])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS -Werror -Wdeprecated-copy-dtor"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE()], [
   371         kx             HAVE_WDEPRECATED_COPY_DTOR=TRUE
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST([HAVE_WDEPRECATED_COPY_DTOR])
   371         kx 
   371         kx dnl At least GCC 8.2 with -O2 (i.e., --enable-optimized) causes a false-positive -Wmaybe-
   371         kx dnl uninitialized warning for code like
   371         kx dnl
   371         kx dnl   OString f();
   371         kx dnl   boost::optional<OString> * g(bool b) {
   371         kx dnl       boost::optional<OString> o;
   371         kx dnl       if (b) o = f();
   371         kx dnl       return new boost::optional<OString>(o);
   371         kx dnl   }
   371         kx dnl
   371         kx dnl (as is e.g. present, in a slightly more elaborate form, in
   371         kx dnl librdf_TypeConverter::extractNode_NoLock in unoxml/source/rdf/librdf_repository.cxx); the below
   371         kx dnl code is meant to be a faithfully stripped-down and self-contained version of the above code:
   371         kx HAVE_BROKEN_GCC_WMAYBE_UNINITIALIZED=
   371         kx if test "$GCC" = yes && test "$COM_IS_CLANG" != TRUE; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE might report false -Werror=maybe-uninitialized])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11 -Werror -Wmaybe-uninitialized"
   371         kx     if test "$ENABLE_OPTIMIZED" = TRUE; then
   371         kx         CXXFLAGS="$CXXFLAGS -O2"
   371         kx     else
   371         kx         CXXFLAGS="$CXXFLAGS -O0"
   371         kx     fi
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx             #include <new>
   371         kx             void f1(int);
   371         kx             struct S1 {
   371         kx                 ~S1() { f1(n); }
   371         kx                 int n = 0;
   371         kx             };
   371         kx             struct S2 {
   371         kx                 S2() {}
   371         kx                 S2(S2 const & s) { if (s.init) set(*reinterpret_cast<S1 const *>(s.stg)); }
   371         kx                 ~S2() { if (init) reinterpret_cast<S1 *>(stg)->S1::~S1(); }
   371         kx                 void set(S1 s) {
   371         kx                     new (stg) S1(s);
   371         kx                     init = true;
   371         kx                 }
   371         kx                 bool init = false;
   371         kx                 char stg[sizeof (S1)];
   371         kx             } ;
   371         kx             S1 f2();
   371         kx             S2 * f3(bool b) {
   371         kx                 S2 o;
   371         kx                 if (b) o.set(f2());
   371         kx                 return new S2(o);
   371         kx             }
   371         kx         ]])], [AC_MSG_RESULT([no])], [
   371         kx             HAVE_BROKEN_GCC_WMAYBE_UNINITIALIZED=TRUE
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST([HAVE_BROKEN_GCC_WMAYBE_UNINITIALIZED])
   371         kx 
   371         kx dnl Check for <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=87296#c5> "[8/9/10/11 Regression]
   371         kx dnl -Wstringop-overflow false positive due to using MEM_REF type of &MEM" (fixed in GCC 11), which
   371         kx dnl hits us e.g. with GCC 10 and --enable-optimized at
   371         kx dnl
   371         kx dnl   In file included from include/rtl/string.hxx:49,
   371         kx dnl                    from include/rtl/ustring.hxx:43,
   371         kx dnl                    from include/osl/file.hxx:35,
   371         kx dnl                    from include/codemaker/global.hxx:28,
   371         kx dnl                    from include/codemaker/options.hxx:23,
   371         kx dnl                    from codemaker/source/commoncpp/commoncpp.cxx:24:
   371         kx dnl   In function ‘char* rtl::addDataHelper(char*, const char*, std::size_t)’,
   371         kx dnl       inlined from ‘static char* rtl::ToStringHelper<const char [N]>::addData(char*, const char*) [with long unsigned int N = 3]’ at include/rtl/stringconcat.hxx:147:85,
   371         kx dnl       inlined from ‘char* rtl::OStringConcat<T1, T2>::addData(char*) const [with T1 = const char [3]; T2 = rtl::OString]’ at include/rtl/stringconcat.hxx:226:103,
   371         kx dnl       inlined from ‘rtl::OStringBuffer& rtl::OStringBuffer::append(rtl::OStringConcat<T1, T2>&&) [with T1 = const char [3]; T2 = rtl::OString]’ at include/rtl/strbuf.hxx:599:30,
   371         kx dnl       inlined from ‘rtl::OString codemaker::cpp::scopedCppName(const rtl::OString&, bool)’ at codemaker/source/commoncpp/commoncpp.cxx:53:55:
   371         kx dnl   include/rtl/stringconcat.hxx:78:15: error: writing 2 bytes into a region of size 1 [-Werror=stringop-overflow=]
   371         kx dnl      78 |         memcpy( buffer, data, length );
   371         kx dnl         |         ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
   371         kx HAVE_BROKEN_GCC_WSTRINGOP_OVERFLOW=
   371         kx if test "$GCC" = yes && test "$COM_IS_CLANG" != TRUE; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE might report false -Werror=stringop-overflow=])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11 -Werror -Wstringop-overflow"
   371         kx     if test "$ENABLE_OPTIMIZED" = TRUE; then
   371         kx         CXXFLAGS="$CXXFLAGS -O2"
   371         kx     else
   371         kx         CXXFLAGS="$CXXFLAGS -O0"
   371         kx     fi
   371         kx     dnl Test code taken from <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=87296#c0>:
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx             void fill(char const * begin, char const * end, char c);
   371         kx             struct q {
   371         kx                 char ids[4];
   371         kx                 char username[6];
   371         kx             };
   371         kx             void test(q & c) {
   371         kx                 fill(c.ids, c.ids + sizeof(c.ids), '\0');
   371         kx                 __builtin_strncpy(c.username, "root", sizeof(c.username));
   371         kx             }
   371         kx         ]])], [AC_MSG_RESULT([no])], [
   371         kx             HAVE_BROKEN_GCC_WSTRINGOP_OVERFLOW=TRUE
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST([HAVE_BROKEN_GCC_WSTRINGOP_OVERFLOW])
   371         kx 
   371         kx HAVE_DLLEXPORTINLINES=
   371         kx if test "$_os" = "WINNT"; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE supports -Zc:dllexportInlines-])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS -Werror -Zc:dllexportInlines-"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE()], [
   371         kx             HAVE_DLLEXPORTINLINES=TRUE
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST([HAVE_DLLEXPORTINLINES])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl CPU Intrinsics support - SSE, AVX
   371         kx dnl ===================================================================
   371         kx 
   371         kx CXXFLAGS_INTRINSICS_SSE2=
   371         kx CXXFLAGS_INTRINSICS_SSSE3=
   371         kx CXXFLAGS_INTRINSICS_SSE41=
   371         kx CXXFLAGS_INTRINSICS_SSE42=
   371         kx CXXFLAGS_INTRINSICS_AVX=
   371         kx CXXFLAGS_INTRINSICS_AVX2=
   371         kx CXXFLAGS_INTRINSICS_AVX512=
   371         kx CXXFLAGS_INTRINSICS_AVX512F=
   371         kx CXXFLAGS_INTRINSICS_F16C=
   371         kx CXXFLAGS_INTRINSICS_FMA=
   371         kx 
   371         kx if test "$GCC" = "yes" -o "$COM_IS_CLANG" = TRUE; then
   371         kx     # GCC, Clang or Clang-cl (clang-cl + MSVC's -arch options don't work well together)
   371         kx     flag_sse2=-msse2
   371         kx     flag_ssse3=-mssse3
   371         kx     flag_sse41=-msse4.1
   371         kx     flag_sse42=-msse4.2
   371         kx     flag_avx=-mavx
   371         kx     flag_avx2=-mavx2
   371         kx     flag_avx512="-mavx512f -mavx512vl -mavx512bw -mavx512dq -mavx512cd"
   371         kx     flag_avx512f=-mavx512f
   371         kx     flag_f16c=-mf16c
   371         kx     flag_fma=-mfma
   371         kx else
   371         kx     # With MSVC using -arch is in fact not necessary for being able
   371         kx     # to use CPU intrinsics, code using AVX512F intrinsics will compile
   371         kx     # even if compiled with -arch:AVX, the -arch option really only affects
   371         kx     # instructions generated for C/C++ code.
   371         kx     # So use the matching same (or lower) -arch options, but only in order
   371         kx     # to generate the best matching instructions for the C++ code surrounding
   371         kx     # the intrinsics.
   371         kx     # SSE2 is the default for x86/x64, so no need to specify the option.
   371         kx     flag_sse2=
   371         kx     # No specific options for these, use the next lower.
   371         kx     flag_ssse3="$flag_sse2"
   371         kx     flag_sse41="$flag_sse2"
   371         kx     flag_sse42="$flag_sse2"
   371         kx     flag_avx=-arch:AVX
   371         kx     flag_avx2=-arch:AVX2
   371         kx     flag_avx512=-arch:AVX512
   371         kx     # Using -arch:AVX512 would enable more than just AVX512F, so use only AVX2.
   371         kx     flag_avx512f=-arch:AVX2
   371         kx     # No MSVC options for these.
   371         kx     flag_f16c="$flag_sse2"
   371         kx     flag_fma="$flag_sse2"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile SSE2 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_sse2"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <emmintrin.h>
   371         kx     int main () {
   371         kx         __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx         c = _mm_xor_si128 (a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_sse2=yes],
   371         kx     [can_compile_sse2=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_sse2}])
   371         kx if test "${can_compile_sse2}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_SSE2="$flag_sse2"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile SSSE3 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_ssse3"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <tmmintrin.h>
   371         kx     int main () {
   371         kx         __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx         c = _mm_maddubs_epi16 (a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_ssse3=yes],
   371         kx     [can_compile_ssse3=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_ssse3}])
   371         kx if test "${can_compile_ssse3}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_SSSE3="$flag_ssse3"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile SSE4.1 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_sse41"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <smmintrin.h>
   371         kx     int main () {
   371         kx         __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx         c = _mm_cmpeq_epi64 (a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_sse41=yes],
   371         kx     [can_compile_sse41=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_sse41}])
   371         kx if test "${can_compile_sse41}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_SSE41="$flag_sse41"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile SSE4.2 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_sse42"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <nmmintrin.h>
   371         kx     int main () {
   371         kx         __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx         c = _mm_cmpgt_epi64 (a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_sse42=yes],
   371         kx     [can_compile_sse42=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_sse42}])
   371         kx if test "${can_compile_sse42}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_SSE42="$flag_sse42"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile AVX intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_avx"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <immintrin.h>
   371         kx     int main () {
   371         kx         __m256 a = _mm256_set1_ps (0.0f), b = _mm256_set1_ps (0.0f), c;
   371         kx         c = _mm256_xor_ps(a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_avx=yes],
   371         kx     [can_compile_avx=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_avx}])
   371         kx if test "${can_compile_avx}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_AVX="$flag_avx"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile AVX2 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_avx2"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <immintrin.h>
   371         kx     int main () {
   371         kx         __m256i a = _mm256_set1_epi32 (0), b = _mm256_set1_epi32 (0), c;
   371         kx         c = _mm256_maddubs_epi16(a, b);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_avx2=yes],
   371         kx     [can_compile_avx2=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_avx2}])
   371         kx if test "${can_compile_avx2}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_AVX2="$flag_avx2"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile AVX512 intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_avx512"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <immintrin.h>
   371         kx     int main () {
   371         kx         __m512i a = _mm512_loadu_si512(0);
   371         kx         __m512d v1 = _mm512_load_pd(0);
   371         kx         // https://gcc.gnu.org/git/?p=gcc.git;a=commit;f=gcc/config/i386/avx512fintrin.h;h=23bce99cbe7016a04e14c2163ed3fe6a5a64f4e2
   371         kx         __m512d v2 = _mm512_abs_pd(v1);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_avx512=yes],
   371         kx     [can_compile_avx512=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_avx512}])
   371         kx if test "${can_compile_avx512}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_AVX512="$flag_avx512"
   371         kx     CXXFLAGS_INTRINSICS_AVX512F="$flag_avx512f"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile F16C intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_f16c"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <immintrin.h>
   371         kx     int main () {
   371         kx         __m128i a = _mm_set1_epi32 (0);
   371         kx         __m128 c;
   371         kx         c = _mm_cvtph_ps(a);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_f16c=yes],
   371         kx     [can_compile_f16c=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_f16c}])
   371         kx if test "${can_compile_f16c}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_F16C="$flag_f16c"
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX can compile FMA intrinsics])
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $flag_fma"
   371         kx AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx     #include <immintrin.h>
   371         kx     int main () {
   371         kx         __m256 a = _mm256_set1_ps (0.0f), b = _mm256_set1_ps (0.0f), c = _mm256_set1_ps (0.0f), d;
   371         kx         d = _mm256_fmadd_ps(a, b, c);
   371         kx         return 0;
   371         kx     }
   371         kx     ])],
   371         kx     [can_compile_fma=yes],
   371         kx     [can_compile_fma=no])
   371         kx AC_LANG_POP([C++])
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_MSG_RESULT([${can_compile_fma}])
   371         kx if test "${can_compile_fma}" = "yes" ; then
   371         kx     CXXFLAGS_INTRINSICS_FMA="$flag_fma"
   371         kx fi
   371         kx 
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_SSE2])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_SSSE3])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_SSE41])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_SSE42])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_AVX])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_AVX2])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_AVX512])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_AVX512F])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_F16C])
   371         kx AC_SUBST([CXXFLAGS_INTRINSICS_FMA])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl system stl sanity tests
   371         kx dnl ===================================================================
   371         kx if test "$_os" != "WINNT"; then
   371         kx 
   371         kx     AC_LANG_PUSH([C++])
   371         kx 
   371         kx     save_CPPFLAGS="$CPPFLAGS"
   371         kx     if test -n "$MACOSX_SDK_PATH"; then
   371         kx         CPPFLAGS="-isysroot $MACOSX_SDK_PATH $CPPFLAGS"
   371         kx     fi
   371         kx 
   371         kx     # Assume visibility is not broken with libc++. The below test is very much designed for libstdc++
   371         kx     # only.
   371         kx     if test "$CPP_LIBRARY" = GLIBCXX; then
   371         kx         dnl gcc#19664, gcc#22482, rhbz#162935
   371         kx         AC_MSG_CHECKING([if STL headers are visibility safe (GCC bug 22482)])
   371         kx         AC_EGREP_HEADER(visibility push, string, stlvisok=yes, stlvisok=no)
   371         kx         AC_MSG_RESULT([$stlvisok])
   371         kx         if test "$stlvisok" = "no"; then
   371         kx             AC_MSG_ERROR([Your libstdc++ headers are not visibility safe. This is no longer supported.])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     # As the below test checks things when linking self-compiled dynamic libraries, it presumably is irrelevant
   371         kx     # when we don't make any dynamic libraries?
   371         kx     if test "$DISABLE_DYNLOADING" = ""; then
   371         kx         AC_MSG_CHECKING([if $CXX_BASE is -fvisibility-inlines-hidden safe (Clang bug 11250)])
   371         kx         cat > conftestlib1.cc <<_ACEOF
   371         kx template<typename T> struct S1 { virtual ~S1() {} virtual void f() {} };
   371         kx struct S2: S1<int> { virtual ~S2(); };
   371         kx S2::~S2() {}
   371         kx _ACEOF
   371         kx         cat > conftestlib2.cc <<_ACEOF
   371         kx template<typename T> struct S1 { virtual ~S1() {} virtual void f() {} };
   371         kx struct S2: S1<int> { virtual ~S2(); };
   371         kx struct S3: S2 { virtual ~S3(); }; S3::~S3() {}
   371         kx _ACEOF
   371         kx         gccvisinlineshiddenok=yes
   371         kx         if ! $CXX $CXXFLAGS $CPPFLAGS $LINKFLAGSSHL -fPIC -fvisibility-inlines-hidden conftestlib1.cc -o libconftest1$DLLPOST >/dev/null 2>&5; then
   371         kx             gccvisinlineshiddenok=no
   371         kx         else
   371         kx             dnl At least Clang -fsanitize=address and -fsanitize=undefined are
   371         kx             dnl known to not work with -z defs (unsetting which makes the test
   371         kx             dnl moot, though):
   371         kx             my_linkflagsnoundefs=$LINKFLAGSNOUNDEFS
   371         kx             if test "$COM_IS_CLANG" = TRUE; then
   371         kx                 for i in $CXX $CXXFLAGS; do
   371         kx                     case $i in
   371         kx                     -fsanitize=*)
   371         kx                         my_linkflagsnoundefs=
   371         kx                         break
   371         kx                         ;;
   371         kx                     esac
   371         kx                 done
   371         kx             fi
   371         kx             if ! $CXX $CXXFLAGS $CPPFLAGS $LINKFLAGSSHL -fPIC -fvisibility-inlines-hidden conftestlib2.cc -L. -lconftest1 $my_linkflagsnoundefs -o libconftest2$DLLPOST >/dev/null 2>&5; then
   371         kx                 gccvisinlineshiddenok=no
   371         kx             fi
   371         kx         fi
   371         kx 
   371         kx         rm -fr libconftest*
   371         kx         AC_MSG_RESULT([$gccvisinlineshiddenok])
   371         kx         if test "$gccvisinlineshiddenok" = "no"; then
   371         kx             AC_MSG_ERROR([Your gcc/clang is not -fvisibility-inlines-hidden safe. This is no longer supported.])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx    AC_MSG_CHECKING([if $CXX_BASE has a visibility bug with class-level attributes (GCC bug 26905)])
   371         kx     cat >visibility.cxx <<_ACEOF
   371         kx #pragma GCC visibility push(hidden)
   371         kx struct __attribute__ ((visibility ("default"))) TestStruct {
   371         kx   static void Init();
   371         kx };
   371         kx __attribute__ ((visibility ("default"))) void TestFunc() {
   371         kx   TestStruct::Init();
   371         kx }
   371         kx _ACEOF
   371         kx     if ! $CXX $CXXFLAGS $CPPFLAGS -fpic -S visibility.cxx; then
   371         kx         gccvisbroken=yes
   371         kx     else
   371         kx         case "$host_cpu" in
   371         kx         i?86|x86_64)
   371         kx             if test "$_os" = "Darwin" -o "$_os" = "iOS"; then
   371         kx                 gccvisbroken=no
   371         kx             else
   371         kx                 if $EGREP -q '@PLT|@GOT' visibility.s || test "$ENABLE_LTO" = "TRUE"; then
   371         kx                     gccvisbroken=no
   371         kx                 else
   371         kx                     gccvisbroken=yes
   371         kx                 fi
   371         kx             fi
   371         kx             ;;
   371         kx         *)
   371         kx             gccvisbroken=no
   371         kx             ;;
   371         kx         esac
   371         kx     fi
   371         kx     rm -f visibility.s visibility.cxx
   371         kx 
   371         kx     AC_MSG_RESULT([$gccvisbroken])
   371         kx     if test "$gccvisbroken" = "yes"; then
   371         kx         AC_MSG_ERROR([Your gcc is not -fvisibility=hidden safe. This is no longer supported.])
   371         kx     fi
   371         kx 
   371         kx     CPPFLAGS="$save_CPPFLAGS"
   371         kx 
   371         kx     AC_MSG_CHECKING([if CET endbranch is recognized])
   371         kx cat > endbr.s <<_ACEOF
   371         kx endbr32
   371         kx _ACEOF
   371         kx     HAVE_ASM_END_BRANCH_INS_SUPPORT=
   371         kx     if $CXX -c endbr.s -o endbr.o >/dev/null 2>&5; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         HAVE_ASM_END_BRANCH_INS_SUPPORT=TRUE
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx     rm -f endbr.s endbr.o
   371         kx     AC_SUBST(HAVE_ASM_END_BRANCH_INS_SUPPORT)
   371         kx 
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl  Clang++ tests
   371         kx dnl ===================================================================
   371         kx 
   371         kx HAVE_GCC_FNO_ENFORCE_EH_SPECS=
   371         kx if test "$GCC" = "yes"; then
   371         kx     AC_MSG_CHECKING([whether $CXX_BASE supports -fno-enforce-eh-specs])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CFLAGS -Werror -fno-enforce-eh-specs"
   371         kx     AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[ return 0; ]])],[ HAVE_GCC_FNO_ENFORCE_EH_SPECS=TRUE ],[])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx     if test "$HAVE_GCC_FNO_ENFORCE_EH_SPECS" = "TRUE"; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(HAVE_GCC_FNO_ENFORCE_EH_SPECS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Compiler plugins
   371         kx dnl ===================================================================
   371         kx 
   371         kx COMPILER_PLUGINS=
   371         kx # currently only Clang
   371         kx 
   371         kx if test "$COM_IS_CLANG" != "TRUE"; then
   371         kx     if test "$libo_fuzzed_enable_compiler_plugins" = yes -a "$enable_compiler_plugins" = yes; then
   371         kx         AC_MSG_NOTICE([Resetting --enable-compiler-plugins=no])
   371         kx         enable_compiler_plugins=no
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx COMPILER_PLUGINS_COM_IS_CLANG=
   371         kx if test "$COM_IS_CLANG" = "TRUE"; then
   371         kx     if test -n "$enable_compiler_plugins"; then
   371         kx         compiler_plugins="$enable_compiler_plugins"
   371         kx     elif test -n "$ENABLE_DBGUTIL"; then
   371         kx         compiler_plugins=test
   371         kx     else
   371         kx         compiler_plugins=no
   371         kx     fi
   371         kx     if test "$compiler_plugins" != no -a "$my_apple_clang" != yes; then
   371         kx         if test "$CLANGVER" -lt 120001; then
   371         kx             if test "$compiler_plugins" = yes; then
   371         kx                 AC_MSG_ERROR(
   371         kx                     [Clang $CLANGVER is too old to build compiler plugins; need >= 12.0.1.])
   371         kx             else
   371         kx                 compiler_plugins=no
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx     if test "$compiler_plugins" != "no"; then
   371         kx         dnl The prefix where Clang resides, override to where Clang resides if
   371         kx         dnl using a source build:
   371         kx         if test -z "$CLANGDIR"; then
   371         kx             CLANGDIR=$(dirname $(dirname $($CXX -print-prog-name=$(basename $(printf '%s\n' $CXX | grep clang | head -n 1)))))
   371         kx         fi
   371         kx         # Assume Clang is self-built, but allow overriding COMPILER_PLUGINS_CXX to the compiler Clang was built with.
   371         kx         if test -z "$COMPILER_PLUGINS_CXX"; then
   371         kx             COMPILER_PLUGINS_CXX=[$(echo $CXX | sed -e 's/-fsanitize=[^ ]*//g')]
   371         kx         fi
   371         kx         clangbindir=$CLANGDIR/bin
   371         kx         if test "$build_os" = "cygwin"; then
   371         kx             clangbindir=$(cygpath -u "$clangbindir")
   371         kx         fi
   371         kx         AC_PATH_PROG(LLVM_CONFIG, llvm-config,[],"$clangbindir" $PATH)
   371         kx         if test -n "$LLVM_CONFIG"; then
   371         kx             COMPILER_PLUGINS_CXXFLAGS=$($LLVM_CONFIG --cxxflags)
   371         kx             COMPILER_PLUGINS_LINKFLAGS=$($LLVM_CONFIG --ldflags --libs --system-libs | tr '\n' ' ')
   371         kx             if test -z "$CLANGLIBDIR"; then
   371         kx                 CLANGLIBDIR=$($LLVM_CONFIG --libdir)
   371         kx             fi
   371         kx             # Try if clang is built from source (in which case its includes are not together with llvm includes).
   371         kx             # src-root is [llvm-toplevel-src-dir]/llvm, clang is [llvm-toplevel-src-dir]/clang
   371         kx             if $LLVM_CONFIG --src-root >/dev/null 2>&1; then
   371         kx                 clangsrcdir=$(dirname $($LLVM_CONFIG --src-root))
   371         kx                 if test -n "$clangsrcdir" -a -d "$clangsrcdir" -a -d "$clangsrcdir/clang/include"; then
   371         kx                     COMPILER_PLUGINS_CXXFLAGS="$COMPILER_PLUGINS_CXXFLAGS -I$clangsrcdir/clang/include"
   371         kx                 fi
   371         kx             fi
   371         kx             # obj-root is [llvm-toplevel-obj-dir]/, clang is [llvm-toplevel-obj-dir]/tools/clang
   371         kx             clangobjdir=$($LLVM_CONFIG --obj-root)
   371         kx             if test -n "$clangobjdir" -a -d "$clangobjdir" -a -d "$clangobjdir/tools/clang/include"; then
   371         kx                 COMPILER_PLUGINS_CXXFLAGS="$COMPILER_PLUGINS_CXXFLAGS -I$clangobjdir/tools/clang/include"
   371         kx             fi
   371         kx         fi
   371         kx         AC_MSG_NOTICE([compiler plugins compile flags: $COMPILER_PLUGINS_CXXFLAGS])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXX=$CXX
   371         kx         save_CXXCPP=$CXXCPP
   371         kx         save_CPPFLAGS=$CPPFLAGS
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         save_LDFLAGS=$LDFLAGS
   371         kx         save_LIBS=$LIBS
   371         kx         CXX=$COMPILER_PLUGINS_CXX
   371         kx         CXXCPP="$COMPILER_PLUGINS_CXX -E"
   371         kx         CPPFLAGS="$COMPILER_PLUGINS_CXXFLAGS"
   371         kx         CXXFLAGS="$COMPILER_PLUGINS_CXXFLAGS"
   371         kx         AC_CHECK_HEADER(clang/Basic/SourceLocation.h,
   371         kx             [COMPILER_PLUGINS=TRUE],
   371         kx             [
   371         kx             if test "$compiler_plugins" = "yes"; then
   371         kx                 AC_MSG_ERROR([Cannot find Clang headers to build compiler plugins.])
   371         kx             else
   371         kx                 AC_MSG_WARN([Cannot find Clang headers to build compiler plugins, plugins disabled])
   371         kx                 add_warning "Cannot find Clang headers to build compiler plugins, plugins disabled."
   371         kx             fi
   371         kx             ])
   371         kx         dnl TODO: Windows doesn't use LO_CLANG_SHARED_PLUGINS for now, see corresponding TODO
   371         kx         dnl comment in compilerplugins/Makefile-clang.mk:
   371         kx         if test -n "$COMPILER_PLUGINS" && test "$_os" != "WINNT"; then
   371         kx             LDFLAGS=""
   371         kx             AC_MSG_CHECKING([for clang libraries to use])
   371         kx             if test -z "$CLANGTOOLLIBS"; then
   371         kx                 LIBS="-lclang-cpp $COMPILER_PLUGINS_LINKFLAGS"
   371         kx                 AC_LINK_IFELSE([
   371         kx                     AC_LANG_PROGRAM([[#include "clang/Basic/SourceLocation.h"]],
   371         kx                         [[ clang::FullSourceLoc().dump(); ]])
   371         kx                 ],[CLANGTOOLLIBS="$LIBS"],[])
   371         kx             fi
   371         kx             dnl If the above check for the combined -lclang-cpp failed, fall back to a hand-curated
   371         kx             dnl list of individual -lclang* (but note that that list can become outdated over time,
   371         kx             dnl see e.g. the since-reverted 5078591de9a0e65ca560a4f1913e90dfe95f66bf "CLANGTOOLLIBS
   371         kx             dnl needs to include -lclangSupport now"):
   371         kx             if test -z "$CLANGTOOLLIBS"; then
   371         kx                 LIBS="-lclangTooling -lclangFrontend -lclangDriver -lclangParse -lclangSema -lclangEdit \
   371         kx  -lclangAnalysis -lclangAST -lclangLex -lclangSerialization -lclangBasic $COMPILER_PLUGINS_LINKFLAGS"
   371         kx                 AC_LINK_IFELSE([
   371         kx                     AC_LANG_PROGRAM([[#include "clang/Basic/SourceLocation.h"]],
   371         kx                         [[ clang::FullSourceLoc().dump(); ]])
   371         kx                 ],[CLANGTOOLLIBS="$LIBS"],[])
   371         kx             fi
   371         kx             AC_MSG_RESULT([$CLANGTOOLLIBS])
   371         kx             if test -z "$CLANGTOOLLIBS"; then
   371         kx                 if test "$compiler_plugins" = "yes"; then
   371         kx                     AC_MSG_ERROR([Cannot find Clang libraries to build compiler plugins.])
   371         kx                 else
   371         kx                     AC_MSG_WARN([Cannot find Clang libraries to build compiler plugins, plugins disabled])
   371         kx                     add_warning "Cannot find Clang libraries to build compiler plugins, plugins disabled."
   371         kx                 fi
   371         kx                 COMPILER_PLUGINS=
   371         kx             fi
   371         kx             if test -n "$COMPILER_PLUGINS"; then
   371         kx                 if test -z "$CLANGSYSINCLUDE"; then
   371         kx                     if test -n "$LLVM_CONFIG"; then
   371         kx                         # Path to the clang system headers (no idea if there's a better way to get it).
   371         kx                         CLANGSYSINCLUDE=$($LLVM_CONFIG --libdir)/clang/$($LLVM_CONFIG --version | sed 's/git\|svn//')/include
   371         kx                     fi
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx         CXX=$save_CXX
   371         kx         CXXCPP=$save_CXXCPP
   371         kx         CPPFLAGS=$save_CPPFLAGS
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         LDFLAGS=$save_LDFLAGS
   371         kx         LIBS="$save_LIBS"
   371         kx         AC_LANG_POP([C++])
   371         kx 
   371         kx         AC_MSG_CHECKING([whether the compiler for building compilerplugins is actually Clang])
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
   371         kx             #ifndef __clang__
   371         kx             you lose
   371         kx             #endif
   371         kx             int foo=42;
   371         kx             ]])],
   371         kx             [AC_MSG_RESULT([yes])
   371         kx              COMPILER_PLUGINS_COM_IS_CLANG=TRUE],
   371         kx             [AC_MSG_RESULT([no])])
   371         kx         AC_SUBST(COMPILER_PLUGINS_COM_IS_CLANG)
   371         kx     fi
   371         kx else
   371         kx     if test "$enable_compiler_plugins" = "yes"; then
   371         kx         AC_MSG_ERROR([Compiler plugins are currently supported only with the Clang compiler.])
   371         kx     fi
   371         kx fi
   371         kx COMPILER_PLUGINS_ANALYZER_PCH=
   371         kx if test "$enable_compiler_plugins_analyzer_pch" != no; then
   371         kx     COMPILER_PLUGINS_ANALYZER_PCH=TRUE
   371         kx fi
   371         kx AC_SUBST(COMPILER_PLUGINS)
   371         kx AC_SUBST(COMPILER_PLUGINS_ANALYZER_PCH)
   371         kx AC_SUBST(COMPILER_PLUGINS_COM_IS_CLANG)
   371         kx AC_SUBST(COMPILER_PLUGINS_CXX)
   371         kx AC_SUBST(COMPILER_PLUGINS_CXXFLAGS)
   371         kx AC_SUBST(COMPILER_PLUGINS_CXX_LINKFLAGS)
   371         kx AC_SUBST(COMPILER_PLUGINS_DEBUG)
   371         kx AC_SUBST(COMPILER_PLUGINS_TOOLING_ARGS)
   371         kx AC_SUBST(CLANGDIR)
   371         kx AC_SUBST(CLANGLIBDIR)
   371         kx AC_SUBST(CLANGTOOLLIBS)
   371         kx AC_SUBST(CLANGSYSINCLUDE)
   371         kx 
   371         kx # Plugin to help linker.
   371         kx # Add something like LD_PLUGIN=/usr/lib64/LLVMgold.so to your autogen.input.
   371         kx # This makes --enable-lto build with clang work.
   371         kx AC_SUBST(LD_PLUGIN)
   371         kx 
   371         kx AC_CHECK_FUNCS(posix_fallocate, HAVE_POSIX_FALLOCATE=YES, [HAVE_POSIX_FALLOCATE=NO])
   371         kx AC_SUBST(HAVE_POSIX_FALLOCATE)
   371         kx 
   371         kx JITC_PROCESSOR_TYPE=""
   371         kx if test "$_os" = "Linux" -a "$host_cpu" = "powerpc"; then
   371         kx     # IBMs JDK needs this...
   371         kx     JITC_PROCESSOR_TYPE=6
   371         kx     export JITC_PROCESSOR_TYPE
   371         kx fi
   371         kx AC_SUBST([JITC_PROCESSOR_TYPE])
   371         kx 
   371         kx # Misc Windows Stuff
   371         kx AC_ARG_WITH(ucrt-dir,
   371         kx     AS_HELP_STRING([--with-ucrt-dir],
   371         kx         [path to the directory with the arch-specific MSU packages of the Windows Universal CRT redistributables
   371         kx         (MS KB 2999226) for packaging into the installsets (without those the target system needs to install
   371         kx         the UCRT or Visual C++ Runtimes manually). The directory must contain the following 6 files:
   371         kx             Windows6.1-KB2999226-x64.msu
   371         kx             Windows6.1-KB2999226-x86.msu
   371         kx             Windows8.1-KB2999226-x64.msu
   371         kx             Windows8.1-KB2999226-x86.msu
   371         kx             Windows8-RT-KB2999226-x64.msu
   371         kx             Windows8-RT-KB2999226-x86.msu
   371         kx         A zip archive including those files is available from Microsoft site:
   371         kx         https://www.microsoft.com/en-us/download/details.aspx?id=48234]),
   371         kx ,)
   371         kx 
   371         kx UCRT_REDISTDIR="$with_ucrt_dir"
   371         kx if test $_os = "WINNT"; then
   371         kx     find_msvc_x64_dlls
   371         kx     MSVC_DLL_PATH=`win_short_path_for_make "$msvcdllpath"`
   371         kx     MSVC_DLLS="$msvcdlls"
   371         kx     if echo "$msvcdllpath" | grep -q "VC143.CRT$"; then
   371         kx         with_redist=143
   371         kx     elif echo "$msvcdllpath" | grep -q "VC142.CRT$"; then
   371         kx         with_redist=142
   371         kx     elif echo "$msvcdllpath" | grep -q "VC141.CRT$"; then
   371         kx         with_redist=141
   371         kx     fi
   371         kx     for i in $PKGFORMAT; do
   371         kx         if test "$i" = msi; then
   371         kx             find_msms "$with_redist"
   371         kx             if test -n "$msmdir"; then
   371         kx                 MSM_PATH=`win_short_path_for_make "$msmdir"`
   371         kx                 SCPDEFS="$SCPDEFS -DWITH_VC_REDIST=$with_redist"
   371         kx             fi
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     if test "$UCRT_REDISTDIR" = "no"; then
   371         kx         dnl explicitly disabled
   371         kx         UCRT_REDISTDIR=""
   371         kx     else
   371         kx         if ! test -f "$UCRT_REDISTDIR/Windows6.1-KB2999226-x64.msu" -a \
   371         kx                   -f "$UCRT_REDISTDIR/Windows6.1-KB2999226-x86.msu" -a \
   371         kx                   -f "$UCRT_REDISTDIR/Windows8.1-KB2999226-x64.msu" -a \
   371         kx                   -f "$UCRT_REDISTDIR/Windows8.1-KB2999226-x86.msu" -a \
   371         kx                   -f "$UCRT_REDISTDIR/Windows8-RT-KB2999226-x64.msu" -a \
   371         kx                   -f "$UCRT_REDISTDIR/Windows8-RT-KB2999226-x86.msu"; then
   371         kx             UCRT_REDISTDIR=""
   371         kx             if test -n "$PKGFORMAT"; then
   371         kx                for i in $PKGFORMAT; do
   371         kx                    case "$i" in
   371         kx                    msi)
   371         kx                        AC_MSG_WARN([--without-ucrt-dir not specified or MSUs not found - installer will have runtime dependency])
   371         kx                        add_warning "--without-ucrt-dir not specified or MSUs not found - installer will have runtime dependency"
   371         kx                        ;;
   371         kx                    esac
   371         kx                done
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(UCRT_REDISTDIR)
   371         kx AC_SUBST(MSVC_DLL_PATH)
   371         kx AC_SUBST(MSVC_DLLS)
   371         kx AC_SUBST(MSM_PATH)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checks for Java
   371         kx dnl ===================================================================
   371         kx if test "$ENABLE_JAVA" != ""; then
   371         kx 
   371         kx     # Windows-specific tests
   371         kx     if test "$build_os" = "cygwin"; then
   371         kx         if test -z "$with_jdk_home"; then
   371         kx             dnl See <https://docs.oracle.com/javase/9/migrate/toc.htm#JSMIG-GUID-EEED398E-AE37-4D12-
   371         kx             dnl AB10-49F82F720027> section "Windows Registry Key Changes":
   371         kx             reg_get_value "$WIN_HOST_BITS" "HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/JDK/CurrentVersion"
   371         kx             if test -n "$regvalue"; then
   371         kx                 ver=$regvalue
   371         kx                 reg_get_value "$WIN_HOST_BITS" "HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/JDK/$ver/JavaHome"
   371         kx                 with_jdk_home=$regvalue
   371         kx             fi
   371         kx             howfound="found automatically"
   371         kx         else
   371         kx             with_jdk_home=`win_short_path_for_make "$with_jdk_home"`
   371         kx             howfound="you passed"
   371         kx         fi
   371         kx 
   371         kx         if ! test -f "$with_jdk_home/lib/jvm.lib" -a -f "$with_jdk_home/bin/java.exe"; then
   371         kx             AC_MSG_ERROR([No JDK found, pass the --with-jdk-home option (or fix the path) pointing to a $WIN_HOST_BITS-bit JDK >= 17])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     # macOS: /usr/libexec/java_home helps to set the current JDK_HOME. Actually JDK_HOME should NOT be set where java (/usr/bin/java) is located.
   371         kx     # /usr/bin/java -> /System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands/java, but /usr does not contain the JDK libraries
   371         kx     if test -z "$with_jdk_home" -a "$_os" = "Darwin" -a -x /usr/libexec/java_home; then
   371         kx         with_jdk_home=`/usr/libexec/java_home`
   371         kx     fi
   371         kx 
   371         kx     JAVA_HOME=; export JAVA_HOME
   371         kx     if test -z "$with_jdk_home"; then
   371         kx         AC_PATH_PROG(JAVAINTERPRETER, $with_java)
   371         kx     else
   371         kx         _java_path="$with_jdk_home/bin/$with_java"
   371         kx         dnl Check if there is a Java interpreter at all.
   371         kx         if test -x "$_java_path"; then
   371         kx             JAVAINTERPRETER=$_java_path
   371         kx         else
   371         kx             AC_MSG_ERROR([$_java_path not found, pass --with-jdk-home])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     dnl Check that the JDK found is correct architecture (at least 2 reasons to
   371         kx     dnl check: officebean needs to link -ljawt, and libjpipe.so needs to be
   371         kx     dnl loaded by java to run JunitTests:
   371         kx     if test "$build_os" = "cygwin" -a "$cross_compiling" != "yes"; then
   371         kx         shortjdkhome=`cygpath -d "$with_jdk_home"`
   371         kx         if test $WIN_HOST_BITS -eq 64 -a -f "$with_jdk_home/bin/java.exe" -a "`$shortjdkhome/bin/java.exe -version 2>&1 | $GREP -i 64-bit`" = "" >/dev/null; then
   371         kx             AC_MSG_WARN([You are building 64-bit binaries but the JDK $howfound is 32-bit])
   371         kx             AC_MSG_ERROR([You should pass the --with-jdk-home option pointing to a 64-bit JDK])
   371         kx         elif test $WIN_HOST_BITS -eq 32 -a -f "$with_jdk_home/bin/java.exe" -a "`$shortjdkhome/bin/java.exe -version 2>&1 | $GREP -i 64-bit`" != ""  >/dev/null; then
   371         kx             AC_MSG_WARN([You are building 32-bit binaries but the JDK $howfound is 64-bit])
   371         kx             AC_MSG_ERROR([You should pass the --with-jdk-home option pointing to a (32-bit) JDK])
   371         kx         fi
   371         kx 
   371         kx         if test x`echo "$JAVAINTERPRETER" | $GREP -i '\.exe$'` = x; then
   371         kx             JAVAINTERPRETER="${JAVAINTERPRETER}.exe"
   371         kx         fi
   371         kx         JAVAINTERPRETER=`win_short_path_for_make "$JAVAINTERPRETER"`
   371         kx     elif test "$cross_compiling" != "yes"; then
   371         kx         case $CPUNAME in
   371         kx             AARCH64|AXP|X86_64|IA64|POWERPC64|S390X|SPARC64|MIPS64|RISCV64|LOONGARCH64)
   371         kx                 if test -f "$JAVAINTERPRETER" -a "`$JAVAINTERPRETER -version 2>&1 | $GREP -i 64-bit`" = "" >/dev/null; then
   371         kx                     AC_MSG_WARN([You are building 64-bit binaries but the JDK $JAVAINTERPRETER is 32-bit])
   371         kx                     AC_MSG_ERROR([You should pass the --with-jdk-home option pointing to a 64-bit JDK])
   371         kx                 fi
   371         kx                 ;;
   371         kx             *) # assumption: everything else 32-bit
   371         kx                 if test -f "$JAVAINTERPRETER" -a "`$JAVAINTERPRETER -version 2>&1 | $GREP -i 64-bit`" != ""  >/dev/null; then
   371         kx                     AC_MSG_WARN([You are building 32-bit binaries but the JDK $howfound is 64-bit])
   371         kx                     AC_MSG_ERROR([You should pass the --with-jdk-home option pointing to a (32-bit) JDK])
   371         kx                 fi
   371         kx                 ;;
   371         kx         esac
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checks for JDK.
   371         kx dnl ===================================================================
   371         kx 
   371         kx # Whether all the complexity here actually is needed any more or not, no idea.
   371         kx 
   371         kx JDK_SECURITYMANAGER_DISALLOWED=
   371         kx if test "$ENABLE_JAVA" != "" -a "$cross_compiling" != "yes"; then
   371         kx     _gij_longver=0
   371         kx     AC_MSG_CHECKING([the installed JDK])
   371         kx     if test -n "$JAVAINTERPRETER"; then
   371         kx         dnl java -version sends output to stderr!
   371         kx         if test `$JAVAINTERPRETER -version 2>&1 | $GREP -c "Kaffe"` -gt 0; then
   371         kx             AC_MSG_ERROR([No valid check available. Please check the block for your desired java in configure.ac])
   371         kx         elif test `$JAVAINTERPRETER --version 2>&1 | $GREP -c "GNU libgcj"` -gt 0; then
   371         kx             AC_MSG_ERROR([No valid check available. Please check the block for your desired java in configure.ac])
   371         kx         elif test `$JAVAINTERPRETER -version 2>&1 | $AWK '{ print }' | $GREP -c "BEA"` -gt 0; then
   371         kx             AC_MSG_ERROR([No valid check available. Please check the block for your desired java in configure.ac])
   371         kx         elif test `$JAVAINTERPRETER -version 2>&1 | $AWK '{ print }' | $GREP -c "IBM"` -gt 0; then
   371         kx             AC_MSG_ERROR([No valid check available. Please check the block for your desired java in configure.ac])
   371         kx         else
   371         kx             JDK=sun
   371         kx 
   371         kx             dnl Sun JDK specific tests
   371         kx             _jdk=`$JAVAINTERPRETER -version 2>&1 | $AWK -F'"' '{ print \$2 }' | $SED '/^$/d' | $SED s/[[-A-Za-z]]*//`
   371         kx             _jdk_ver=`echo "$_jdk" | $AWK -F. '{ print (($1 * 100) + $2) * 100 + $3;}'`
   371         kx 
   371         kx             if test "$_jdk_ver" -lt 170000; then
   371         kx                 AC_MSG_ERROR([JDK is too old, you need at least 17 ($_jdk_ver < 170000)])
   371         kx             fi
   371         kx             dnl TODO: Presumably, the Security Manager will not merely be disallowed, but be
   371         kx             dnl completely removed in some Java version > 18 (see
   371         kx             dnl <https://openjdk.java.net/jeps/411> "Deprecate the Security Manager for Removal"):
   371         kx             if test "$_jdk_ver" -ge 180000; then
   371         kx                 JDK_SECURITYMANAGER_DISALLOWED=TRUE
   371         kx             fi
   371         kx 
   371         kx             JAVA_HOME=`echo $JAVAINTERPRETER | $SED -n "s,//*bin//*java,,p"`
   371         kx             if test "$_os" = "WINNT"; then
   371         kx                 JAVA_HOME=`echo $JAVA_HOME | $SED "s,\.[[eE]][[xX]][[eE]]$,,"`
   371         kx             fi
   371         kx             AC_MSG_RESULT([found $JAVA_HOME (JDK $_jdk)])
   371         kx 
   371         kx             # set to limit VM usage for JunitTests
   371         kx             JAVAIFLAGS=-Xmx64M
   371         kx             # set to limit VM usage for javac
   371         kx             JAVACFLAGS=-J-Xmx128M
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_ERROR([Java not found. You need at least JDK 17])
   371         kx     fi
   371         kx else
   371         kx     if test -z "$ENABLE_JAVA"; then
   371         kx         dnl Java disabled
   371         kx         JAVA_HOME=
   371         kx         export JAVA_HOME
   371         kx     elif test "$cross_compiling" = "yes"; then
   371         kx         # Just assume compatibility of build and host JDK
   371         kx         JDK=$JDK_FOR_BUILD
   371         kx         JAVAIFLAGS=$JAVAIFLAGS_FOR_BUILD
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checks for javac
   371         kx dnl ===================================================================
   371         kx if test "$ENABLE_JAVA" != "" -a "$cross_compiling" != "yes"; then
   371         kx     javacompiler="javac"
   371         kx     : ${JAVA_SOURCE_VER=8}
   371         kx     : ${JAVA_TARGET_VER=8}
   371         kx     if test -z "$with_jdk_home"; then
   371         kx         AC_PATH_PROG(JAVACOMPILER, $javacompiler)
   371         kx     else
   371         kx         _javac_path="$with_jdk_home/bin/$javacompiler"
   371         kx         dnl Check if there is a Java compiler at all.
   371         kx         if test -x "$_javac_path"; then
   371         kx             JAVACOMPILER=$_javac_path
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$JAVACOMPILER"; then
   371         kx         AC_MSG_ERROR([$javacompiler not found set with_jdk_home])
   371         kx     fi
   371         kx     if test "$build_os" = "cygwin"; then
   371         kx         if test x`echo "$JAVACOMPILER" | $GREP -i '\.exe$'` = x; then
   371         kx             JAVACOMPILER="${JAVACOMPILER}.exe"
   371         kx         fi
   371         kx         JAVACOMPILER=`win_short_path_for_make "$JAVACOMPILER"`
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checks for javadoc
   371         kx dnl ===================================================================
   371         kx if test "$ENABLE_JAVA" != "" -a "$cross_compiling" != "yes"; then
   371         kx     if test -z "$with_jdk_home"; then
   371         kx         AC_PATH_PROG(JAVADOC, javadoc)
   371         kx     else
   371         kx         _javadoc_path="$with_jdk_home/bin/javadoc"
   371         kx         dnl Check if there is a javadoc at all.
   371         kx         if test -x "$_javadoc_path"; then
   371         kx             JAVADOC=$_javadoc_path
   371         kx         else
   371         kx             AC_PATH_PROG(JAVADOC, javadoc)
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$JAVADOC"; then
   371         kx         AC_MSG_ERROR([$_javadoc_path not found set with_jdk_home])
   371         kx     fi
   371         kx     if test "$build_os" = "cygwin"; then
   371         kx         if test x`echo "$JAVADOC" | $GREP -i '\.exe$'` = x; then
   371         kx             JAVADOC="${JAVADOC}.exe"
   371         kx         fi
   371         kx         JAVADOC=`win_short_path_for_make "$JAVADOC"`
   371         kx     fi
   371         kx 
   371         kx     if test `$JAVADOC --version 2>&1 | $GREP -c "gjdoc"` -gt 0; then
   371         kx     JAVADOCISGJDOC="yes"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(JAVADOC)
   371         kx AC_SUBST(JAVADOCISGJDOC)
   371         kx 
   371         kx if test "$ENABLE_JAVA" != "" -a \( "$cross_compiling" != "yes" -o -n "$with_jdk_home" \); then
   371         kx     # check if JAVA_HOME was (maybe incorrectly?) set automatically to /usr
   371         kx     if test "$JAVA_HOME" = "/usr" -a "x$with_jdk_home" = "x"; then
   371         kx         if basename $(readlink $(readlink $JAVACOMPILER)) >/dev/null 2>/dev/null; then
   371         kx            # try to recover first by looking whether we have an alternative
   371         kx            # system as in Debian or newer SuSEs where following /usr/bin/javac
   371         kx            # over /etc/alternatives/javac leads to the right bindir where we
   371         kx            # just need to strip a bit away to get a valid JAVA_HOME
   371         kx            JAVA_HOME=$(readlink $(readlink $JAVACOMPILER))
   371         kx         elif readlink $JAVACOMPILER >/dev/null 2>/dev/null; then
   371         kx             # maybe only one level of symlink (e.g. on Mac)
   371         kx             JAVA_HOME=$(readlink $JAVACOMPILER)
   371         kx             if test "$(dirname $JAVA_HOME)" = "."; then
   371         kx                 # we've got no path to trim back
   371         kx                 JAVA_HOME=""
   371         kx             fi
   371         kx         else
   371         kx             # else warn
   371         kx             AC_MSG_WARN([JAVA_HOME is set to /usr - this is very likely to be incorrect])
   371         kx             AC_MSG_WARN([if this is the case, please inform the correct JAVA_HOME with --with-jdk-home])
   371         kx             add_warning "JAVA_HOME is set to /usr - this is very likely to be incorrect"
   371         kx             add_warning "if this is the case, please inform the correct JAVA_HOME with --with-jdk-home"
   371         kx         fi
   371         kx         dnl now that we probably have the path to the real javac, make a JAVA_HOME out of it...
   371         kx         if test "$JAVA_HOME" != "/usr"; then
   371         kx             if test "$_os" = "Darwin" -o "$OS_FOR_BUILD" = MACOSX; then
   371         kx                 dnl Leopard returns a non-suitable path with readlink - points to "Current" only
   371         kx                 JAVA_HOME=$(echo $JAVA_HOME | $SED -e s,/Current/Commands/javac$,/CurrentJDK/Home,)
   371         kx                 dnl Tiger already returns a JDK path...
   371         kx                 JAVA_HOME=$(echo $JAVA_HOME | $SED -e s,/CurrentJDK/Commands/javac$,/CurrentJDK/Home,)
   371         kx             else
   371         kx                 JAVA_HOME=$(echo $JAVA_HOME | $SED -e s,/bin/javac$,,)
   371         kx                 dnl check that we have a directory as certain distros eg gentoo substitute javac for a script
   371         kx                 dnl that checks which version to run
   371         kx                 if test -f "$JAVA_HOME"; then
   371         kx                     JAVA_HOME=""; # set JAVA_HOME to null if it's a file
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx     # as we drop out of this, JAVA_HOME may have been set to the empty string by readlink
   371         kx 
   371         kx     dnl now if JAVA_HOME has been set to empty, then call findhome to find it
   371         kx     if test -z "$JAVA_HOME"; then
   371         kx         if test "x$with_jdk_home" = "x"; then
   371         kx             cat > findhome.java <<_ACEOF
   371         kx [import java.io.File;
   371         kx 
   371         kx class findhome
   371         kx {
   371         kx     public static void main(String args[])
   371         kx     {
   371         kx         String jrelocation = System.getProperty("java.home");
   371         kx         File jre = new File(jrelocation);
   371         kx         System.out.println(jre.getParent());
   371         kx     }
   371         kx }]
   371         kx _ACEOF
   371         kx             AC_MSG_CHECKING([if javac works])
   371         kx             javac_cmd="$JAVACOMPILER findhome.java 1>&2"
   371         kx             AC_TRY_EVAL(javac_cmd)
   371         kx             if test $? = 0 -a -f ./findhome.class; then
   371         kx                 AC_MSG_RESULT([javac works])
   371         kx             else
   371         kx                 echo "configure: javac test failed" >&5
   371         kx                 cat findhome.java >&5
   371         kx                 AC_MSG_ERROR([javac does not work - java projects will not build!])
   371         kx             fi
   371         kx             AC_MSG_CHECKING([if gij knows its java.home])
   371         kx             JAVA_HOME=`$JAVAINTERPRETER findhome`
   371         kx             if test $? = 0 -a "$JAVA_HOME" != ""; then
   371         kx                 AC_MSG_RESULT([$JAVA_HOME])
   371         kx             else
   371         kx                 echo "configure: java test failed" >&5
   371         kx                 cat findhome.java >&5
   371         kx                 AC_MSG_ERROR([gij does not know its java.home - use --with-jdk-home])
   371         kx             fi
   371         kx             # clean-up after ourselves
   371         kx             rm -f ./findhome.java ./findhome.class
   371         kx         else
   371         kx             JAVA_HOME=`echo $JAVAINTERPRETER | $SED -n "s,//*bin//*$with_java,,p"`
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     # now check if $JAVA_HOME is really valid
   371         kx     if test "$_os" = "Darwin" -o "$OS_FOR_BUILD" = MACOSX; then
   371         kx         if test ! -f "$JAVA_HOME/lib/jvm.cfg" -a "x$with_jdk_home" = "x"; then
   371         kx             AC_MSG_WARN([JAVA_HOME was not explicitly informed with --with-jdk-home. the configure script])
   371         kx             AC_MSG_WARN([attempted to find JAVA_HOME automatically, but apparently it failed])
   371         kx             AC_MSG_WARN([in case JAVA_HOME is incorrectly set, some projects will not be built correctly])
   371         kx             add_warning "JAVA_HOME was not explicitly informed with --with-jdk-home. the configure script"
   371         kx             add_warning "attempted to find JAVA_HOME automatically, but apparently it failed"
   371         kx             add_warning "in case JAVA_HOME is incorrectly set, some projects will not be built correctly"
   371         kx         fi
   371         kx     fi
   371         kx     PathFormat "$JAVA_HOME"
   371         kx     JAVA_HOME="$formatted_path"
   371         kx fi
   371         kx 
   371         kx if test -z "$JAWTLIB" -a -n "$ENABLE_JAVA" -a "$_os" != Android -a \
   371         kx     "$_os" != Darwin
   371         kx then
   371         kx     AC_MSG_CHECKING([for JAWT lib])
   371         kx     if test "$_os" = WINNT; then
   371         kx         # The path to $JAVA_HOME/lib/$JAWTLIB is part of $ILIB:
   371         kx         JAWTLIB=jawt.lib
   371         kx     else
   371         kx         case "$host_cpu" in
   371         kx         arm*)
   371         kx             AS_IF([test -e "$JAVA_HOME/jre/lib/aarch32/libjawt.so"], [my_java_arch=aarch32], [my_java_arch=arm])
   371         kx             JAVA_ARCH=$my_java_arch
   371         kx             ;;
   371         kx         i*86)
   371         kx             my_java_arch=i386
   371         kx             ;;
   371         kx         m68k)
   371         kx             my_java_arch=m68k
   371         kx             ;;
   371         kx         powerpc)
   371         kx             my_java_arch=ppc
   371         kx             ;;
   371         kx         powerpc64)
   371         kx             my_java_arch=ppc64
   371         kx             ;;
   371         kx         powerpc64le)
   371         kx             AS_IF([test -e "$JAVA_HOME/jre/lib/ppc64le/libjawt.so"], [my_java_arch=ppc64le], [my_java_arch=ppc64])
   371         kx             JAVA_ARCH=$my_java_arch
   371         kx             ;;
   371         kx         sparc64)
   371         kx             my_java_arch=sparcv9
   371         kx             ;;
   371         kx         x86_64)
   371         kx             my_java_arch=amd64
   371         kx             ;;
   371         kx         *)
   371         kx             my_java_arch=$host_cpu
   371         kx             ;;
   371         kx         esac
   371         kx         # This is where JDK9 puts the library
   371         kx         if test -e "$JAVA_HOME/lib/libjawt.so"; then
   371         kx             JAWTLIB="-L$JAVA_HOME/lib/ -ljawt"
   371         kx         else
   371         kx             JAWTLIB="-L$JAVA_HOME/jre/lib/$my_java_arch -ljawt"
   371         kx         fi
   371         kx         AS_IF([test "$JAVA_ARCH" != ""], [AC_DEFINE_UNQUOTED([JAVA_ARCH], ["$JAVA_ARCH"])])
   371         kx     fi
   371         kx     AC_MSG_RESULT([$JAWTLIB])
   371         kx fi
   371         kx AC_SUBST(JAWTLIB)
   371         kx 
   371         kx if test -n "$ENABLE_JAVA" -a -z "$JAVAINC"; then
   371         kx     case "$host_os" in
   371         kx 
   371         kx     cygwin*|wsl*)
   371         kx         JAVAINC="-I$JAVA_HOME/include/win32"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include"
   371         kx         ;;
   371         kx 
   371         kx     darwin*)
   371         kx         if test -d "$JAVA_HOME/include/darwin"; then
   371         kx             JAVAINC="-I$JAVA_HOME/include  -I$JAVA_HOME/include/darwin"
   371         kx         else
   371         kx             JAVAINC=${ISYSTEM}$FRAMEWORKSHOME/JavaVM.framework/Versions/Current/Headers
   371         kx         fi
   371         kx         ;;
   371         kx 
   371         kx     dragonfly*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx 
   371         kx     freebsd*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/freebsd"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/bsd"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/linux"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx 
   371         kx     k*bsd*-gnu*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/linux"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx 
   371         kx     linux-gnu*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/linux"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx 
   371         kx     *netbsd*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/netbsd"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx        ;;
   371         kx 
   371         kx     openbsd*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/openbsd"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx 
   371         kx     solaris*)
   371         kx         JAVAINC="-I$JAVA_HOME/include"
   371         kx         JAVAINC="$JAVAINC -I$JAVA_HOME/include/solaris"
   371         kx         test -d "$JAVA_HOME/include/native_thread" && JAVAINC="$JAVAINC -I$JAVA_HOME/include/native_thread"
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx SOLARINC="$SOLARINC $JAVAINC"
   371         kx 
   371         kx if test "$ENABLE_JAVA" != "" -a "$cross_compiling" != "yes"; then
   371         kx     JAVA_HOME_FOR_BUILD=$JAVA_HOME
   371         kx     JAVAIFLAGS_FOR_BUILD=$JAVAIFLAGS
   371         kx     JDK_FOR_BUILD=$JDK
   371         kx     JDK_SECURITYMANAGER_DISALLOWED_FOR_BUILD=$JDK_SECURITYMANAGER_DISALLOWED
   371         kx fi
   371         kx 
   371         kx AC_SUBST(JAVACFLAGS)
   371         kx AC_SUBST(JAVACOMPILER)
   371         kx AC_SUBST(JAVAINTERPRETER)
   371         kx AC_SUBST(JAVAIFLAGS)
   371         kx AC_SUBST(JAVAIFLAGS_FOR_BUILD)
   371         kx AC_SUBST(JAVA_HOME)
   371         kx AC_SUBST(JAVA_HOME_FOR_BUILD)
   371         kx AC_SUBST(JDK)
   371         kx AC_SUBST(JDK_FOR_BUILD)
   371         kx AC_SUBST(JDK_SECURITYMANAGER_DISALLOWED_FOR_BUILD)
   371         kx AC_SUBST(JAVA_SOURCE_VER)
   371         kx AC_SUBST(JAVA_TARGET_VER)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Export file validation
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable export file validation])
   371         kx if test "$with_export_validation" != "no"; then
   371         kx     if test -z "$ENABLE_JAVA"; then
   371         kx         if test "$with_export_validation" = "yes"; then
   371         kx             AC_MSG_ERROR([requested, but Java is disabled])
   371         kx         else
   371         kx             AC_MSG_RESULT([no, as Java is disabled])
   371         kx         fi
   371         kx     elif ! test -d "${SRC_ROOT}/schema"; then
   371         kx         if test "$with_export_validation" = "yes"; then
   371         kx             AC_MSG_ERROR([requested, but schema directory is missing (it is excluded from tarballs)])
   371         kx         else
   371         kx             AC_MSG_RESULT([no, schema directory is missing (it is excluded from tarballs)])
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx         AC_DEFINE(HAVE_EXPORT_VALIDATION)
   371         kx 
   371         kx         AC_PATH_PROGS(ODFVALIDATOR, odfvalidator)
   371         kx         if test -z "$ODFVALIDATOR"; then
   371         kx             # remember to download the ODF toolkit with validator later
   371         kx             AC_MSG_NOTICE([no odfvalidator found, will download it])
   371         kx             BUILD_TYPE="$BUILD_TYPE ODFVALIDATOR"
   371         kx             ODFVALIDATOR="$BUILDDIR/bin/odfvalidator.sh"
   371         kx 
   371         kx             # and fetch name of odfvalidator jar name from download.lst
   371         kx             ODFVALIDATOR_JAR=`$SED -n -e "s/^ODFVALIDATOR_JAR *:= *\(.*\) */\1/p" $SRC_ROOT/download.lst`
   371         kx             AC_SUBST(ODFVALIDATOR_JAR)
   371         kx 
   371         kx             if test -z "$ODFVALIDATOR_JAR"; then
   371         kx                 AC_MSG_ERROR([cannot determine odfvalidator jar location (--with-export-validation)])
   371         kx             fi
   371         kx         fi
   371         kx         if test "$build_os" = "cygwin"; then
   371         kx             # In case of Cygwin it will be executed from Windows,
   371         kx             # so we need to run bash and absolute path to validator
   371         kx             # so instead of "odfvalidator" it will be
   371         kx             # something like "bash.exe C:\cygwin\opt\lo\bin\odfvalidator"
   371         kx             ODFVALIDATOR="bash.exe `cygpath -m "$ODFVALIDATOR"`"
   371         kx         else
   371         kx             ODFVALIDATOR="sh $ODFVALIDATOR"
   371         kx         fi
   371         kx         AC_SUBST(ODFVALIDATOR)
   371         kx 
   371         kx 
   371         kx         AC_PATH_PROGS(OFFICEOTRON, officeotron)
   371         kx         if test -z "$OFFICEOTRON"; then
   371         kx             # remember to download the officeotron with validator later
   371         kx             AC_MSG_NOTICE([no officeotron found, will download it])
   371         kx             BUILD_TYPE="$BUILD_TYPE OFFICEOTRON"
   371         kx             OFFICEOTRON="$BUILDDIR/bin/officeotron.sh"
   371         kx 
   371         kx             # and fetch name of officeotron jar name from download.lst
   371         kx             OFFICEOTRON_JAR=`$SED -n -e "s/^OFFICEOTRON_JAR *:= *\(.*\) */\1/p" $SRC_ROOT/download.lst`
   371         kx             AC_SUBST(OFFICEOTRON_JAR)
   371         kx 
   371         kx             if test -z "$OFFICEOTRON_JAR"; then
   371         kx                 AC_MSG_ERROR([cannot determine officeotron jar location (--with-export-validation)])
   371         kx             fi
   371         kx         else
   371         kx             # check version of existing officeotron
   371         kx             OFFICEOTRON_VER=`$OFFICEOTRON --version | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
   371         kx             if test 0"$OFFICEOTRON_VER" -lt 704; then
   371         kx                 AC_MSG_ERROR([officeotron too old])
   371         kx             fi
   371         kx         fi
   371         kx         if test "$build_os" = "cygwin"; then
   371         kx             # In case of Cygwin it will be executed from Windows,
   371         kx             # so we need to run bash and absolute path to validator
   371         kx             # so instead of "odfvalidator" it will be
   371         kx             # something like "bash.exe C:\cygwin\opt\lo\bin\odfvalidator"
   371         kx             OFFICEOTRON="bash.exe `cygpath -m "$OFFICEOTRON"`"
   371         kx         else
   371         kx             OFFICEOTRON="sh $OFFICEOTRON"
   371         kx         fi
   371         kx     fi
   371         kx     AC_SUBST(OFFICEOTRON)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([for Microsoft Binary File Format Validator])
   371         kx if test "$with_bffvalidator" != "no"; then
   371         kx     AC_DEFINE(HAVE_BFFVALIDATOR)
   371         kx 
   371         kx     if test "$with_export_validation" = "no"; then
   371         kx         AC_MSG_ERROR([Please enable export validation (-with-export-validation)!])
   371         kx     fi
   371         kx 
   371         kx     if test "$with_bffvalidator" = "yes"; then
   371         kx         BFFVALIDATOR=`win_short_path_for_make "$PROGRAMFILES/Microsoft Office/BFFValidator/BFFValidator.exe"`
   371         kx     else
   371         kx         BFFVALIDATOR="$with_bffvalidator"
   371         kx     fi
   371         kx 
   371         kx     if test "$build_os" = "cygwin"; then
   371         kx         if test -n "$BFFVALIDATOR" -a -e "`cygpath $BFFVALIDATOR`"; then
   371         kx             AC_MSG_RESULT($BFFVALIDATOR)
   371         kx         else
   371         kx             AC_MSG_ERROR([bffvalidator not found, but required by --with-bffvalidator])
   371         kx         fi
   371         kx     elif test -n "$BFFVALIDATOR"; then
   371         kx         # We are not in Cygwin but need to run Windows binary with wine
   371         kx         AC_PATH_PROGS(WINE, wine)
   371         kx 
   371         kx         # so swap in a shell wrapper that converts paths transparently
   371         kx         BFFVALIDATOR_EXE="$BFFVALIDATOR"
   371         kx         BFFVALIDATOR="sh $BUILDDIR/bin/bffvalidator.sh"
   371         kx         AC_SUBST(BFFVALIDATOR_EXE)
   371         kx         AC_MSG_RESULT($BFFVALIDATOR)
   371         kx     else
   371         kx         AC_MSG_ERROR([bffvalidator not found, but required by --with-bffvalidator])
   371         kx     fi
   371         kx     AC_SUBST(BFFVALIDATOR)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for epm (not needed for Windows)
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable EPM for packing])
   371         kx if test "$enable_epm" = "yes"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     if test "$_os" != "WINNT"; then
   371         kx         if test $_os = Darwin; then
   371         kx             EPM=internal
   371         kx         elif test -n "$with_epm"; then
   371         kx             EPM=$with_epm
   371         kx         else
   371         kx             AC_PATH_PROG(EPM, epm, no)
   371         kx         fi
   371         kx         if test "$EPM" = "no" -o "$EPM" = "internal"; then
   371         kx             AC_MSG_NOTICE([EPM will be built.])
   371         kx             BUILD_TYPE="$BUILD_TYPE EPM"
   371         kx             EPM=${WORKDIR}/UnpackedTarball/epm/epm
   371         kx         else
   371         kx             # Gentoo has some epm which is something different...
   371         kx             AC_MSG_CHECKING([whether the found epm is the right epm])
   371         kx             if $EPM | grep "ESP Package Manager" >/dev/null 2>/dev/null; then
   371         kx                 AC_MSG_RESULT([yes])
   371         kx             else
   371         kx                 AC_MSG_ERROR([no. Install ESP Package Manager (https://jimjag.github.io/epm/) and/or specify the path to the right epm])
   371         kx             fi
   371         kx             AC_MSG_CHECKING([epm version])
   371         kx             EPM_VERSION=`$EPM | grep 'ESP Package Manager' | cut -d' ' -f4 | $SED -e s/v//`
   371         kx             if test "`echo $EPM_VERSION | cut -d'.' -f1`" -gt "3" || \
   371         kx                test "`echo $EPM_VERSION | cut -d'.' -f1`" -eq "3" -a "`echo $EPM_VERSION | cut -d'.' -f2`" -ge "7"; then
   371         kx                 AC_MSG_RESULT([OK, >= 3.7])
   371         kx             else
   371         kx                 AC_MSG_RESULT([too old. epm >= 3.7 is required.])
   371         kx                 AC_MSG_ERROR([Install ESP Package Manager (https://jimjag.github.io/epm/) and/or specify the path to the right epm])
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     if echo "$PKGFORMAT" | $EGREP rpm 2>&1 >/dev/null; then
   371         kx         AC_MSG_CHECKING([for rpm])
   371         kx         for a in "$RPM" rpmbuild rpm; do
   371         kx             $a --usage >/dev/null 2> /dev/null
   371         kx             if test $? -eq 0; then
   371         kx                 RPM=$a
   371         kx                 break
   371         kx             else
   371         kx                 $a --version >/dev/null 2> /dev/null
   371         kx                 if test $? -eq 0; then
   371         kx                     RPM=$a
   371         kx                     break
   371         kx                 fi
   371         kx             fi
   371         kx         done
   371         kx         if test -z "$RPM"; then
   371         kx             AC_MSG_ERROR([not found])
   371         kx         elif "$RPM" --help 2>&1 | $EGREP buildroot >/dev/null; then
   371         kx             RPM_PATH=`which $RPM`
   371         kx             AC_MSG_RESULT([$RPM_PATH])
   371         kx             SCPDEFS="$SCPDEFS -DWITH_RPM"
   371         kx         else
   371         kx             AC_MSG_ERROR([cannot build packages. Try installing rpmbuild.])
   371         kx         fi
   371         kx     fi
   371         kx     if echo "$PKGFORMAT" | $EGREP deb 2>&1 >/dev/null; then
   371         kx         AC_PATH_PROG(DPKG, dpkg, no)
   371         kx         if test "$DPKG" = "no"; then
   371         kx             AC_MSG_ERROR([dpkg needed for deb creation. Install dpkg.])
   371         kx         fi
   371         kx     fi
   371         kx     if echo "$PKGFORMAT" | $EGREP rpm 2>&1 >/dev/null || \
   371         kx        echo "$PKGFORMAT" | $EGREP pkg 2>&1 >/dev/null; then
   371         kx         if test "$with_epm" = "no" -a "$_os" != "Darwin"; then
   371         kx             if test "`echo $EPM_VERSION | cut -d'.' -f1`" -lt "4"; then
   371         kx                 AC_MSG_CHECKING([whether epm is patched for LibreOffice's needs])
   371         kx                 if grep "Patched for .*Office" $EPM >/dev/null 2>/dev/null; then
   371         kx                     AC_MSG_RESULT([yes])
   371         kx                 else
   371         kx                     AC_MSG_RESULT([no])
   371         kx                     if echo "$PKGFORMAT" | $GREP -q rpm; then
   371         kx                         _pt="rpm"
   371         kx                         AC_MSG_WARN([the rpms will need to be installed with --nodeps])
   371         kx                         add_warning "the rpms will need to be installed with --nodeps"
   371         kx                     else
   371         kx                         _pt="pkg"
   371         kx                     fi
   371         kx                     AC_MSG_WARN([the ${_pt}s will not be relocatable])
   371         kx                     add_warning "the ${_pt}s will not be relocatable"
   371         kx                     AC_MSG_WARN([if you want to make sure installation without --nodeps and
   371         kx                                  relocation will work, you need to patch your epm with the
   371         kx                                  patch in epm/epm-3.7.patch or build with
   371         kx                                  --with-epm=internal which will build a suitable epm])
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx     if echo "$PKGFORMAT" | $EGREP pkg 2>&1 >/dev/null; then
   371         kx         AC_PATH_PROG(PKGMK, pkgmk, no)
   371         kx         if test "$PKGMK" = "no"; then
   371         kx             AC_MSG_ERROR([pkgmk needed for Solaris pkg creation. Install it.])
   371         kx         fi
   371         kx     fi
   371         kx     AC_SUBST(RPM)
   371         kx     AC_SUBST(DPKG)
   371         kx     AC_SUBST(PKGMK)
   371         kx else
   371         kx     for i in $PKGFORMAT; do
   371         kx         case "$i" in
   371         kx         bsd | deb | pkg | rpm | native | portable)
   371         kx             AC_MSG_ERROR(
   371         kx                 [--with-package-format='$PKGFORMAT' requires --enable-epm])
   371         kx             ;;
   371         kx         esac
   371         kx     done
   371         kx     AC_MSG_RESULT([no])
   371         kx     EPM=NO
   371         kx fi
   371         kx AC_SUBST(EPM)
   371         kx 
   371         kx ENABLE_LWP=
   371         kx if test "$enable_lotuswordpro" = "yes"; then
   371         kx     ENABLE_LWP="TRUE"
   371         kx fi
   371         kx AC_SUBST(ENABLE_LWP)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for building ODK
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to build the ODK])
   371         kx if test "$enable_odk" = yes; then
   371         kx     if test "$DISABLE_DYNLOADING" = TRUE; then
   371         kx         AC_MSG_ERROR([can't build ODK for --disable-dynamic-loading builds])
   371         kx     fi
   371         kx     AC_MSG_RESULT([yes])
   371         kx     BUILD_TYPE="$BUILD_TYPE ODK"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx if test "$enable_odk" != yes; then
   371         kx     unset DOXYGEN
   371         kx else
   371         kx     if test "$with_doxygen" = no; then
   371         kx         AC_MSG_CHECKING([for doxygen])
   371         kx         unset DOXYGEN
   371         kx         AC_MSG_RESULT([no])
   371         kx     else
   371         kx         if test "$with_doxygen" = yes; then
   371         kx             AC_PATH_PROG([DOXYGEN], [doxygen])
   371         kx             if test -z "$DOXYGEN"; then
   371         kx                 AC_MSG_ERROR([doxygen not found in \$PATH; specify its pathname via --with-doxygen=..., or disable its use via --without-doxygen])
   371         kx             fi
   371         kx             if $DOXYGEN -g - | grep -q "HAVE_DOT *= *YES"; then
   371         kx                 if ! dot -V 2>/dev/null; then
   371         kx                     AC_MSG_ERROR([dot not found in \$PATH but doxygen defaults to HAVE_DOT=YES; install graphviz or disable its use via --without-doxygen])
   371         kx                 fi
   371         kx             fi
   371         kx         else
   371         kx             AC_MSG_CHECKING([for doxygen])
   371         kx             DOXYGEN=$with_doxygen
   371         kx             AC_MSG_RESULT([$DOXYGEN])
   371         kx         fi
   371         kx         if test -n "$DOXYGEN"; then
   371         kx             DOXYGEN_VERSION=`$DOXYGEN --version 2>/dev/null`
   371         kx             DOXYGEN_NUMVERSION=`echo $DOXYGEN_VERSION | $AWK -F. '{ print \$1*10000 + \$2*100 + \$3 }'`
   371         kx             if ! test "$DOXYGEN_NUMVERSION" -ge "10804" ; then
   371         kx                 AC_MSG_ERROR([found doxygen is too old; need at least version 1.8.4 or specify --without-doxygen])
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([DOXYGEN])
   371         kx 
   371         kx dnl ==================================================================
   371         kx dnl libfuzzer
   371         kx dnl ==================================================================
   371         kx AC_MSG_CHECKING([whether to enable fuzzers])
   371         kx if test "$enable_fuzzers" != yes; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     if test -z $LIB_FUZZING_ENGINE; then
   371         kx       AC_MSG_ERROR(['LIB_FUZZING_ENGINE' must be set when using --enable-fuzzers. Examples include '-fsanitize=fuzzer'.])
   371         kx     fi
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_FUZZERS="TRUE"
   371         kx     AC_DEFINE([ENABLE_FUZZERS],1)
   371         kx     BUILD_TYPE="$BUILD_TYPE FUZZERS"
   371         kx fi
   371         kx AC_SUBST(LIB_FUZZING_ENGINE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system zlib
   371         kx dnl ===================================================================
   371         kx if test "$with_system_zlib" = "auto"; then
   371         kx     case "$_os" in
   371         kx     WINNT)
   371         kx         with_system_zlib="$with_system_libs"
   371         kx         ;;
   371         kx     *)
   371         kx         if test "$enable_fuzzers" != "yes"; then
   371         kx             with_system_zlib=yes
   371         kx         else
   371         kx             with_system_zlib=no
   371         kx         fi
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx dnl we want to use libo_CHECK_SYSTEM_MODULE here too, but macOS is too stupid
   371         kx dnl and has no pkg-config for it at least on some tinderboxes,
   371         kx dnl so leaving that out for now
   371         kx dnl libo_CHECK_SYSTEM_MODULE([zlib],[ZLIB],[zlib])
   371         kx AC_MSG_CHECKING([which zlib to use])
   371         kx if test "$with_system_zlib" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_ZLIB=TRUE
   371         kx     AC_CHECK_HEADER(zlib.h, [],
   371         kx         [AC_MSG_ERROR(zlib.h not found. install zlib)], [])
   371         kx     AC_CHECK_LIB(z, deflate, [ ZLIB_LIBS=-lz ],
   371         kx         [AC_MSG_ERROR(zlib not found or functional)], [])
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_ZLIB=
   371         kx     BUILD_TYPE="$BUILD_TYPE ZLIB"
   371         kx     ZLIB_CFLAGS="-I${WORKDIR}/UnpackedTarball/zlib"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         ZLIB_LIBS="${WORKDIR}/LinkTarget/StaticLibrary/zlib.lib"
   371         kx     else
   371         kx         ZLIB_LIBS="-L${WORKDIR}/LinkTarget/StaticLibrary -lzlib"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ZLIB_CFLAGS)
   371         kx AC_SUBST(ZLIB_LIBS)
   371         kx AC_SUBST(SYSTEM_ZLIB)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system jpeg
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which libjpeg to use])
   371         kx if test "$with_system_jpeg" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_LIBJPEG=TRUE
   371         kx     AC_CHECK_HEADER(jpeglib.h, [ LIBJPEG_CFLAGS= ],
   371         kx         [AC_MSG_ERROR(jpeg.h not found. install libjpeg)], [])
   371         kx     AC_CHECK_LIB(jpeg, jpeg_resync_to_restart, [ LIBJPEG_LIBS="-ljpeg" ],
   371         kx         [AC_MSG_ERROR(jpeg library not found or functional)], [])
   371         kx else
   371         kx     SYSTEM_LIBJPEG=
   371         kx     AC_MSG_RESULT([internal, libjpeg-turbo])
   371         kx     BUILD_TYPE="$BUILD_TYPE LIBJPEG_TURBO"
   371         kx 
   371         kx     case "$host_cpu" in
   371         kx     x86_64 | amd64 | i*86 | x86 | ia32)
   371         kx         AC_CHECK_PROGS(NASM, [nasm nasmw yasm])
   371         kx         if test -z "$NASM" -a "$build_os" = "cygwin"; then
   371         kx             if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/nasm"; then
   371         kx                 NASM="$LODE_HOME/opt/bin/nasm"
   371         kx             elif test -x "/opt/lo/bin/nasm"; then
   371         kx                 NASM="/opt/lo/bin/nasm"
   371         kx             fi
   371         kx         fi
   371         kx 
   371         kx         if test -n "$NASM"; then
   371         kx             AC_MSG_CHECKING([for object file format of host system])
   371         kx             case "$host_os" in
   371         kx               cygwin* | mingw* | pw32* | wsl*)
   371         kx                 case "$host_cpu" in
   371         kx                   x86_64)
   371         kx                     objfmt='Win64-COFF'
   371         kx                     ;;
   371         kx                   *)
   371         kx                     objfmt='Win32-COFF'
   371         kx                     ;;
   371         kx                 esac
   371         kx               ;;
   371         kx               msdosdjgpp* | go32*)
   371         kx                 objfmt='COFF'
   371         kx               ;;
   371         kx               os2-emx*) # not tested
   371         kx                 objfmt='MSOMF' # obj
   371         kx               ;;
   371         kx               linux*coff* | linux*oldld*)
   371         kx                 objfmt='COFF' # ???
   371         kx               ;;
   371         kx               linux*aout*)
   371         kx                 objfmt='a.out'
   371         kx               ;;
   371         kx               linux*)
   371         kx                 case "$host_cpu" in
   371         kx                   x86_64)
   371         kx                     objfmt='ELF64'
   371         kx                     ;;
   371         kx                   *)
   371         kx                     objfmt='ELF'
   371         kx                     ;;
   371         kx                 esac
   371         kx               ;;
   371         kx               kfreebsd* | freebsd* | netbsd* | openbsd*)
   371         kx                 if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then
   371         kx                   objfmt='BSD-a.out'
   371         kx                 else
   371         kx                   case "$host_cpu" in
   371         kx                     x86_64 | amd64)
   371         kx                       objfmt='ELF64'
   371         kx                       ;;
   371         kx                     *)
   371         kx                       objfmt='ELF'
   371         kx                       ;;
   371         kx                   esac
   371         kx                 fi
   371         kx               ;;
   371         kx               solaris* | sunos* | sysv* | sco*)
   371         kx                 case "$host_cpu" in
   371         kx                   x86_64)
   371         kx                     objfmt='ELF64'
   371         kx                     ;;
   371         kx                   *)
   371         kx                     objfmt='ELF'
   371         kx                     ;;
   371         kx                 esac
   371         kx               ;;
   371         kx               darwin* | rhapsody* | nextstep* | openstep* | macos*)
   371         kx                 case "$host_cpu" in
   371         kx                   x86_64)
   371         kx                     objfmt='Mach-O64'
   371         kx                     ;;
   371         kx                   *)
   371         kx                     objfmt='Mach-O'
   371         kx                     ;;
   371         kx                 esac
   371         kx               ;;
   371         kx               *)
   371         kx                 objfmt='ELF ?'
   371         kx               ;;
   371         kx             esac
   371         kx 
   371         kx             AC_MSG_RESULT([$objfmt])
   371         kx             if test "$objfmt" = 'ELF ?'; then
   371         kx               objfmt='ELF'
   371         kx               AC_MSG_WARN([unexpected host system. assumed that the format is $objfmt.])
   371         kx             fi
   371         kx 
   371         kx             AC_MSG_CHECKING([for object file format specifier (NAFLAGS) ])
   371         kx             case "$objfmt" in
   371         kx               MSOMF)      NAFLAGS='-fobj -DOBJ32 -DPIC';;
   371         kx               Win32-COFF) NAFLAGS='-fwin32 -DWIN32 -DPIC';;
   371         kx               Win64-COFF) NAFLAGS='-fwin64 -DWIN64 -D__x86_64__ -DPIC';;
   371         kx               COFF)       NAFLAGS='-fcoff -DCOFF -DPIC';;
   371         kx               a.out)      NAFLAGS='-faout -DAOUT -DPIC';;
   371         kx               BSD-a.out)  NAFLAGS='-faoutb -DAOUT -DPIC';;
   371         kx               ELF)        NAFLAGS='-felf -DELF -DPIC';;
   371         kx               ELF64)      NAFLAGS='-felf64 -DELF -D__x86_64__ -DPIC';;
   371         kx               RDF)        NAFLAGS='-frdf -DRDF -DPIC';;
   371         kx               Mach-O)     NAFLAGS='-fmacho -DMACHO -DPIC';;
   371         kx               Mach-O64)   NAFLAGS='-fmacho64 -DMACHO -D__x86_64__ -DPIC';;
   371         kx             esac
   371         kx             AC_MSG_RESULT([$NAFLAGS])
   371         kx 
   371         kx             AC_MSG_CHECKING([whether the assembler ($NASM $NAFLAGS) works])
   371         kx             cat > conftest.asm << EOF
   371         kx             [%line __oline__ "configure"
   371         kx                     section .text
   371         kx                     global  _main,main
   371         kx             _main:
   371         kx             main:   xor     eax,eax
   371         kx                     ret
   371         kx             ]
   371         kx EOF
   371         kx             try_nasm='$NASM $NAFLAGS -o conftest.o conftest.asm'
   371         kx             if AC_TRY_EVAL(try_nasm) && test -s conftest.o; then
   371         kx               AC_MSG_RESULT(yes)
   371         kx             else
   371         kx               echo "configure: failed program was:" >&AS_MESSAGE_LOG_FD
   371         kx               cat conftest.asm >&AS_MESSAGE_LOG_FD
   371         kx               rm -rf conftest*
   371         kx               AC_MSG_RESULT(no)
   371         kx               AC_MSG_WARN([installation or configuration problem: assembler cannot create object files.])
   371         kx               NASM=""
   371         kx             fi
   371         kx 
   371         kx         fi
   371         kx 
   371         kx         if test -z "$NASM"; then
   371         kx cat << _EOS
   371         kx ****************************************************************************
   371         kx You need yasm or nasm (Netwide Assembler) to build the internal jpeg library optimally.
   371         kx To get one please:
   371         kx 
   371         kx _EOS
   371         kx             if test "$build_os" = "cygwin"; then
   371         kx cat << _EOS
   371         kx install a pre-compiled binary for Win32
   371         kx 
   371         kx mkdir -p /opt/lo/bin
   371         kx cd /opt/lo/bin
   371         kx wget https://dev-www.libreoffice.org/bin/cygwin/nasm.exe
   371         kx chmod +x nasm
   371         kx 
   371         kx or get and install one from https://www.nasm.us/
   371         kx 
   371         kx Then re-run autogen.sh
   371         kx 
   371         kx Note: autogen.sh will try to use /opt/lo/bin/nasm if the environment variable NASM is not already defined.
   371         kx Alternatively, you can install the 'new' nasm where ever you want and make sure that \`which nasm\` finds it.
   371         kx 
   371         kx _EOS
   371         kx             else
   371         kx cat << _EOS
   371         kx consult https://github.com/libjpeg-turbo/libjpeg-turbo/blob/main/BUILDING.md
   371         kx 
   371         kx _EOS
   371         kx             fi
   371         kx             AC_MSG_WARN([no suitable nasm (Netwide Assembler) found])
   371         kx             add_warning "no suitable nasm (Netwide Assembler) found for internal libjpeg-turbo"
   371         kx         fi
   371         kx       ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx AC_SUBST(NASM)
   371         kx AC_SUBST(NAFLAGS)
   371         kx AC_SUBST(LIBJPEG_CFLAGS)
   371         kx AC_SUBST(LIBJPEG_LIBS)
   371         kx AC_SUBST(SYSTEM_LIBJPEG)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system clucene
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([clucene],[CLUCENE],[libclucene-core])
   371         kx if test "$SYSTEM_CLUCENE" = TRUE; then
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     save_CPPFLAGS=$CPPFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $CLUCENE_CFLAGS"
   371         kx     CPPFLAGS="$CPPFLAGS $CLUCENE_CFLAGS"
   371         kx     dnl https://sourceforge.net/p/clucene/bugs/200/
   371         kx     dnl https://bugzilla.redhat.com/show_bug.cgi?id=794795
   371         kx     AC_CHECK_HEADER([CLucene/analysis/cjk/CJKAnalyzer.h], [],
   371         kx                  [AC_MSG_ERROR([Your version of libclucene has contribs-lib missing.])], [#include <CLucene.h>])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     CPPFLAGS=$save_CPPFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx     CLUCENE_LIBS="$CLUCENE_LIBS -lclucene-contribs-lib"
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system expat
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([expat], [EXPAT], [expat])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system xmlsec
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([xmlsec], [XMLSEC], [xmlsec1-nss >= 1.2.35])
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable Embedded OpenType support])
   371         kx if test "$enable_eot" = "yes"; then
   371         kx     ENABLE_EOT="TRUE"
   371         kx     AC_DEFINE([ENABLE_EOT])
   371         kx     AC_MSG_RESULT([yes])
   371         kx 
   371         kx     libo_CHECK_SYSTEM_MODULE([libeot],[LIBEOT],[libeot >= 0.01])
   371         kx else
   371         kx     ENABLE_EOT=
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST([ENABLE_EOT])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for DLP libs
   371         kx dnl ===================================================================
   371         kx REVENGE_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/librevenge/inc"
   371         kx AS_IF([test "$COM" = "MSC"],
   371         kx       [librevenge_libdir="${WORKDIR}/LinkTarget/Library"],
   371         kx       [librevenge_libdir="${WORKDIR}/UnpackedTarball/librevenge/src/lib/.libs"]
   371         kx )
   371         kx REVENGE_LIBS_internal="-L${librevenge_libdir} -lrevenge-0.0"
   371         kx libo_CHECK_SYSTEM_MODULE([librevenge],[REVENGE],[librevenge-0.0 >= 0.0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libodfgen],[ODFGEN],[libodfgen-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libepubgen],[EPUBGEN],[libepubgen-0.1])
   371         kx 
   371         kx WPD_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/libwpd/inc"
   371         kx AS_IF([test "$COM" = "MSC"],
   371         kx       [libwpd_libdir="${WORKDIR}/LinkTarget/Library"],
   371         kx       [libwpd_libdir="${WORKDIR}/UnpackedTarball/libwpd/src/lib/.libs"]
   371         kx )
   371         kx WPD_LIBS_internal="-L${libwpd_libdir} -lwpd-0.10"
   371         kx libo_CHECK_SYSTEM_MODULE([libwpd],[WPD],[libwpd-0.10])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libwpg],[WPG],[libwpg-0.3])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libwps],[WPS],[libwps-0.4])
   371         kx libo_PKG_VERSION([WPS], [libwps-0.4], [0.4.14])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libvisio],[VISIO],[libvisio-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libcdr],[CDR],[libcdr-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libmspub],[MSPUB],[libmspub-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libmwaw],[MWAW],[libmwaw-0.3 >= 0.3.21])
   371         kx libo_PKG_VERSION([MWAW], [libmwaw-0.3], [0.3.21])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libetonyek],[ETONYEK],[libetonyek-0.1])
   371         kx libo_PKG_VERSION([ETONYEK], [libetonyek-0.1], [0.1.10])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libfreehand],[FREEHAND],[libfreehand-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libebook],[EBOOK],[libe-book-0.1])
   371         kx libo_PKG_VERSION([EBOOK], [libe-book-0.1], [0.1.2])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libabw],[ABW],[libabw-0.1])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libpagemaker],[PAGEMAKER],[libpagemaker-0.0])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libqxp],[QXP],[libqxp-0.0])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libzmf],[ZMF],[libzmf-0.0])
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libstaroffice],[STAROFFICE],[libstaroffice-0.0])
   371         kx libo_PKG_VERSION([STAROFFICE], [libstaroffice-0.0], [0.0.7])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system lcms2
   371         kx dnl ===================================================================
   371         kx if test "$with_system_lcms2" != "yes"; then
   371         kx     SYSTEM_LCMS2=
   371         kx fi
   371         kx LCMS2_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/lcms2/include"
   371         kx LCMS2_LIBS_internal="-L${WORKDIR}/UnpackedTarball/lcms2/src/.libs -llcms2"
   371         kx libo_CHECK_SYSTEM_MODULE([lcms2],[LCMS2],[lcms2])
   371         kx if test "$GCC" = "yes"; then
   371         kx     LCMS2_CFLAGS="${LCMS2_CFLAGS} -Wno-long-long"
   371         kx fi
   371         kx if test "$COM" = "MSC"; then # override the above
   371         kx     LCMS2_LIBS=${WORKDIR}/UnpackedTarball/lcms2/bin/lcms2.lib
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system cppunit
   371         kx dnl ===================================================================
   371         kx if test "$_os" != "Android" ; then
   371         kx     libo_CHECK_SYSTEM_MODULE([cppunit],[CPPUNIT],[cppunit >= 1.14.0])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check whether freetype is available
   371         kx dnl
   371         kx dnl FreeType has 3 different kinds of versions
   371         kx dnl * release, like 2.4.10
   371         kx dnl * libtool, like 13.0.7 (this what pkg-config returns)
   371         kx dnl * soname
   371         kx dnl FreeType's docs/VERSION.DLL provides a table mapping between the three
   371         kx dnl
   371         kx dnl 9.9.3 is 2.2.0
   371         kx dnl When the minimal version is at least 2.8.1, remove Skia's check down below.
   371         kx dnl ===================================================================
   371         kx FREETYPE_CFLAGS_internal="${ISYSTEM}${WORKDIR}/UnpackedTarball/freetype/include"
   371         kx if test "x$ac_config_site_64bit_host" = xYES; then
   371         kx     FREETYPE_LIBS_internal="-L${WORKDIR}/UnpackedTarball/freetype/instdir/lib64 -lfreetype"
   371         kx else
   371         kx     FREETYPE_LIBS_internal="-L${WORKDIR}/UnpackedTarball/freetype/instdir/lib -lfreetype"
   371         kx fi
   371         kx libo_CHECK_SYSTEM_MODULE([freetype],[FREETYPE],[freetype2 >= 9.9.3],,system,TRUE)
   371         kx 
   371         kx # ===================================================================
   371         kx # Check for system libxslt
   371         kx # to prevent incompatibilities between internal libxml2 and external libxslt,
   371         kx # or vice versa, use with_system_libxml here
   371         kx # ===================================================================
   371         kx if test "$with_system_libxml" = "auto"; then
   371         kx     case "$_os" in
   371         kx     WINNT|iOS|Android)
   371         kx         with_system_libxml="$with_system_libs"
   371         kx         ;;
   371         kx     Emscripten)
   371         kx         with_system_libxml=no
   371         kx         ;;
   371         kx     *)
   371         kx         if test "$enable_fuzzers" != "yes"; then
   371         kx             with_system_libxml=yes
   371         kx         else
   371         kx             with_system_libxml=no
   371         kx         fi
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([which libxslt to use])
   371         kx if test "$with_system_libxml" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_LIBXSLT=TRUE
   371         kx     if test "$_os" = "Darwin"; then
   371         kx         dnl make sure to use SDK path
   371         kx         LIBXSLT_CFLAGS="-I$MACOSX_SDK_PATH/usr/include/libxml2"
   371         kx         LIBEXSLT_CFLAGS="$LIBXSLT_CFLAGS"
   371         kx         dnl omit -L/usr/lib
   371         kx         LIBXSLT_LIBS="-lxslt -lxml2 -lz -lpthread -liconv -lm"
   371         kx         LIBEXSLT_LIBS="-lexslt $LIBXSLT_LIBS"
   371         kx     else
   371         kx         PKG_CHECK_MODULES(LIBXSLT, libxslt)
   371         kx         LIBXSLT_CFLAGS=$(printf '%s' "$LIBXSLT_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${LIBXSLT_LIBS}"
   371         kx         LIBXSLT_LIBS="${filteredlibs}"
   371         kx         PKG_CHECK_MODULES(LIBEXSLT, libexslt)
   371         kx         LIBEXSLT_CFLAGS=$(printf '%s' "$LIBEXSLT_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${LIBEXSLT_LIBS}"
   371         kx         LIBEXSLT_LIBS=$(printf '%s' "${filteredlibs}" | sed -e "s/-lgpg-error//"  -e "s/-lgcrypt//")
   371         kx     fi
   371         kx 
   371         kx     dnl Check for xsltproc
   371         kx     AC_PATH_PROG(XSLTPROC, xsltproc, no)
   371         kx     if test "$XSLTPROC" = "no"; then
   371         kx         AC_MSG_ERROR([xsltproc is required])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_LIBXSLT=
   371         kx     BUILD_TYPE="$BUILD_TYPE LIBXSLT"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBXSLT)
   371         kx if test -z "$SYSTEM_LIBXSLT_FOR_BUILD"; then
   371         kx     SYSTEM_LIBXSLT_FOR_BUILD="$SYSTEM_LIBXSLT"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBXSLT_FOR_BUILD)
   371         kx 
   371         kx AC_SUBST(LIBEXSLT_CFLAGS)
   371         kx AC_SUBST(LIBEXSLT_LIBS)
   371         kx AC_SUBST(LIBXSLT_CFLAGS)
   371         kx AC_SUBST(LIBXSLT_LIBS)
   371         kx AC_SUBST(XSLTPROC)
   371         kx 
   371         kx # ===================================================================
   371         kx # Check for system libxml
   371         kx # ===================================================================
   371         kx AC_MSG_CHECKING([which libxml to use])
   371         kx if test "$with_system_libxml" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_LIBXML=TRUE
   371         kx     if test "$_os" = "Darwin"; then
   371         kx         dnl make sure to use SDK path
   371         kx         LIBXML_CFLAGS="-I$MACOSX_SDK_PATH/usr/include/libxml2"
   371         kx         dnl omit -L/usr/lib
   371         kx         LIBXML_LIBS="-lxml2 -lz -lpthread -liconv -lm"
   371         kx     elif test $_os = iOS; then
   371         kx         dnl make sure to use SDK path
   371         kx         usr=`echo '#include <stdlib.h>' | $CC -E -MD - | grep usr/include/stdlib.h | head -1 | sed -e 's,# 1 ",,' -e 's,/usr/include/.*,/usr,'`
   371         kx         LIBXML_CFLAGS="-I$usr/include/libxml2"
   371         kx         LIBXML_LIBS="-L$usr/lib -lxml2 -liconv"
   371         kx     else
   371         kx         PKG_CHECK_MODULES(LIBXML, libxml-2.0 >= 2.0)
   371         kx         LIBXML_CFLAGS=$(printf '%s' "$LIBXML_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${LIBXML_LIBS}"
   371         kx         LIBXML_LIBS="${filteredlibs}"
   371         kx     fi
   371         kx 
   371         kx     dnl Check for xmllint
   371         kx     AC_PATH_PROG(XMLLINT, xmllint, no)
   371         kx     if test "$XMLLINT" = "no"; then
   371         kx         AC_MSG_ERROR([xmllint is required])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_LIBXML=
   371         kx     LIBXML_CFLAGS="-I${WORKDIR}/UnpackedTarball/libxml2/include"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         LIBXML_CFLAGS="${LIBXML_CFLAGS} -I${WORKDIR}/UnpackedTarball/icu/source/i18n -I${WORKDIR}/UnpackedTarball/icu/source/common"
   371         kx     fi
   371         kx     if test "$COM" = "MSC"; then
   371         kx         LIBXML_LIBS="${WORKDIR}/UnpackedTarball/libxml2/win32/bin.msvc/libxml2.lib"
   371         kx     else
   371         kx         LIBXML_LIBS="-L${WORKDIR}/UnpackedTarball/libxml2/.libs -lxml2"
   371         kx         if test "$DISABLE_DYNLOADING" = TRUE; then
   371         kx             LIBXML_LIBS="$LIBXML_LIBS -lm"
   371         kx         fi
   371         kx     fi
   371         kx     BUILD_TYPE="$BUILD_TYPE LIBXML2"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBXML)
   371         kx if test -z "$SYSTEM_LIBXML_FOR_BUILD"; then
   371         kx     SYSTEM_LIBXML_FOR_BUILD="$SYSTEM_LIBXML"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBXML_FOR_BUILD)
   371         kx AC_SUBST(LIBXML_CFLAGS)
   371         kx AC_SUBST(LIBXML_LIBS)
   371         kx AC_SUBST(XMLLINT)
   371         kx 
   371         kx # =====================================================================
   371         kx # Checking for a Python interpreter with version >= 3.3.
   371         kx # Optionally user can pass an option to configure, i. e.
   371         kx # ./configure PYTHON=/usr/bin/python
   371         kx # =====================================================================
   371         kx if test $_os = Darwin -a "$enable_python" != no -a "$enable_python" != fully-internal -a "$enable_python" != internal -a "$enable_python" != system; then
   371         kx     # Only allowed choices for macOS are 'no', 'internal' (default), and 'fully-internal'
   371         kx     # unless PYTHON is defined as above which allows 'system'
   371         kx     enable_python=internal
   371         kx fi
   371         kx if test "$build_os" != "cygwin" -a "$enable_python" != fully-internal; then
   371         kx     if test -n "$PYTHON"; then
   371         kx         PYTHON_FOR_BUILD=$PYTHON
   371         kx     else
   371         kx         # This allows a lack of system python with no error, we use internal one in that case.
   371         kx         AM_PATH_PYTHON([3.3],, [:])
   371         kx         # Clean PYTHON_VERSION checked below if cross-compiling
   371         kx         PYTHON_VERSION=""
   371         kx         if test "$PYTHON" != ":"; then
   371         kx             PYTHON_FOR_BUILD=$PYTHON
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx # Checks for Python to use for Pyuno
   371         kx AC_MSG_CHECKING([which Python to use for Pyuno])
   371         kx case "$enable_python" in
   371         kx no|disable)
   371         kx     if test -z "$PYTHON_FOR_BUILD" -a "$cross_compiling" != yes; then
   371         kx         # Python is required to build LibreOffice. In theory we could separate the build-time Python
   371         kx         # requirement from the choice whether to include Python stuff in the installer, but why
   371         kx         # bother?
   371         kx         AC_MSG_ERROR([Python is required at build time.])
   371         kx     fi
   371         kx     enable_python=no
   371         kx     AC_MSG_RESULT([none])
   371         kx     ;;
   371         kx ""|yes|auto)
   371         kx     if test "$DISABLE_SCRIPTING" = TRUE; then
   371         kx         if test -z "$PYTHON_FOR_BUILD" -a "$cross_compiling" != yes; then
   371         kx             AC_MSG_ERROR([Python support can't be disabled without cross-compiling or a system python.])
   371         kx         fi
   371         kx         AC_MSG_RESULT([none, overridden by --disable-scripting])
   371         kx         enable_python=no
   371         kx     elif test $build_os = cygwin -o $build_os = wsl; then
   371         kx         dnl When building on Windows we don't attempt to use any installed
   371         kx         dnl "system"  Python.
   371         kx         AC_MSG_RESULT([fully internal])
   371         kx         enable_python=internal
   371         kx     elif test "$cross_compiling" = yes; then
   371         kx         AC_MSG_RESULT([system])
   371         kx         enable_python=system
   371         kx     else
   371         kx         # Unset variables set by the above AM_PATH_PYTHON so that
   371         kx         # we actually do check anew.
   371         kx         AC_MSG_RESULT([])
   371         kx         unset PYTHON am_cv_pathless_PYTHON ac_cv_path_PYTHON am_cv_python_version am_cv_python_platform am_cv_python_pythondir am_cv_python_pyexecdir
   371         kx         AM_PATH_PYTHON([3.3],, [:])
   371         kx         AC_MSG_CHECKING([which Python to use for Pyuno])
   371         kx         if test "$PYTHON" = ":"; then
   371         kx             if test -z "$PYTHON_FOR_BUILD"; then
   371         kx                 AC_MSG_RESULT([fully internal])
   371         kx             else
   371         kx                 AC_MSG_RESULT([internal])
   371         kx             fi
   371         kx             enable_python=internal
   371         kx         else
   371         kx             AC_MSG_RESULT([system])
   371         kx             enable_python=system
   371         kx         fi
   371         kx     fi
   371         kx     ;;
   371         kx internal)
   371         kx     AC_MSG_RESULT([internal])
   371         kx     ;;
   371         kx fully-internal)
   371         kx     AC_MSG_RESULT([fully internal])
   371         kx     enable_python=internal
   371         kx     ;;
   371         kx system)
   371         kx     AC_MSG_RESULT([system])
   371         kx     if test "$_os" = Darwin -a -z "$PYTHON"; then
   371         kx         AC_MSG_ERROR([--enable-python=system doesn't work on macOS because the version provided is obsolete])
   371         kx     fi
   371         kx     ;;
   371         kx *)
   371         kx     AC_MSG_ERROR([Incorrect --enable-python option])
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx if test $enable_python != no; then
   371         kx     BUILD_TYPE="$BUILD_TYPE PYUNO"
   371         kx fi
   371         kx 
   371         kx if test $enable_python = system; then
   371         kx     if test -n "$PYTHON_CFLAGS" -a -n "$PYTHON_LIBS"; then
   371         kx         # Fallback: Accept these in the environment, or as set above
   371         kx         # for MacOSX.
   371         kx         :
   371         kx     elif test "$cross_compiling" != yes; then
   371         kx         # Unset variables set by the above AM_PATH_PYTHON so that
   371         kx         # we actually do check anew.
   371         kx         unset PYTHON am_cv_pathless_PYTHON ac_cv_path_PYTHON am_cv_python_version am_cv_python_platform am_cv_python_pythondir am_cv_python_pyexecdir
   371         kx         # This causes an error if no python command is found
   371         kx         AM_PATH_PYTHON([3.3])
   371         kx         python_include=`$PYTHON -c "import distutils.sysconfig; print(distutils.sysconfig.get_config_var('INCLUDEPY'));"`
   371         kx         python_version=`$PYTHON -c "import distutils.sysconfig; print(distutils.sysconfig.get_config_var('VERSION'));"`
   371         kx         python_libs=`$PYTHON -c "import distutils.sysconfig; print(distutils.sysconfig.get_config_var('LIBS'));"`
   371         kx         python_libdir=`$PYTHON -c "import distutils.sysconfig; print(distutils.sysconfig.get_config_var('LIBDIR'));"`
   371         kx         if test -z "$PKG_CONFIG"; then
   371         kx             PYTHON_CFLAGS="-I$python_include"
   371         kx             PYTHON_LIBS="-L$python_libdir -lpython$python_version $python_libs"
   371         kx         elif $PKG_CONFIG --exists python-$python_version-embed; then
   371         kx             PYTHON_CFLAGS="`$PKG_CONFIG --cflags python-$python_version-embed`"
   371         kx             PYTHON_LIBS="`$PKG_CONFIG --libs python-$python_version-embed` $python_libs"
   371         kx         elif $PKG_CONFIG --exists python-$python_version; then
   371         kx             PYTHON_CFLAGS="`$PKG_CONFIG --cflags python-$python_version`"
   371         kx             PYTHON_LIBS="`$PKG_CONFIG --libs python-$python_version` $python_libs"
   371         kx         else
   371         kx             PYTHON_CFLAGS="-I$python_include"
   371         kx             PYTHON_LIBS="-L$python_libdir -lpython$python_version $python_libs"
   371         kx         fi
   371         kx         FilterLibs "${PYTHON_LIBS}"
   371         kx         PYTHON_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         dnl How to find out the cross-compilation Python installation path?
   371         kx         AC_MSG_CHECKING([for python version])
   371         kx         AS_IF([test -n "$PYTHON_VERSION"],
   371         kx               [AC_MSG_RESULT([$PYTHON_VERSION])],
   371         kx               [AC_MSG_RESULT([not found])
   371         kx                AC_MSG_ERROR([no usable python found])])
   371         kx         test -n "$PYTHON_CFLAGS" && break
   371         kx     fi
   371         kx 
   371         kx     dnl Check if the headers really work
   371         kx     save_CPPFLAGS="$CPPFLAGS"
   371         kx     CPPFLAGS="$CPPFLAGS $PYTHON_CFLAGS"
   371         kx     AC_CHECK_HEADER(Python.h)
   371         kx     CPPFLAGS="$save_CPPFLAGS"
   371         kx 
   371         kx     # let the PYTHON_FOR_BUILD match the same python installation that
   371         kx     # provides PYTHON_CFLAGS/PYTHON_LDFLAGS for pyuno, which should be
   371         kx     # better for PythonTests.
   371         kx     PYTHON_FOR_BUILD=$PYTHON
   371         kx fi
   371         kx 
   371         kx if test "$with_lxml" != no; then
   371         kx     if test -z "$PYTHON_FOR_BUILD"; then
   371         kx         case $build_os in
   371         kx             cygwin)
   371         kx                 AC_MSG_WARN([No system-provided python lxml, gla11y will only report widget classes and ids])
   371         kx                 ;;
   371         kx             *)
   371         kx                 if test "$cross_compiling" != yes ; then
   371         kx                     BUILD_TYPE="$BUILD_TYPE LXML"
   371         kx                 fi
   371         kx                 ;;
   371         kx         esac
   371         kx     else
   371         kx         AC_MSG_CHECKING([for python lxml])
   371         kx         if $PYTHON_FOR_BUILD -c "import lxml.etree as ET" 2> /dev/null ; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             case $build_os in
   371         kx                 cygwin)
   371         kx                     AC_MSG_RESULT([no, gla11y will only report widget classes and ids])
   371         kx                     ;;
   371         kx                 *)
   371         kx                     if test "$cross_compiling" != yes -a "x$ac_cv_header_Python_h" = "xyes"; then
   371         kx                         if test -n ${SYSTEM_LIBXSLT} -o -n ${SYSTEM_LIBXML}; then
   371         kx                             AC_MSG_RESULT([no, and no system libxml/libxslt, gla11y will only report widget classes and ids])
   371         kx                         else
   371         kx                             BUILD_TYPE="$BUILD_TYPE LXML"
   371         kx                             AC_MSG_RESULT([no, using internal lxml])
   371         kx                         fi
   371         kx                     else
   371         kx                         AC_MSG_RESULT([no, and system does not provide python development headers, gla11y will only report widget classes and ids])
   371         kx                     fi
   371         kx                     ;;
   371         kx             esac
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test \( "$cross_compiling" = yes -a -z "$PYTHON_FOR_BUILD" \) -o "$enable_python" = internal; then
   371         kx     SYSTEM_PYTHON=
   371         kx     PYTHON_VERSION_MAJOR=3
   371         kx     PYTHON_VERSION_MINOR=8
   371         kx     PYTHON_VERSION=${PYTHON_VERSION_MAJOR}.${PYTHON_VERSION_MINOR}.18
   371         kx     if ! grep -q -i python.*${PYTHON_VERSION} ${SRC_ROOT}/download.lst; then
   371         kx         AC_MSG_ERROR([PYTHON_VERSION ${PYTHON_VERSION} but no matching file in download.lst])
   371         kx     fi
   371         kx     AC_DEFINE_UNQUOTED([PYTHON_VERSION_STRING], [L"${PYTHON_VERSION}"])
   371         kx 
   371         kx     # Embedded Python dies without Home set
   371         kx     if test "$HOME" = ""; then
   371         kx         export HOME=""
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl By now enable_python should be "system", "internal" or "no"
   371         kx case $enable_python in
   371         kx system)
   371         kx     SYSTEM_PYTHON=TRUE
   371         kx 
   371         kx     if test "x$ac_cv_header_Python_h" != "xyes"; then
   371         kx        AC_MSG_ERROR([Python headers not found. You probably want to set both the PYTHON_CFLAGS and PYTHON_LIBS environment variables.])
   371         kx     fi
   371         kx 
   371         kx     AC_LANG_PUSH(C)
   371         kx     CFLAGS="$CFLAGS $PYTHON_CFLAGS"
   371         kx     AC_MSG_CHECKING([for correct python library version])
   371         kx        AC_RUN_IFELSE([AC_LANG_SOURCE([[
   371         kx #include <Python.h>
   371         kx 
   371         kx int main(int argc, char **argv) {
   371         kx    if ((PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION >= 3)) return 0;
   371         kx    else return 1;
   371         kx }
   371         kx        ]])],[AC_MSG_RESULT([ok])],[AC_MSG_ERROR([Python >= 3.3 is needed when building with Python 3])],[AC_MSG_RESULT([skipped; cross-compiling])])
   371         kx     AC_LANG_POP(C)
   371         kx 
   371         kx     dnl FIXME Check if the Python library can be linked with, too?
   371         kx     ;;
   371         kx 
   371         kx internal)
   371         kx     BUILD_TYPE="$BUILD_TYPE PYTHON"
   371         kx     if test "$OS" = LINUX -o "$OS" = WNT ; then
   371         kx         BUILD_TYPE="$BUILD_TYPE LIBFFI"
   371         kx     fi
   371         kx     ;;
   371         kx no)
   371         kx     DISABLE_PYTHON=TRUE
   371         kx     SYSTEM_PYTHON=
   371         kx     ;;
   371         kx *)
   371         kx     AC_MSG_ERROR([Internal configure script error, invalid enable_python value "$enable_python"])
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx AC_SUBST(DISABLE_PYTHON)
   371         kx AC_SUBST(SYSTEM_PYTHON)
   371         kx AC_SUBST(PYTHON_CFLAGS)
   371         kx AC_SUBST(PYTHON_FOR_BUILD)
   371         kx AC_SUBST(PYTHON_LIBS)
   371         kx AC_SUBST(PYTHON_VERSION)
   371         kx AC_SUBST(PYTHON_VERSION_MAJOR)
   371         kx AC_SUBST(PYTHON_VERSION_MINOR)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build LibreLogo])
   371         kx case "$enable_python" in
   371         kx no|disable)
   371         kx     AC_MSG_RESULT([no; Python disabled])
   371         kx     ;;
   371         kx *)
   371         kx     if test "${enable_librelogo}" = "no"; then
   371         kx         AC_MSG_RESULT([no])
   371         kx     else
   371         kx         AC_MSG_RESULT([yes])
   371         kx         BUILD_TYPE="${BUILD_TYPE} LIBRELOGO"
   371         kx         AC_DEFINE([ENABLE_LIBRELOGO],1)
   371         kx     fi
   371         kx     ;;
   371         kx esac
   371         kx AC_SUBST(ENABLE_LIBRELOGO)
   371         kx 
   371         kx ENABLE_MARIADBC=
   371         kx MARIADBC_MAJOR=1
   371         kx MARIADBC_MINOR=0
   371         kx MARIADBC_MICRO=2
   371         kx AC_MSG_CHECKING([whether to build the MariaDB/MySQL SDBC driver])
   371         kx if test "x$enable_mariadb_sdbc" != "xno" -a "$enable_mpl_subset" != "yes"; then
   371         kx     ENABLE_MARIADBC=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx     BUILD_TYPE="$BUILD_TYPE MARIADBC"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_MARIADBC)
   371         kx AC_SUBST(MARIADBC_MAJOR)
   371         kx AC_SUBST(MARIADBC_MINOR)
   371         kx AC_SUBST(MARIADBC_MICRO)
   371         kx 
   371         kx if test "$ENABLE_MARIADBC" = "TRUE"; then
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system MariaDB
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which MariaDB to use])
   371         kx     if test "$with_system_mariadb" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_MARIADB_CONNECTOR_C=TRUE
   371         kx         #AC_PATH_PROG(MARIADBCONFIG, [mariadb_config])
   371         kx         if test -z "$MARIADBCONFIG"; then
   371         kx             AC_PATH_PROG(MARIADBCONFIG, [mysql_config])
   371         kx             if test -z "$MARIADBCONFIG"; then
   371         kx                 AC_MSG_ERROR([mysql_config is missing. Install MySQL client library development package.])
   371         kx                 #AC_MSG_ERROR([mariadb_config and mysql_config are missing. Install MariaDB or MySQL client library development package.])
   371         kx             fi
   371         kx         fi
   371         kx         AC_MSG_CHECKING([MariaDB version])
   371         kx         MARIADB_VERSION=`$MARIADBCONFIG --version`
   371         kx         MARIADB_MAJOR=`$MARIADBCONFIG --version | cut -d"." -f1`
   371         kx         if test "$MARIADB_MAJOR" -ge "5"; then
   371         kx             AC_MSG_RESULT([OK])
   371         kx         else
   371         kx             AC_MSG_ERROR([too old, use 5.0.x or later])
   371         kx         fi
   371         kx         AC_MSG_CHECKING([for MariaDB Client library])
   371         kx         MARIADB_CFLAGS=`$MARIADBCONFIG --cflags`
   371         kx         if test "$COM_IS_CLANG" = TRUE; then
   371         kx             MARIADB_CFLAGS=$(printf '%s' "$MARIADB_CFLAGS" | sed -e s/-fstack-protector-strong//)
   371         kx         fi
   371         kx         MARIADB_LIBS=`$MARIADBCONFIG --libs_r`
   371         kx         dnl At least mariadb-5.5.34-3.fc20.x86_64 plus
   371         kx         dnl mariadb-5.5.34-3.fc20.i686 reports 64-bit specific output even under
   371         kx         dnl linux32:
   371         kx         if test "$OS" = LINUX -a "$CPUNAME" = INTEL; then
   371         kx             MARIADB_CFLAGS=$(printf '%s' "$MARIADB_CFLAGS" | sed -e s/-m64//)
   371         kx             MARIADB_LIBS=$(printf '%s' "$MARIADB_LIBS" \
   371         kx                 | sed -e 's|/lib64/|/lib/|')
   371         kx         fi
   371         kx         FilterLibs "${MARIADB_LIBS}"
   371         kx         MARIADB_LIBS="${filteredlibs}"
   371         kx         AC_MSG_RESULT([includes '$MARIADB_CFLAGS', libraries '$MARIADB_LIBS'])
   371         kx         AC_MSG_CHECKING([whether to bundle the MySQL/MariaDB client library])
   371         kx         if test "$enable_bundle_mariadb" = "yes"; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx             BUNDLE_MARIADB_CONNECTOR_C=TRUE
   371         kx             LIBMARIADB=lib$(echo "${MARIADB_LIBS}" | sed -e 's/[[[:space:]]]\{1,\}-l\([[^[:space:]]]\{1,\}\)/\
   371         kx \1\
   371         kx /g' -e 's/^-l\([[^[:space:]]]\{1,\}\)[[[:space:]]]*/\
   371         kx \1\
   371         kx /g' | grep -E '(mysqlclient|mariadb)')
   371         kx             if test "$_os" = "Darwin"; then
   371         kx                 LIBMARIADB=${LIBMARIADB}.dylib
   371         kx             elif test "$_os" = "WINNT"; then
   371         kx                 LIBMARIADB=${LIBMARIADB}.dll
   371         kx             else
   371         kx                 LIBMARIADB=${LIBMARIADB}.so
   371         kx             fi
   371         kx             LIBMARIADB_PATH=$($MARIADBCONFIG --variable=pkglibdir)
   371         kx             AC_MSG_CHECKING([for $LIBMARIADB in $LIBMARIADB_PATH])
   371         kx             if test -e "$LIBMARIADB_PATH/$LIBMARIADB"; then
   371         kx                 AC_MSG_RESULT([found.])
   371         kx                 PathFormat "$LIBMARIADB_PATH"
   371         kx                 LIBMARIADB_PATH="$formatted_path"
   371         kx             else
   371         kx                 AC_MSG_ERROR([not found.])
   371         kx             fi
   371         kx         else
   371         kx             AC_MSG_RESULT([no])
   371         kx             BUNDLE_MARIADB_CONNECTOR_C=
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_MARIADB_CONNECTOR_C=
   371         kx         MARIADB_CFLAGS="-I${WORKDIR}/UnpackedTarball/mariadb-connector-c/include"
   371         kx         MARIADB_LIBS="-L${WORKDIR}/LinkTarget/StaticLibrary -lmariadb-connector-c"
   371         kx         BUILD_TYPE="$BUILD_TYPE MARIADB_CONNECTOR_C"
   371         kx     fi
   371         kx 
   371         kx     AC_SUBST(SYSTEM_MARIADB_CONNECTOR_C)
   371         kx     AC_SUBST(MARIADB_CFLAGS)
   371         kx     AC_SUBST(MARIADB_LIBS)
   371         kx     AC_SUBST(LIBMARIADB)
   371         kx     AC_SUBST(LIBMARIADB_PATH)
   371         kx     AC_SUBST(BUNDLE_MARIADB_CONNECTOR_C)
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system hsqldb
   371         kx dnl ===================================================================
   371         kx if test "$with_java" != "no" -a "$cross_compiling" != "yes"; then
   371         kx     AC_MSG_CHECKING([which hsqldb to use])
   371         kx     if test "$with_system_hsqldb" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_HSQLDB=TRUE
   371         kx         if test -z $HSQLDB_JAR; then
   371         kx             HSQLDB_JAR=/usr/share/java/hsqldb.jar
   371         kx         fi
   371         kx         if ! test -f $HSQLDB_JAR; then
   371         kx                AC_MSG_ERROR(hsqldb.jar not found.)
   371         kx         fi
   371         kx         AC_MSG_CHECKING([whether hsqldb is 1.8.0.x])
   371         kx         export HSQLDB_JAR
   371         kx         if $PERL -e \
   371         kx            'use Archive::Zip;
   371         kx             my $file = "$ENV{'HSQLDB_JAR'}";
   371         kx             my $zip = Archive::Zip->new( $file );
   371         kx             my $mf = $zip->contents ( "META-INF/MANIFEST.MF" );
   371         kx             if ( $mf =~ m/Specification-Version: 1.8.*/ )
   371         kx             {
   371         kx                 push @l, split(/\n/, $mf);
   371         kx                 foreach my $line (@l)
   371         kx                 {
   371         kx                     if ($line =~ m/Specification-Version:/)
   371         kx                     {
   371         kx                         ($t, $version) = split (/:/,$line);
   371         kx                         $version =~ s/^\s//;
   371         kx                         ($a, $b, $c, $d) = split (/\./,$version);
   371         kx                         if ($c == "0" && $d > "8")
   371         kx                         {
   371         kx                             exit 0;
   371         kx                         }
   371         kx                         else
   371         kx                         {
   371         kx                             exit 1;
   371         kx                         }
   371         kx                     }
   371         kx                 }
   371         kx             }
   371         kx             else
   371         kx             {
   371         kx                 exit 1;
   371         kx             }'; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             AC_MSG_ERROR([no, you need hsqldb >= 1.8.0.9 but < 1.8.1])
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_HSQLDB=
   371         kx         BUILD_TYPE="$BUILD_TYPE HSQLDB"
   371         kx         NEED_ANT=TRUE
   371         kx     fi
   371         kx else
   371         kx     if test "$with_java" != "no" -a -z "$HSQLDB_JAR"; then
   371         kx         BUILD_TYPE="$BUILD_TYPE HSQLDB"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_HSQLDB)
   371         kx AC_SUBST(HSQLDB_JAR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for PostgreSQL stuff
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to build the PostgreSQL SDBC driver])
   371         kx if test "x$enable_postgresql_sdbc" != "xno"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     SCPDEFS="$SCPDEFS -DWITH_POSTGRESQL_SDBC"
   371         kx 
   371         kx     if test "$with_krb5" = "yes" -a "$enable_openssl" = "no"; then
   371         kx         AC_MSG_ERROR([krb5 needs OpenSSL, but --disable-openssl was given.])
   371         kx     fi
   371         kx     if test "$with_gssapi" = "yes" -a "$enable_openssl" = "no"; then
   371         kx         AC_MSG_ERROR([GSSAPI needs OpenSSL, but --disable-openssl was given.])
   371         kx     fi
   371         kx 
   371         kx     postgres_interface=""
   371         kx     if test "$with_system_postgresql" = "yes"; then
   371         kx         postgres_interface="external PostgreSQL"
   371         kx         SYSTEM_POSTGRESQL=TRUE
   371         kx         if test "$_os" = Darwin; then
   371         kx             supp_path=''
   371         kx             for d in /Library/PostgreSQL/9.*/bin /sw/opt/postgresql/9.*/bin /opt/local/lib/postgresql9*/bin; do
   371         kx                 pg_supp_path="$P_SEP$d$pg_supp_path"
   371         kx             done
   371         kx         fi
   371         kx         AC_PATH_PROG(PGCONFIG, pg_config, ,$PATH$pg_supp_path)
   371         kx         if test -n "$PGCONFIG"; then
   371         kx             POSTGRESQL_INC=-I$(${PGCONFIG} --includedir)
   371         kx             POSTGRESQL_LIB="-L$(${PGCONFIG} --libdir)"
   371         kx         else
   371         kx             PKG_CHECK_MODULES(POSTGRESQL, libpq, [
   371         kx               POSTGRESQL_INC=$POSTGRESQL_CFLAGS
   371         kx               POSTGRESQL_LIB=$POSTGRESQL_LIBS
   371         kx             ],[
   371         kx               AC_MSG_ERROR([pg_config or 'pkg-config libpq' needed; set PGCONFIG if not in PATH])
   371         kx             ])
   371         kx         fi
   371         kx         FilterLibs "${POSTGRESQL_LIB}"
   371         kx         POSTGRESQL_LIB="${filteredlibs}"
   371         kx     else
   371         kx         # if/when anything else than PostgreSQL uses Kerberos,
   371         kx         # move this out of `test "x$enable_postgresql_sdbc" != "xno"'
   371         kx         WITH_KRB5=
   371         kx         WITH_GSSAPI=
   371         kx         case "$_os" in
   371         kx         Darwin)
   371         kx             # macOS has system MIT Kerberos 5 since 10.4
   371         kx             if test "$with_krb5" != "no"; then
   371         kx                 WITH_KRB5=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 # Not sure whether it makes any sense here to search multiple potential libraries; it is not likely
   371         kx                 # that the libraries where these functions are located on macOS will change, is it?
   371         kx                 AC_SEARCH_LIBS(com_err, [com_err 'com_err -lssl -lcrypto' krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'com_err' required for Kerberos 5])])
   371         kx                 KRB5_LIBS=$LIBS
   371         kx                 LIBS=$save_LIBS
   371         kx                 AC_SEARCH_LIBS(krb5_sendauth, [krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'krb5_sendauth' required for Kerberos 5])])
   371         kx                 KRB5_LIBS="$KRB5_LIBS $LIBS"
   371         kx                 LIBS=$save_LIBS
   371         kx             fi
   371         kx             if test "$with_gssapi" != "no"; then
   371         kx                 WITH_GSSAPI=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 AC_SEARCH_LIBS(gss_init_sec_context, [gssapi_krb5 gss 'gssapi -lkrb5 -lcrypto'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'gss_init_sec_context' required for GSSAPI])])
   371         kx                 GSSAPI_LIBS=$LIBS
   371         kx                 LIBS=$save_LIBS
   371         kx             fi
   371         kx             ;;
   371         kx         WINNT)
   371         kx             if test "$with_krb5" = "yes" -o "$with_gssapi" = "yes"; then
   371         kx                 AC_MSG_ERROR([Refusing to enable MIT Kerberos 5 or GSSAPI on Windows.])
   371         kx             fi
   371         kx             ;;
   371         kx         Linux|GNU|*BSD|DragonFly)
   371         kx             if test "$with_krb5" != "no"; then
   371         kx                 WITH_KRB5=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 AC_SEARCH_LIBS(com_err, [com_err 'com_err -lssl -lcrypto' krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'com_err' required for Kerberos 5])])
   371         kx                 KRB5_LIBS=$LIBS
   371         kx                 LIBS=$save_LIBS
   371         kx                 AC_SEARCH_LIBS(krb5_sendauth, [krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'krb5_sendauth' required for Kerberos 5])])
   371         kx                 KRB5_LIBS="$KRB5_LIBS $LIBS"
   371         kx                 LIBS=$save_LIBS
   371         kx             fi
   371         kx             if test "$with_gssapi" != "no"; then
   371         kx                 WITH_GSSAPI=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 AC_SEARCH_LIBS(gss_init_sec_context, [gssapi_krb5 gss 'gssapi -lkrb5 -lcrypto'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'gss_init_sec_context' required for GSSAPI])])
   371         kx                 GSSAPI_LIBS=$LIBS
   371         kx                 LIBS=$save_LIBS
   371         kx             fi
   371         kx             ;;
   371         kx         *)
   371         kx             if test "$with_krb5" = "yes"; then
   371         kx                 WITH_KRB5=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 AC_SEARCH_LIBS(com_err, [com_err 'com_err -lssl -lcrypto' krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'com_err' required for Kerberos 5])])
   371         kx                 KRB5_LIBS=$LIBS
   371         kx                 LIBS=$save_LIBS
   371         kx                 AC_SEARCH_LIBS(krb5_sendauth, [krb5 'krb5 -lcrypto -ldes -lasn1 -lroken'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'krb5_sendauth' required for Kerberos 5])])
   371         kx                 KRB5_LIBS="$KRB5_LIBS $LIBS"
   371         kx                 LIBS=$save_LIBS
   371         kx             fi
   371         kx             if test "$with_gssapi" = "yes"; then
   371         kx                 WITH_GSSAPI=TRUE
   371         kx                 save_LIBS=$LIBS
   371         kx                 AC_SEARCH_LIBS(gss_init_sec_context, [gssapi_krb5 gss 'gssapi -lkrb5 -lcrypto'], [],
   371         kx                     [AC_MSG_ERROR([could not find function 'gss_init_sec_context' required for GSSAPI])])
   371         kx                 LIBS=$save_LIBS
   371         kx                 GSSAPI_LIBS=$LIBS
   371         kx             fi
   371         kx         esac
   371         kx 
   371         kx         if test -n "$with_libpq_path"; then
   371         kx             SYSTEM_POSTGRESQL=TRUE
   371         kx             postgres_interface="external libpq"
   371         kx             POSTGRESQL_LIB="-L${with_libpq_path}/lib/"
   371         kx             POSTGRESQL_INC=-I"${with_libpq_path}/include/"
   371         kx         else
   371         kx             SYSTEM_POSTGRESQL=
   371         kx             postgres_interface="internal"
   371         kx             POSTGRESQL_LIB=""
   371         kx             POSTGRESQL_INC="%OVERRIDE_ME%"
   371         kx             BUILD_TYPE="$BUILD_TYPE POSTGRESQL"
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([PostgreSQL C interface])
   371         kx     AC_MSG_RESULT([$postgres_interface])
   371         kx 
   371         kx     if test "${SYSTEM_POSTGRESQL}" = "TRUE"; then
   371         kx         AC_MSG_NOTICE([checking system PostgreSQL prerequisites])
   371         kx         save_CFLAGS=$CFLAGS
   371         kx         save_CPPFLAGS=$CPPFLAGS
   371         kx         save_LIBS=$LIBS
   371         kx         CPPFLAGS="${CPPFLAGS} ${POSTGRESQL_INC}"
   371         kx         LIBS="${LIBS} ${POSTGRESQL_LIB}"
   371         kx         AC_CHECK_HEADER([libpq-fe.h], [], [AC_MSG_ERROR([libpq-fe.h is needed])], [])
   371         kx         AC_CHECK_LIB([pq], [PQconnectdbParams], [:],
   371         kx             [AC_MSG_ERROR(libpq not found or too old. Need >= 9.0)], [])
   371         kx         CFLAGS=$save_CFLAGS
   371         kx         CPPFLAGS=$save_CPPFLAGS
   371         kx         LIBS=$save_LIBS
   371         kx     fi
   371         kx     BUILD_POSTGRESQL_SDBC=TRUE
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(WITH_KRB5)
   371         kx AC_SUBST(WITH_GSSAPI)
   371         kx AC_SUBST(GSSAPI_LIBS)
   371         kx AC_SUBST(KRB5_LIBS)
   371         kx AC_SUBST(BUILD_POSTGRESQL_SDBC)
   371         kx AC_SUBST(SYSTEM_POSTGRESQL)
   371         kx AC_SUBST(POSTGRESQL_INC)
   371         kx AC_SUBST(POSTGRESQL_LIB)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for Firebird stuff
   371         kx dnl ===================================================================
   371         kx ENABLE_FIREBIRD_SDBC=
   371         kx if test "$enable_firebird_sdbc" = "yes" ; then
   371         kx     SCPDEFS="$SCPDEFS -DWITH_FIREBIRD_SDBC"
   371         kx 
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system Firebird
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which Firebird to use])
   371         kx     if test "$with_system_firebird" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_FIREBIRD=TRUE
   371         kx         AC_PATH_PROG(FIREBIRDCONFIG, [fb_config])
   371         kx         if test -z "$FIREBIRDCONFIG"; then
   371         kx             AC_MSG_NOTICE([No fb_config -- using pkg-config])
   371         kx             PKG_CHECK_MODULES([FIREBIRD], [fbclient >= 3], [FIREBIRD_PKGNAME=fbclient], [
   371         kx                 PKG_CHECK_MODULES([FIREBIRD], [fbembed], [FIREBIRD_PKGNAME=fbembed])
   371         kx             ])
   371         kx             FIREBIRD_VERSION=`pkg-config --modversion "$FIREBIRD_PKGNAME"`
   371         kx         else
   371         kx             AC_MSG_NOTICE([fb_config found])
   371         kx             FIREBIRD_VERSION=`$FIREBIRDCONFIG --version`
   371         kx             AC_MSG_CHECKING([for Firebird Client library])
   371         kx             FIREBIRD_CFLAGS=`$FIREBIRDCONFIG --cflags`
   371         kx             FIREBIRD_LIBS=`$FIREBIRDCONFIG --embedlibs`
   371         kx             FilterLibs "${FIREBIRD_LIBS}"
   371         kx             FIREBIRD_LIBS="${filteredlibs}"
   371         kx         fi
   371         kx         AC_MSG_RESULT([includes `$FIREBIRD_CFLAGS', libraries `$FIREBIRD_LIBS'])
   371         kx         AC_MSG_CHECKING([Firebird version])
   371         kx         if test -n "${FIREBIRD_VERSION}"; then
   371         kx             FIREBIRD_MAJOR=`echo $FIREBIRD_VERSION | cut -d"." -f1`
   371         kx             if test "$FIREBIRD_MAJOR" -ge "3"; then
   371         kx                 AC_MSG_RESULT([OK])
   371         kx             else
   371         kx                 AC_MSG_ERROR([Ensure firebird >= 3 is installed])
   371         kx             fi
   371         kx         else
   371         kx             save_CFLAGS="${CFLAGS}"
   371         kx             CFLAGS="${CFLAGS} ${FIREBIRD_CFLAGS}"
   371         kx             AC_COMPILE_IFELSE([AC_LANG_SOURCE([[#include <ibase.h>
   371         kx #if defined(FB_API_VER) && FB_API_VER == 30
   371         kx int fb_api_is_30(void) { return 0; }
   371         kx #else
   371         kx #error "Wrong Firebird API version"
   371         kx #endif]])],AC_MSG_RESULT([OK]),AC_MSG_ERROR([Ensure firebird 3.0.x is installed]))
   371         kx             CFLAGS="$save_CFLAGS"
   371         kx         fi
   371         kx         ENABLE_FIREBIRD_SDBC=TRUE
   371         kx         AC_DEFINE([ENABLE_FIREBIRD_SDBC],1)
   371         kx     elif test "$enable_database_connectivity" = no; then
   371         kx         AC_MSG_RESULT([none])
   371         kx     elif test "$cross_compiling" = "yes"; then
   371         kx         AC_MSG_RESULT([none])
   371         kx     else
   371         kx         dnl Embedded Firebird has version 3.0
   371         kx         dnl We need libatomic_ops for any non X86/X64 system
   371         kx         if test "${CPUNAME}" != INTEL -a "${CPUNAME}" != X86_64; then
   371         kx             dnl ===================================================================
   371         kx             dnl Check for system libatomic_ops
   371         kx             dnl ===================================================================
   371         kx             libo_CHECK_SYSTEM_MODULE([libatomic_ops],[LIBATOMIC_OPS],[atomic_ops >= 0.7.2])
   371         kx             if test "$with_system_libatomic_ops" = "yes"; then
   371         kx                 SYSTEM_LIBATOMIC_OPS=TRUE
   371         kx                 AC_CHECK_HEADERS(atomic_ops.h, [],
   371         kx                 [AC_MSG_ERROR(atomic_ops.h not found. install libatomic_ops)], [])
   371         kx             else
   371         kx                 SYSTEM_LIBATOMIC_OPS=
   371         kx                 LIBATOMIC_OPS_CFLAGS="-I${WORKDIR}/UnpackedTarball/libatomic_ops/include"
   371         kx                 LIBATOMIC_OPS_LIBS="-latomic_ops"
   371         kx                 BUILD_TYPE="$BUILD_TYPE LIBATOMIC_OPS"
   371         kx             fi
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_FIREBIRD=
   371         kx         FIREBIRD_CFLAGS="-I${WORKDIR}/UnpackedTarball/firebird/gen/Release/firebird/include"
   371         kx         FIREBIRD_LIBS="-lfbclient"
   371         kx 
   371         kx         if test "$with_system_libtommath" = "yes"; then
   371         kx             SYSTEM_LIBTOMMATH=TRUE
   371         kx             dnl check for tommath presence
   371         kx             save_LIBS=$LIBS
   371         kx             AC_CHECK_HEADER(tommath.h,,AC_MSG_ERROR(Include file for tommath not found - please install development tommath package))
   371         kx             AC_CHECK_LIB(tommath, mp_init, LIBTOMMATH_LIBS=-ltommath, AC_MSG_ERROR(Library tommath not found - please install development tommath package))
   371         kx             LIBS=$save_LIBS
   371         kx         else
   371         kx             SYSTEM_LIBTOMMATH=
   371         kx             LIBTOMMATH_CFLAGS="-I${WORKDIR}/UnpackedTarball/libtommath"
   371         kx             LIBTOMMATH_LIBS="-ltommath"
   371         kx             BUILD_TYPE="$BUILD_TYPE LIBTOMMATH"
   371         kx         fi
   371         kx 
   371         kx         BUILD_TYPE="$BUILD_TYPE FIREBIRD"
   371         kx         ENABLE_FIREBIRD_SDBC=TRUE
   371         kx         AC_DEFINE([ENABLE_FIREBIRD_SDBC],1)
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_FIREBIRD_SDBC)
   371         kx AC_SUBST(SYSTEM_LIBATOMIC_OPS)
   371         kx AC_SUBST(LIBATOMIC_OPS_CFLAGS)
   371         kx AC_SUBST(LIBATOMIC_OPS_LIBS)
   371         kx AC_SUBST(SYSTEM_FIREBIRD)
   371         kx AC_SUBST(FIREBIRD_CFLAGS)
   371         kx AC_SUBST(FIREBIRD_LIBS)
   371         kx AC_SUBST(SYSTEM_LIBTOMMATH)
   371         kx AC_SUBST(LIBTOMMATH_CFLAGS)
   371         kx AC_SUBST(LIBTOMMATH_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system curl
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([curl],[CURL],[libcurl >= 7.68.0],enabled)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system boost
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which boost to use])
   371         kx if test "$with_system_boost" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_BOOST=TRUE
   371         kx     AX_BOOST_BASE([1.66],,[AC_MSG_ERROR([no suitable Boost found])])
   371         kx     AX_BOOST_DATE_TIME
   371         kx     AX_BOOST_FILESYSTEM
   371         kx     AX_BOOST_IOSTREAMS
   371         kx     AX_BOOST_LOCALE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $BOOST_CPPFLAGS $CXXFLAGS_CXX11"
   371         kx     AC_CHECK_HEADER(boost/shared_ptr.hpp, [],
   371         kx        [AC_MSG_ERROR(boost/shared_ptr.hpp not found. install boost)], [])
   371         kx     AC_CHECK_HEADER(boost/spirit/include/classic_core.hpp, [],
   371         kx        [AC_MSG_ERROR(boost/spirit/include/classic_core.hpp not found. install boost >= 1.36)], [])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx     # this is in m4/ax_boost_base.m4
   371         kx     FilterLibs "${BOOST_LDFLAGS}"
   371         kx     BOOST_LDFLAGS="${filteredlibs}"
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     BUILD_TYPE="$BUILD_TYPE BOOST"
   371         kx     SYSTEM_BOOST=
   371         kx     if test "${COM}" = "GCC" -o "${COM_IS_CLANG}" = "TRUE"; then
   371         kx         # use warning-suppressing wrapper headers
   371         kx         BOOST_CPPFLAGS="-I${SRC_ROOT}/external/boost/include -I${WORKDIR}/UnpackedTarball/boost"
   371         kx     else
   371         kx         BOOST_CPPFLAGS="-I${WORKDIR}/UnpackedTarball/boost"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_BOOST)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system mdds
   371         kx dnl ===================================================================
   371         kx MDDS_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/mdds/include"
   371         kx libo_CHECK_SYSTEM_MODULE([mdds],[MDDS],[mdds-2.1 >= 2.1.0])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system dragonbox
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which dragonbox to use])
   371         kx if test "$with_system_dragonbox" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_DRAGONBOX=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CPPFLAGS=$CPPFLAGS
   371         kx     # This is where upstream installs to, unfortunately no .pc or so...
   371         kx     DRAGONBOX_CFLAGS=-I/usr/include/dragonbox-1.1.3
   371         kx     CPPFLAGS="$CPPFLAGS $DRAGONBOX_CFLAGS"
   371         kx     AC_CHECK_HEADER([dragonbox/dragonbox.h], [],
   371         kx        [AC_MSG_ERROR([dragonbox/dragonbox.h not found. install dragonbox])], [])
   371         kx     AC_LANG_POP([C++])
   371         kx     CPPFLAGS=$save_CPPFLAGS
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     BUILD_TYPE="$BUILD_TYPE DRAGONBOX"
   371         kx     SYSTEM_DRAGONBOX=
   371         kx fi
   371         kx AC_SUBST([SYSTEM_DRAGONBOX])
   371         kx AC_SUBST([DRAGONBOX_CFLAGS])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system frozen
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which frozen to use])
   371         kx if test "$with_system_frozen" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_FROZEN=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CPPFLAGS=$CPPFLAGS
   371         kx     AC_CHECK_HEADER([frozen/unordered_map.h], [],
   371         kx        [AC_MSG_ERROR([frozen/unordered_map.h not found. install frozen headers])], [])
   371         kx     AC_LANG_POP([C++])
   371         kx     CPPFLAGS=$save_CPPFLAGS
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     BUILD_TYPE="$BUILD_TYPE FROZEN"
   371         kx     SYSTEM_FROZEN=
   371         kx fi
   371         kx AC_SUBST([SYSTEM_FROZEN])
   371         kx AC_SUBST([FROZEN_CFLAGS])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system libfixmath
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which libfixmath to use])
   371         kx if test "$with_system_libfixmath" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_LIBFIXMATH=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_CHECK_HEADER([libfixmath/fix16.hpp], [],
   371         kx        [AC_MSG_ERROR([libfixmath/fix16.hpp not found. install libfixmath])], [])
   371         kx     AC_CHECK_LIB([libfixmath], [fix16_mul], [:], [AC_MSG_ERROR(libfixmath lib not found or functional)], [])
   371         kx     AC_LANG_POP([C++])
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_LIBFIXMATH=
   371         kx fi
   371         kx AC_SUBST([SYSTEM_LIBFIXMATH])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system glm
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which glm to use])
   371         kx if test "$with_system_glm" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_GLM=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_CHECK_HEADER([glm/glm.hpp], [],
   371         kx        [AC_MSG_ERROR([glm/glm.hpp not found. install glm])], [])
   371         kx     AC_LANG_POP([C++])
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     BUILD_TYPE="$BUILD_TYPE GLM"
   371         kx     SYSTEM_GLM=
   371         kx     GLM_CFLAGS="${ISYSTEM}${WORKDIR}/UnpackedTarball/glm"
   371         kx fi
   371         kx AC_SUBST([GLM_CFLAGS])
   371         kx AC_SUBST([SYSTEM_GLM])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system odbc
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which odbc headers to use])
   371         kx if test "$with_system_odbc" = "yes" -o '(' "$with_system_headers" = "yes" -a "$with_system_odbc" = "auto" ')' -o '(' "$_os" = "WINNT" -a  "$with_system_odbc" != "no" ')'; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_ODBC_HEADERS=TRUE
   371         kx 
   371         kx     if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx         save_CPPFLAGS=$CPPFLAGS
   371         kx         find_winsdk
   371         kx         PathFormat "$winsdktest"
   371         kx         CPPFLAGS="$CPPFLAGS -I$formatted_path/include/um -I$formatted_path/Include/$winsdklibsubdir/um -I$formatted_path/include -I$formatted_path/include/shared -I$formatted_path/include/$winsdklibsubdir/shared"
   371         kx         AC_CHECK_HEADER(sqlext.h, [],
   371         kx             [AC_MSG_ERROR(odbc not found. install odbc)],
   371         kx             [#include <windows.h>])
   371         kx         CPPFLAGS=$save_CPPFLAGS
   371         kx     else
   371         kx         AC_CHECK_HEADER(sqlext.h, [],
   371         kx             [AC_MSG_ERROR(odbc not found. install odbc)],[])
   371         kx     fi
   371         kx elif test "$enable_database_connectivity" = no; then
   371         kx     AC_MSG_RESULT([none])
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_ODBC_HEADERS=
   371         kx fi
   371         kx AC_SUBST(SYSTEM_ODBC_HEADERS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system NSS
   371         kx dnl ===================================================================
   371         kx if test "$enable_fuzzers" != "yes" -a "$enable_nss" = "yes"; then
   371         kx     libo_CHECK_SYSTEM_MODULE([nss],[NSS],[nss >= 3.9.3 nspr >= 4.8],,system-if-linux)
   371         kx     AC_DEFINE(HAVE_FEATURE_NSS)
   371         kx     ENABLE_NSS=TRUE
   371         kx elif test $_os != iOS -a "$enable_openssl" != "no"; then
   371         kx     with_tls=openssl
   371         kx fi
   371         kx AC_SUBST(ENABLE_NSS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Enable LDAP support
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$test_openldap" = yes; then
   371         kx     AC_MSG_CHECKING([whether to enable LDAP support])
   371         kx     if test "$enable_ldap" = yes -a \( "$enable_openssl" = yes -o "$with_system_openldap" = yes \); then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         ENABLE_LDAP=TRUE
   371         kx     else
   371         kx         if test "$enable_ldap" != "yes"; then
   371         kx             AC_MSG_RESULT([no])
   371         kx         else
   371         kx             AC_MSG_RESULT([no (needs OPENSSL or system openldap)])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system openldap
   371         kx dnl ===================================================================
   371         kx 
   371         kx     if test "$ENABLE_LDAP" = TRUE; then
   371         kx         AC_MSG_CHECKING([which openldap library to use])
   371         kx         if test "$with_system_openldap" = yes; then
   371         kx             AC_MSG_RESULT([external])
   371         kx             SYSTEM_OPENLDAP=TRUE
   371         kx             AC_CHECK_HEADERS(ldap.h, [], [AC_MSG_ERROR(ldap.h not found. install openldap libs)], [])
   371         kx             AC_CHECK_LIB([ldap], [ldap_simple_bind_s], [:], [AC_MSG_ERROR(openldap lib not found or functional)], [])
   371         kx             AC_CHECK_LIB([ldap], [ldap_set_option], [:], [AC_MSG_ERROR(openldap lib not found or functional)], [])
   371         kx         else
   371         kx             AC_MSG_RESULT([internal])
   371         kx             BUILD_TYPE="$BUILD_TYPE OPENLDAP"
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_LDAP)
   371         kx AC_SUBST(SYSTEM_OPENLDAP)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for TLS/SSL and cryptographic implementation to use
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which TLS/SSL and cryptographic implementation to use])
   371         kx if test -n "$with_tls"; then
   371         kx     case $with_tls in
   371         kx     openssl)
   371         kx         AC_DEFINE(USE_TLS_OPENSSL)
   371         kx         TLS=OPENSSL
   371         kx         AC_MSG_RESULT([$TLS])
   371         kx 
   371         kx         if test "$enable_openssl" != "yes"; then
   371         kx             AC_MSG_ERROR(["Disabling OpenSSL was requested, but the requested TLS to use is actually OpenSSL."])
   371         kx         fi
   371         kx 
   371         kx         # warn that OpenSSL has been selected but not all TLS code has this option
   371         kx         AC_MSG_WARN([TLS/SSL implementation to use is OpenSSL but some code may still depend on NSS])
   371         kx         add_warning "TLS/SSL implementation to use is OpenSSL but some code may still depend on NSS"
   371         kx         ;;
   371         kx     nss)
   371         kx         AC_DEFINE(USE_TLS_NSS)
   371         kx         TLS=NSS
   371         kx         AC_MSG_RESULT([$TLS])
   371         kx         ;;
   371         kx     no)
   371         kx         AC_MSG_RESULT([none])
   371         kx         AC_MSG_WARN([Skipping TLS/SSL])
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_RESULT([])
   371         kx         AC_MSG_ERROR([unsupported implementation $with_tls. Supported are:
   371         kx openssl - OpenSSL
   371         kx nss - Mozilla's Network Security Services (NSS)
   371         kx     ])
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     # default to using NSS, it results in smaller oox lib
   371         kx     AC_DEFINE(USE_TLS_NSS)
   371         kx     TLS=NSS
   371         kx     AC_MSG_RESULT([$TLS])
   371         kx fi
   371         kx AC_SUBST(TLS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system sane
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which sane header to use])
   371         kx if test "$with_system_sane" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     AC_CHECK_HEADER(sane/sane.h, [],
   371         kx       [AC_MSG_ERROR(sane not found. install sane)], [])
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     BUILD_TYPE="$BUILD_TYPE SANE"
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system icu
   371         kx dnl ===================================================================
   371         kx ICU_MAJOR=73
   371         kx ICU_MINOR=2
   371         kx ICU_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/icu/source/i18n -I${WORKDIR}/UnpackedTarball/icu/source/common"
   371         kx ICU_LIBS_internal="-L${WORKDIR}/UnpackedTarball/icu/source/lib"
   371         kx libo_CHECK_SYSTEM_MODULE([icu],[ICU],[icu-i18n >= 66])
   371         kx if test "$SYSTEM_ICU" = TRUE; then
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_MSG_CHECKING([for unicode/rbbi.h])
   371         kx     AC_PREPROC_IFELSE([AC_LANG_SOURCE([[unicode/rbbi.h]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([icu headers not found])])
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     ICU_VERSION=`$PKG_CONFIG --modversion icu-i18n 2>/dev/null`
   371         kx     ICU_MAJOR=`echo $ICU_VERSION | cut -d"." -f1`
   371         kx     ICU_MINOR=`echo $ICU_VERSION | cut -d"." -f2`
   371         kx 
   371         kx     if test "$CROSS_COMPILING" != TRUE; then
   371         kx         # using the system icu tools can lead to version confusion, use the
   371         kx         # ones from the build environment when cross-compiling
   371         kx         AC_PATH_PROG(SYSTEM_GENBRK, genbrk, [], [$PATH:/usr/sbin:/sbin])
   371         kx         if test -z "$SYSTEM_GENBRK"; then
   371         kx             AC_MSG_ERROR([\'genbrk\' not found in \$PATH, install the icu development tool \'genbrk\'])
   371         kx         fi
   371         kx         AC_PATH_PROG(SYSTEM_GENCCODE, genccode, [], [$PATH:/usr/sbin:/sbin:/usr/local/sbin])
   371         kx         if test -z "$SYSTEM_GENCCODE"; then
   371         kx             AC_MSG_ERROR([\'genccode\' not found in \$PATH, install the icu development tool \'genccode\'])
   371         kx         fi
   371         kx         AC_PATH_PROG(SYSTEM_GENCMN, gencmn, [], [$PATH:/usr/sbin:/sbin:/usr/local/sbin])
   371         kx         if test -z "$SYSTEM_GENCMN"; then
   371         kx             AC_MSG_ERROR([\'gencmn\' not found in \$PATH, install the icu development tool \'gencmn\'])
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(SYSTEM_GENBRK)
   371         kx AC_SUBST(SYSTEM_GENCCODE)
   371         kx AC_SUBST(SYSTEM_GENCMN)
   371         kx AC_SUBST(ICU_MAJOR)
   371         kx AC_SUBST(ICU_MINOR)
   371         kx 
   371         kx dnl ==================================================================
   371         kx dnl CURL
   371         kx dnl ==================================================================
   371         kx if test "$enable_curl" == "yes"; then
   371         kx     AC_DEFINE([HAVE_FEATURE_CURL])
   371         kx fi
   371         kx 
   371         kx dnl ==================================================================
   371         kx dnl Breakpad
   371         kx dnl ==================================================================
   371         kx DEFAULT_CRASHDUMP_VALUE="true"
   371         kx AC_MSG_CHECKING([whether to enable breakpad])
   371         kx if test "$enable_breakpad" != yes; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     if test "$enable_curl" != "yes"; then
   371         kx         AC_MSG_ERROR([--disable-breakpad must be used when --disable-curl is used])
   371         kx     fi
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_BREAKPAD="TRUE"
   371         kx     AC_DEFINE(ENABLE_BREAKPAD)
   371         kx     AC_DEFINE(HAVE_FEATURE_BREAKPAD, 1)
   371         kx     BUILD_TYPE="$BUILD_TYPE BREAKPAD"
   371         kx 
   371         kx     AC_MSG_CHECKING([for disable crash dump])
   371         kx     if test "$enable_crashdump" = no; then
   371         kx         DEFAULT_CRASHDUMP_VALUE="false"
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx        AC_MSG_RESULT([no])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([for crashreport config])
   371         kx     if test "$with_symbol_config" = "no"; then
   371         kx         BREAKPAD_SYMBOL_CONFIG="invalid"
   371         kx         AC_MSG_RESULT([no])
   371         kx     else
   371         kx         BREAKPAD_SYMBOL_CONFIG="$with_symbol_config"
   371         kx         AC_DEFINE(BREAKPAD_SYMBOL_CONFIG)
   371         kx         AC_MSG_RESULT([yes])
   371         kx     fi
   371         kx     AC_SUBST(BREAKPAD_SYMBOL_CONFIG)
   371         kx fi
   371         kx AC_SUBST(ENABLE_BREAKPAD)
   371         kx AC_SUBST(DEFAULT_CRASHDUMP_VALUE)
   371         kx 
   371         kx dnl ==================================================================
   371         kx dnl libcmis
   371         kx dnl ==================================================================
   371         kx if test "$enable_libcmis" == "yes"; then
   371         kx     if test "$enable_curl" != "yes"; then
   371         kx         AC_MSG_ERROR([--disable-libcmis must be used when --disable-curl is used])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Orcus
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([orcus],[ORCUS],[liborcus-0.18 >= 0.19.1])
   371         kx if test "$with_system_orcus" != "yes"; then
   371         kx     if test "$SYSTEM_BOOST" = "TRUE"; then
   371         kx         dnl Link with Boost.System
   371         kx         dnl This seems to be necessary since boost 1.50 (1.48 does not need it,
   371         kx         dnl 1.49 is untested). The macro BOOST_THREAD_DONT_USE_SYSTEM mentioned
   371         kx         dnl in documentation has no effect.
   371         kx         AX_BOOST_SYSTEM
   371         kx     fi
   371         kx fi
   371         kx dnl FIXME by renaming SYSTEM_LIBORCUS to SYSTEM_ORCUS in the build system world
   371         kx SYSTEM_LIBORCUS=$SYSTEM_ORCUS
   371         kx AC_SUBST([BOOST_SYSTEM_LIB])
   371         kx AC_SUBST(SYSTEM_LIBORCUS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl HarfBuzz
   371         kx dnl ===================================================================
   371         kx harfbuzz_required_version=5.1.0
   371         kx 
   371         kx GRAPHITE_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/graphite/include -DGRAPHITE2_STATIC"
   371         kx HARFBUZZ_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/harfbuzz/src"
   371         kx case "$_os" in
   371         kx     Linux)
   371         kx         GRAPHITE_LIBS_internal="${WORKDIR}/LinkTarget/StaticLibrary/libgraphite.a"
   371         kx         HARFBUZZ_LIBS_internal="${WORKDIR}/UnpackedTarball/harfbuzz/src/.libs/libharfbuzz.a"
   371         kx         ;;
   371         kx     *)
   371         kx         GRAPHITE_LIBS_internal="-L${WORKDIR}/LinkTarget/StaticLibrary -lgraphite"
   371         kx         HARFBUZZ_LIBS_internal="-L${WORKDIR}/UnpackedTarball/harfbuzz/src/.libs -lharfbuzz"
   371         kx         ;;
   371         kx esac
   371         kx libo_CHECK_SYSTEM_MODULE([graphite],[GRAPHITE],[graphite2 >= 0.9.3])
   371         kx libo_CHECK_SYSTEM_MODULE([harfbuzz],[HARFBUZZ],[harfbuzz-icu >= $harfbuzz_required_version])
   371         kx 
   371         kx if test "$COM" = "MSC"; then # override the above
   371         kx     GRAPHITE_LIBS="${WORKDIR}/LinkTarget/StaticLibrary/graphite.lib"
   371         kx     HARFBUZZ_LIBS="${WORKDIR}/UnpackedTarball/harfbuzz/src/.libs/libharfbuzz.lib"
   371         kx fi
   371         kx 
   371         kx if test "$with_system_harfbuzz" = "yes"; then
   371         kx     if test "$with_system_graphite" = "no"; then
   371         kx         AC_MSG_ERROR([--with-system-graphite must be used when --with-system-harfbuzz is used])
   371         kx     fi
   371         kx     AC_MSG_CHECKING([whether system Harfbuzz is built with Graphite support])
   371         kx     save_LIBS="$LIBS"
   371         kx     save_CFLAGS="$CFLAGS"
   371         kx     LIBS="$LIBS $HARFBUZZ_LIBS"
   371         kx     CFLAGS="$CFLAGS $HARFBUZZ_CFLAGS"
   371         kx     AC_CHECK_FUNC(hb_graphite2_face_get_gr_face,,[AC_MSG_ERROR([Harfbuzz needs to be built with Graphite support.])])
   371         kx     LIBS="$save_LIBS"
   371         kx     CFLAGS="$save_CFLAGS"
   371         kx else
   371         kx     if test "$with_system_graphite" = "yes"; then
   371         kx         AC_MSG_ERROR([--without-system-graphite must be used when --without-system-harfbuzz is used])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test "$USING_X11" = TRUE; then
   371         kx     AC_PATH_X
   371         kx     AC_PATH_XTRA
   371         kx     CPPFLAGS="$CPPFLAGS $X_CFLAGS"
   371         kx 
   371         kx     if test -z "$x_includes"; then
   371         kx         x_includes="default_x_includes"
   371         kx     fi
   371         kx     if test -z "$x_libraries"; then
   371         kx         x_libraries="default_x_libraries"
   371         kx     fi
   371         kx     CFLAGS="$CFLAGS $X_CFLAGS"
   371         kx     LDFLAGS="$LDFLAGS $X_LDFLAGS $X_LIBS"
   371         kx     AC_CHECK_LIB(X11, XOpenDisplay, x_libs="-lX11 $X_EXTRA_LIBS", [AC_MSG_ERROR([X Development libraries not found])])
   371         kx else
   371         kx     x_includes="no_x_includes"
   371         kx     x_libraries="no_x_libraries"
   371         kx fi
   371         kx 
   371         kx if test "$USING_X11" = TRUE; then
   371         kx     dnl ===================================================================
   371         kx     dnl Check for extension headers
   371         kx     dnl ===================================================================
   371         kx     AC_CHECK_HEADERS(X11/extensions/shape.h,[],[AC_MSG_ERROR([libXext headers not found])],
   371         kx      [#include <X11/extensions/shape.h>])
   371         kx 
   371         kx     # vcl needs ICE and SM
   371         kx     AC_CHECK_HEADERS(X11/ICE/ICElib.h,[],[AC_MSG_ERROR([libICE headers not found])])
   371         kx     AC_CHECK_LIB([ICE], [IceConnectionNumber], [:],
   371         kx         [AC_MSG_ERROR(ICE library not found)])
   371         kx     AC_CHECK_HEADERS(X11/SM/SMlib.h,[],[AC_MSG_ERROR([libSM headers not found])])
   371         kx     AC_CHECK_LIB([SM], [SmcOpenConnection], [:],
   371         kx         [AC_MSG_ERROR(SM library not found)])
   371         kx fi
   371         kx 
   371         kx if test "$USING_X11" = TRUE -a "$ENABLE_JAVA" != ""; then
   371         kx     # bean/native/unix/com_sun_star_comp_beans_LocalOfficeWindow.c needs Xt
   371         kx     AC_CHECK_HEADERS(X11/Intrinsic.h,[],[AC_MSG_ERROR([libXt headers not found])])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system Xrender
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to use Xrender])
   371         kx if test "$USING_X11" = TRUE -a  "$test_xrender" = "yes"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     PKG_CHECK_MODULES(XRENDER, xrender)
   371         kx     XRENDER_CFLAGS=$(printf '%s' "$XRENDER_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${XRENDER_LIBS}"
   371         kx     XRENDER_LIBS="${filteredlibs}"
   371         kx     AC_CHECK_LIB([Xrender], [XRenderQueryVersion], [:],
   371         kx       [AC_MSG_ERROR(libXrender not found or functional)], [])
   371         kx     AC_CHECK_HEADER(X11/extensions/Xrender.h, [],
   371         kx       [AC_MSG_ERROR(Xrender not found. install X)], [])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(XRENDER_CFLAGS)
   371         kx AC_SUBST(XRENDER_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for XRandr
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable RandR support])
   371         kx if test "$USING_X11" = TRUE -a "$test_randr" = "yes" -a \( "$enable_randr" = "yes" -o "$enable_randr" = "TRUE" \); then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     PKG_CHECK_MODULES(XRANDR, xrandr >= 1.2, ENABLE_RANDR="TRUE", ENABLE_RANDR="")
   371         kx     if test "$ENABLE_RANDR" != "TRUE"; then
   371         kx         AC_CHECK_HEADER(X11/extensions/Xrandr.h, [],
   371         kx                     [AC_MSG_ERROR([X11/extensions/Xrandr.h could not be found. X11 dev missing?])], [])
   371         kx         XRANDR_CFLAGS=" "
   371         kx         AC_CHECK_LIB([Xrandr], [XRRQueryExtension], [:],
   371         kx           [ AC_MSG_ERROR(libXrandr not found or functional) ], [])
   371         kx         XRANDR_LIBS="-lXrandr "
   371         kx         ENABLE_RANDR="TRUE"
   371         kx     fi
   371         kx     XRANDR_CFLAGS=$(printf '%s' "$XRANDR_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${XRANDR_LIBS}"
   371         kx     XRANDR_LIBS="${filteredlibs}"
   371         kx else
   371         kx     ENABLE_RANDR=""
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(XRANDR_CFLAGS)
   371         kx AC_SUBST(XRANDR_LIBS)
   371         kx AC_SUBST(ENABLE_RANDR)
   371         kx 
   371         kx if test -z "$with_webdav"; then
   371         kx     with_webdav=$test_webdav
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([for WebDAV support])
   371         kx case "$with_webdav" in
   371         kx no)
   371         kx     AC_MSG_RESULT([no])
   371         kx     WITH_WEBDAV=""
   371         kx     ;;
   371         kx *)
   371         kx     AC_MSG_RESULT([yes])
   371         kx     # curl is already mandatory (almost) and checked elsewhere
   371         kx     if test "$enable_curl" = "no"; then
   371         kx         AC_MSG_ERROR(["--without-webdav must be used when --disable-curl is used"])
   371         kx     fi
   371         kx     WITH_WEBDAV=TRUE
   371         kx     ;;
   371         kx esac
   371         kx AC_SUBST(WITH_WEBDAV)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for disabling cve_tests
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to execute CVE tests])
   371         kx # If not explicitly enabled or disabled, default
   371         kx if test -z "$enable_cve_tests"; then
   371         kx     case "$OS" in
   371         kx     WNT)
   371         kx         # Default cves off for Windows with its wild and wonderful
   371         kx         # variety of AV software kicking in and panicking
   371         kx         enable_cve_tests=no
   371         kx         ;;
   371         kx     *)
   371         kx         # otherwise yes
   371         kx         enable_cve_tests=yes
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx if test "$enable_cve_tests" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     DISABLE_CVE_TESTS=TRUE
   371         kx     AC_SUBST(DISABLE_CVE_TESTS)
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system openssl
   371         kx dnl ===================================================================
   371         kx ENABLE_OPENSSL=
   371         kx AC_MSG_CHECKING([whether to disable OpenSSL usage])
   371         kx if test "$enable_openssl" = "yes"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_OPENSSL=TRUE
   371         kx     if test "$_os" = Darwin ; then
   371         kx         # OpenSSL is deprecated when building for 10.7 or later.
   371         kx         #
   371         kx         # https://stackoverflow.com/questions/7406946/why-is-apple-deprecating-openssl-in-macos-10-7-lion
   371         kx         # https://stackoverflow.com/questions/7475914/libcrypto-deprecated-on-mac-os-x-10-7-lion
   371         kx 
   371         kx         with_system_openssl=no
   371         kx         libo_CHECK_SYSTEM_MODULE([openssl],[OPENSSL],[openssl])
   371         kx     elif test "$_os" = "FreeBSD" -o "$_os" = "NetBSD" -o "$_os" = "OpenBSD" -o "$_os" = "DragonFly" \
   371         kx             && test "$with_system_openssl" != "no"; then
   371         kx         with_system_openssl=yes
   371         kx         SYSTEM_OPENSSL=TRUE
   371         kx         OPENSSL_CFLAGS=
   371         kx         OPENSSL_LIBS="-lssl -lcrypto"
   371         kx     else
   371         kx         libo_CHECK_SYSTEM_MODULE([openssl],[OPENSSL],[openssl])
   371         kx         if test -n "${SYSTEM_OPENSSL}"; then
   371         kx             AC_DEFINE([SYSTEM_OPENSSL])
   371         kx         fi
   371         kx     fi
   371         kx     if test "$with_system_openssl" = "yes"; then
   371         kx         AC_MSG_CHECKING([whether openssl supports SHA512])
   371         kx         AC_LANG_PUSH([C])
   371         kx         AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <openssl/sha.h>]],[[
   371         kx             SHA512_CTX context;
   371         kx ]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([no, openssl too old. Need >= 0.9.8.])])
   371         kx         AC_LANG_POP(C)
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx 
   371         kx     # warn that although OpenSSL is disabled, system libraries may depend on it
   371         kx     AC_MSG_WARN([OpenSSL has been disabled. No code compiled here will make use of it but system libraries may create indirect dependencies])
   371         kx     add_warning "OpenSSL has been disabled. No code compiled here will make use of it but system libraries may create indirect dependencies"
   371         kx fi
   371         kx 
   371         kx AC_SUBST([ENABLE_OPENSSL])
   371         kx 
   371         kx if test "$enable_cipher_openssl_backend" = yes && test "$ENABLE_OPENSSL" != TRUE; then
   371         kx     if test "$libo_fuzzed_enable_cipher_openssl_backend" = yes; then
   371         kx         AC_MSG_NOTICE([Resetting --enable-cipher-openssl-backend=no])
   371         kx         enable_cipher_openssl_backend=no
   371         kx     else
   371         kx         AC_MSG_ERROR([--enable-cipher-openssl-backend needs OpenSSL, but --disable-openssl was given.])
   371         kx     fi
   371         kx fi
   371         kx AC_MSG_CHECKING([whether to enable the OpenSSL backend for rtl/cipher.h])
   371         kx ENABLE_CIPHER_OPENSSL_BACKEND=
   371         kx if test "$enable_cipher_openssl_backend" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_CIPHER_OPENSSL_BACKEND=TRUE
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST([ENABLE_CIPHER_OPENSSL_BACKEND])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Select the crypto backends used by LO
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$build_crypto" = yes; then
   371         kx     if test "$OS" = WNT; then
   371         kx         BUILD_TYPE="$BUILD_TYPE CRYPTO_MSCAPI"
   371         kx         AC_DEFINE([USE_CRYPTO_MSCAPI])
   371         kx     elif test "$ENABLE_NSS" = TRUE; then
   371         kx         BUILD_TYPE="$BUILD_TYPE CRYPTO_NSS"
   371         kx         AC_DEFINE([USE_CRYPTO_NSS])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx ARGON2_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/argon2/include"
   371         kx if test "$COM" = "MSC"; then
   371         kx     ARGON2_LIBS_internal="${WORKDIR}/UnpackedTarball/argon2/vs2015/build/Argon2OptDll.lib"
   371         kx else
   371         kx     ARGON2_LIBS_internal="${WORKDIR}/UnpackedTarball/argon2/libargon2.a"
   371         kx fi
   371         kx libo_CHECK_SYSTEM_MODULE([argon2],[ARGON2],[libargon2])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system redland
   371         kx dnl ===================================================================
   371         kx dnl redland: versions before 1.0.8 write RDF/XML that is useless for ODF (@xml:base)
   371         kx dnl raptor2: need at least 2.0.7 for CVE-2012-0037
   371         kx libo_CHECK_SYSTEM_MODULE([redland],[REDLAND],[redland >= 1.0.8 raptor2 >= 2.0.7])
   371         kx if test "$with_system_redland" = "yes"; then
   371         kx     AC_CHECK_LIB([rdf], [librdf_world_set_raptor_init_handler], [:],
   371         kx             [AC_MSG_ERROR(librdf too old. Need >= 1.0.16)], [])
   371         kx else
   371         kx     RAPTOR_MAJOR="0"
   371         kx     RASQAL_MAJOR="3"
   371         kx     REDLAND_MAJOR="0"
   371         kx fi
   371         kx AC_SUBST(RAPTOR_MAJOR)
   371         kx AC_SUBST(RASQAL_MAJOR)
   371         kx AC_SUBST(REDLAND_MAJOR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system hunspell
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which libhunspell to use])
   371         kx if test "$with_system_hunspell" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_HUNSPELL=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     PKG_CHECK_MODULES(HUNSPELL, hunspell, HUNSPELL_PC="TRUE", HUNSPELL_PC="" )
   371         kx     if test "$HUNSPELL_PC" != "TRUE"; then
   371         kx         AC_CHECK_HEADER(hunspell.hxx, [],
   371         kx             [
   371         kx             AC_CHECK_HEADER(hunspell/hunspell.hxx, [ HUNSPELL_CFLAGS=-I/usr/include/hunspell ],
   371         kx             [AC_MSG_ERROR(hunspell headers not found.)], [])
   371         kx             ], [])
   371         kx         AC_CHECK_LIB([hunspell], [main], [:],
   371         kx            [ AC_MSG_ERROR(hunspell library not found.) ], [])
   371         kx         HUNSPELL_LIBS=-lhunspell
   371         kx     fi
   371         kx     AC_LANG_POP([C++])
   371         kx     HUNSPELL_CFLAGS=$(printf '%s' "$HUNSPELL_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${HUNSPELL_LIBS}"
   371         kx     HUNSPELL_LIBS="${filteredlibs}"
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_HUNSPELL=
   371         kx     HUNSPELL_CFLAGS="-I${WORKDIR}/UnpackedTarball/hunspell/src/hunspell"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         HUNSPELL_LIBS="${WORKDIR}/LinkTarget/StaticLibrary/hunspell.lib"
   371         kx     else
   371         kx         HUNSPELL_LIBS="-L${WORKDIR}/UnpackedTarball/hunspell/src/hunspell/.libs -lhunspell-1.7"
   371         kx     fi
   371         kx     BUILD_TYPE="$BUILD_TYPE HUNSPELL"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_HUNSPELL)
   371         kx AC_SUBST(HUNSPELL_CFLAGS)
   371         kx AC_SUBST(HUNSPELL_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system zxcvbn
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which zxcvbn to use])
   371         kx if test "$with_system_zxcvbn" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_ZXCVBN=TRUE
   371         kx     AC_CHECK_HEADER(zxcvbn.h, [],
   371         kx        [ AC_MSG_ERROR(zxcvbn headers not found.)], [])
   371         kx     AC_CHECK_LIB(zxcvbn, ZxcvbnMatch, [],
   371         kx         [ AC_MSG_ERROR(zxcvbn library not found.)], [])
   371         kx else
   371         kx    AC_MSG_RESULT([internal])
   371         kx    BUILD_TYPE="$BUILD_TYPE ZXCVBN"
   371         kx    SYSTEM_ZXCVBN=
   371         kx fi
   371         kx AC_SUBST(SYSTEM_ZXCVBN)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system zxing
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to use zxing])
   371         kx if test "$enable_zxing" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_ZXING=
   371         kx     SYSTEM_ZXING=
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_ZXING=TRUE
   371         kx     AC_MSG_CHECKING([which libzxing to use])
   371         kx     if test "$with_system_zxing" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_ZXING=TRUE
   371         kx         ZXING_CFLAGS=
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         save_IFS=$IFS
   371         kx         IFS=$P_SEP
   371         kx         for i in $CPLUS_INCLUDE_PATH /usr/include; do
   371         kx             dnl Reset IFS as soon as possible, to avoid unexpected side effects (and the
   371         kx             dnl "/usr/include" fallback makes sure we get here at least once; resetting rather than
   371         kx             dnl unsetting follows the advice at <https://git.savannah.gnu.org/gitweb/?p=autoconf.git;
   371         kx             dnl a=commitdiff;h=e51c9919f2cf70185b7916ac040bc0bbfd0f743b> "Add recommendation on (not)
   371         kx             dnl unsetting IFS."):
   371         kx             IFS=$save_IFS
   371         kx             dnl TODO: GCC and Clang treat empty paths in CPLUS_INCLUDE_PATH like ".", but we simply
   371         kx             dnl ignore them here:
   371         kx             if test -z "$i"; then
   371         kx                 continue
   371         kx             fi
   371         kx             dnl TODO: White space in $i would cause problems:
   371         kx             CXXFLAGS="$save_CXXFLAGS ${CXXFLAGS_CXX11} -I$i/ZXing"
   371         kx             AC_CHECK_HEADER(MultiFormatWriter.h, [ZXING_CFLAGS=-I$i/ZXing; break],
   371         kx                 [unset ac_cv_header_MultiFormatWriter_h], [#include <stdexcept>])
   371         kx         done
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         if test -z "$ZXING_CFLAGS"; then
   371         kx             AC_MSG_ERROR(zxing headers not found.)
   371         kx         fi
   371         kx         AC_CHECK_LIB([ZXing], [main], [ZXING_LIBS=-lZXing],
   371         kx             [ AC_CHECK_LIB([ZXingCore], [main], [ZXING_LIBS=-lZXingCore],
   371         kx             [ AC_MSG_ERROR(zxing C++ library not found.) ])], [])
   371         kx         AC_LANG_POP([C++])
   371         kx         ZXING_CFLAGS=$(printf '%s' "$ZXING_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${ZXING_LIBS}"
   371         kx         ZXING_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_ZXING=
   371         kx         BUILD_TYPE="$BUILD_TYPE ZXING"
   371         kx         ZXING_CFLAGS="-I${WORKDIR}/UnpackedTarball/zxing/core/src"
   371         kx     fi
   371         kx     if test "$ENABLE_ZXING" = TRUE; then
   371         kx         AC_DEFINE(ENABLE_ZXING)
   371         kx     fi
   371         kx     AC_MSG_CHECKING([whether zxing::tosvg function is available])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11 $ZXING_CFLAGS"
   371         kx     AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <BitMatrix.h>
   371         kx             #include <BitMatrixIO.h>
   371         kx             int main(){
   371         kx                 ZXing::BitMatrix matrix(1, 1);
   371         kx                 matrix.set(0, 0, true);
   371         kx                 ZXing::ToSVG(matrix);
   371         kx                 return 0;
   371         kx             }
   371         kx         ])], [
   371         kx             AC_DEFINE([HAVE_ZXING_TOSVG],[1])
   371         kx             AC_MSG_RESULT([yes])
   371         kx         ], [AC_MSG_RESULT([no])])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx     AC_SUBST(HAVE_ZXING_TOSVG)
   371         kx fi
   371         kx AC_SUBST(SYSTEM_ZXING)
   371         kx AC_SUBST(ENABLE_ZXING)
   371         kx AC_SUBST(ZXING_CFLAGS)
   371         kx AC_SUBST(ZXING_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system box2d
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which box2d to use])
   371         kx if test "$with_system_box2d" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_BOX2D=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     AC_CHECK_HEADER(box2d/box2d.h, [BOX2D_H_FOUND='TRUE'],
   371         kx         [BOX2D_H_FOUND='FALSE'])
   371         kx     if test "$BOX2D_H_FOUND" = "TRUE"; then # 2.4.0+
   371         kx         _BOX2D_LIB=box2d
   371         kx         AC_DEFINE(BOX2D_HEADER,<box2d/box2d.h>)
   371         kx     else
   371         kx         # fail this. there's no other alternative to check when we are here.
   371         kx         AC_CHECK_HEADER([Box2D/Box2D.h], [],
   371         kx             [AC_MSG_ERROR(box2d headers not found.)])
   371         kx         _BOX2D_LIB=Box2D
   371         kx         AC_DEFINE(BOX2D_HEADER,<Box2D/Box2D.h>)
   371         kx     fi
   371         kx     AC_CHECK_LIB([$_BOX2D_LIB], [main], [:],
   371         kx         [ AC_MSG_ERROR(box2d library not found.) ], [])
   371         kx     BOX2D_LIBS=-l$_BOX2D_LIB
   371         kx     AC_LANG_POP([C++])
   371         kx     BOX2D_CFLAGS=$(printf '%s' "$BOX2D_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${BOX2D_LIBS}"
   371         kx     BOX2D_LIBS="${filteredlibs}"
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_BOX2D=
   371         kx     BUILD_TYPE="$BUILD_TYPE BOX2D"
   371         kx fi
   371         kx AC_SUBST(SYSTEM_BOX2D)
   371         kx AC_SUBST(BOX2D_CFLAGS)
   371         kx AC_SUBST(BOX2D_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checking for altlinuxhyph
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which altlinuxhyph to use])
   371         kx if test "$with_system_altlinuxhyph" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_HYPH=TRUE
   371         kx     AC_CHECK_HEADER(hyphen.h, [],
   371         kx        [ AC_MSG_ERROR(altlinuxhyph headers not found.)], [])
   371         kx     AC_CHECK_MEMBER(struct _HyphenDict.cset, [],
   371         kx        [ AC_MSG_ERROR(no. You are sure you have altlinuyhyph headers?)],
   371         kx        [#include <hyphen.h>])
   371         kx     AC_CHECK_LIB(hyphen, hnj_hyphen_hyphenate2, [HYPHEN_LIB=-lhyphen],
   371         kx         [ AC_MSG_ERROR(altlinuxhyph library not found or too old.)], [])
   371         kx     if test -z "$HYPHEN_LIB"; then
   371         kx         AC_CHECK_LIB(hyph, hnj_hyphen_hyphenate2, [HYPHEN_LIB=-lhyph],
   371         kx            [ AC_MSG_ERROR(altlinuxhyph library not found or too old.)], [])
   371         kx     fi
   371         kx     if test -z "$HYPHEN_LIB"; then
   371         kx         AC_CHECK_LIB(hnj, hnj_hyphen_hyphenate2, [HYPHEN_LIB=-lhnj],
   371         kx            [ AC_MSG_ERROR(altlinuxhyph library not found or too old.)], [])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_HYPH=
   371         kx     BUILD_TYPE="$BUILD_TYPE HYPHEN"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         HYPHEN_LIB="${WORKDIR}/LinkTarget/StaticLibrary/hyphen.lib"
   371         kx     else
   371         kx         HYPHEN_LIB="-L${WORKDIR}/UnpackedTarball/hyphen/.libs -lhyphen"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_HYPH)
   371         kx AC_SUBST(HYPHEN_LIB)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checking for mythes
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which mythes to use])
   371         kx if test "$with_system_mythes" = "yes"; then
   371         kx     AC_MSG_RESULT([external])
   371         kx     SYSTEM_MYTHES=TRUE
   371         kx     AC_LANG_PUSH([C++])
   371         kx     PKG_CHECK_MODULES(MYTHES, mythes, MYTHES_PKGCONFIG=yes, MYTHES_PKGCONFIG=no)
   371         kx     if test "$MYTHES_PKGCONFIG" = "no"; then
   371         kx         AC_CHECK_HEADER(mythes.hxx, [],
   371         kx             [ AC_MSG_ERROR(mythes.hxx headers not found.)], [])
   371         kx         AC_CHECK_LIB([mythes-1.2], [main], [:],
   371         kx             [ MYTHES_FOUND=no], [])
   371         kx     if test "$MYTHES_FOUND" = "no"; then
   371         kx         AC_CHECK_LIB(mythes, main, [MYTHES_FOUND=yes],
   371         kx                 [ MYTHES_FOUND=no], [])
   371         kx     fi
   371         kx     if test "$MYTHES_FOUND" = "no"; then
   371         kx         AC_MSG_ERROR([mythes library not found!.])
   371         kx     fi
   371         kx     fi
   371         kx     AC_LANG_POP([C++])
   371         kx     MYTHES_CFLAGS=$(printf '%s' "$MYTHES_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${MYTHES_LIBS}"
   371         kx     MYTHES_LIBS="${filteredlibs}"
   371         kx else
   371         kx     AC_MSG_RESULT([internal])
   371         kx     SYSTEM_MYTHES=
   371         kx     BUILD_TYPE="$BUILD_TYPE MYTHES"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         MYTHES_LIBS="${WORKDIR}/LinkTarget/StaticLibrary/mythes.lib"
   371         kx     else
   371         kx         MYTHES_LIBS="-L${WORKDIR}/UnpackedTarball/mythes/.libs -lmythes-1.2"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_MYTHES)
   371         kx AC_SUBST(MYTHES_CFLAGS)
   371         kx AC_SUBST(MYTHES_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl How should we build the linear programming solver ?
   371         kx dnl ===================================================================
   371         kx 
   371         kx ENABLE_COINMP=
   371         kx AC_MSG_CHECKING([whether to build with CoinMP])
   371         kx if test "$enable_coinmp" != "no"; then
   371         kx     ENABLE_COINMP=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx     if test "$with_system_coinmp" = "yes"; then
   371         kx         SYSTEM_COINMP=TRUE
   371         kx         PKG_CHECK_MODULES(COINMP, coinmp coinutils)
   371         kx         FilterLibs "${COINMP_LIBS}"
   371         kx         COINMP_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         BUILD_TYPE="$BUILD_TYPE COINMP"
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_COINMP)
   371         kx AC_SUBST(SYSTEM_COINMP)
   371         kx AC_SUBST(COINMP_CFLAGS)
   371         kx AC_SUBST(COINMP_LIBS)
   371         kx 
   371         kx ENABLE_LPSOLVE=
   371         kx AC_MSG_CHECKING([whether to build with lpsolve])
   371         kx if test "$enable_lpsolve" != "no"; then
   371         kx     ENABLE_LPSOLVE=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_LPSOLVE)
   371         kx 
   371         kx if test "$ENABLE_LPSOLVE" = TRUE; then
   371         kx     AC_MSG_CHECKING([which lpsolve to use])
   371         kx     if test "$with_system_lpsolve" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_LPSOLVE=TRUE
   371         kx         AC_CHECK_HEADER(lpsolve/lp_lib.h, [],
   371         kx            [ AC_MSG_ERROR(lpsolve headers not found.)], [])
   371         kx         save_LIBS=$LIBS
   371         kx         # some systems need this. Like Ubuntu...
   371         kx         AC_CHECK_LIB(m, floor)
   371         kx         AC_CHECK_LIB(dl, dlopen)
   371         kx         AC_CHECK_LIB([lpsolve55], [make_lp], [:],
   371         kx             [ AC_MSG_ERROR(lpsolve library not found or too old.)], [])
   371         kx         LIBS=$save_LIBS
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_LPSOLVE=
   371         kx         BUILD_TYPE="$BUILD_TYPE LPSOLVE"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LPSOLVE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checking for libexttextcat
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([libexttextcat],[LIBEXTTEXTCAT],[libexttextcat >= 3.4.1])
   371         kx if test "$with_system_libexttextcat" = "yes"; then
   371         kx     SYSTEM_LIBEXTTEXTCAT_DATA=file://`$PKG_CONFIG --variable=pkgdatadir libexttextcat`
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBEXTTEXTCAT_DATA)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checking for libnumbertext
   371         kx dnl ===================================================================
   371         kx libo_CHECK_SYSTEM_MODULE([libnumbertext],[LIBNUMBERTEXT],[libnumbertext >= 1.0.6])
   371         kx if test "$with_system_libnumbertext" = "yes"; then
   371         kx     SYSTEM_LIBNUMBERTEXT_DATA=file://`$PKG_CONFIG --variable=pkgdatadir libnumbertext`
   371         kx     SYSTEM_LIBNUMBERTEXT=YES
   371         kx else
   371         kx     SYSTEM_LIBNUMBERTEXT=
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBNUMBERTEXT)
   371         kx AC_SUBST(SYSTEM_LIBNUMBERTEXT_DATA)
   371         kx 
   371         kx dnl ***************************************
   371         kx dnl testing libc version for Linux...
   371         kx dnl ***************************************
   371         kx if test "$_os" = "Linux"; then
   371         kx     AC_MSG_CHECKING([whether the libc is recent enough])
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
   371         kx     #include <features.h>
   371         kx     #if defined(__GNU_LIBRARY__) && (__GLIBC__ < 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ < 1))
   371         kx     #error glibc >= 2.1 is required
   371         kx     #endif
   371         kx     ]])],, [AC_MSG_RESULT([yes])], [AC_MSG_ERROR([no, upgrade libc])])
   371         kx fi
   371         kx 
   371         kx dnl =========================================
   371         kx dnl Check for uuidgen
   371         kx dnl =========================================
   371         kx if test "$_os" = "WINNT"; then
   371         kx     # we must use the uuidgen from the Windows SDK, which will be in the LO_PATH, but isn't in
   371         kx     # the PATH for AC_PATH_PROG. It is already tested above in the WINDOWS_SDK_HOME check.
   371         kx     UUIDGEN=uuidgen.exe
   371         kx     AC_SUBST(UUIDGEN)
   371         kx else
   371         kx     AC_PATH_PROG([UUIDGEN], [uuidgen])
   371         kx     if test -z "$UUIDGEN"; then
   371         kx         AC_MSG_WARN([uuid is needed for building installation sets])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ***************************************
   371         kx dnl Checking for bison and flex
   371         kx dnl ***************************************
   371         kx AC_PATH_PROG(BISON, bison)
   371         kx if test -z "$BISON"; then
   371         kx     AC_MSG_ERROR([no bison found in \$PATH, install it])
   371         kx else
   371         kx     AC_MSG_CHECKING([the bison version])
   371         kx     _bison_version=`$BISON --version | grep GNU | $SED -e 's@^[[^0-9]]*@@' -e 's@ .*@@' -e 's@,.*@@'`
   371         kx     _bison_longver=`echo $_bison_version | $AWK -F. '{ print \$1*1000+\$2}'`
   371         kx     dnl Accept newer than 2.0; for --enable-compiler-plugins at least 2.3 is known to be bad and
   371         kx     dnl cause
   371         kx     dnl
   371         kx     dnl   idlc/source/parser.y:222:15: error: externally available entity 'YYSTYPE' is not previously declared in an included file (if it is only used in this translation unit, put it in an unnamed namespace; otherwise, provide a declaration of it in an included file) [loplugin:external]
   371         kx     dnl   typedef union YYSTYPE
   371         kx     dnl           ~~~~~~^~~~~~~
   371         kx     dnl
   371         kx     dnl while at least 3.4.1 is know to be good:
   371         kx     if test "$COMPILER_PLUGINS" = TRUE; then
   371         kx         if test "$_bison_longver" -lt 2004; then
   371         kx             AC_MSG_ERROR([failed ($BISON $_bison_version need 2.4+ for --enable-compiler-plugins)])
   371         kx         fi
   371         kx     else
   371         kx         if test "$_bison_longver" -lt 2000; then
   371         kx             AC_MSG_ERROR([failed ($BISON $_bison_version need 2.0+)])
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([BISON])
   371         kx 
   371         kx AC_PATH_PROG(FLEX, flex)
   371         kx if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx     FLEX=`cygpath -m $FLEX`
   371         kx fi
   371         kx if test -z "$FLEX"; then
   371         kx     AC_MSG_ERROR([no flex found in \$PATH, install it])
   371         kx else
   371         kx     AC_MSG_CHECKING([the flex version])
   371         kx     _flex_version=$($FLEX --version | $SED -e 's/^.*\([[[:digit:]]]\{1,\}\.[[[:digit:]]]\{1,\}\.[[[:digit:]]]\{1,\}\).*$/\1/')
   371         kx     if test $(echo $_flex_version | $AWK -F. '{printf("%d%03d%03d", $1, $2, $3)}') -lt 2006000; then
   371         kx         AC_MSG_ERROR([failed ($FLEX $_flex_version found, but need at least 2.6.0)])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([FLEX])
   371         kx 
   371         kx AC_PATH_PROG(DIFF, diff)
   371         kx if test -z "$DIFF"; then
   371         kx     AC_MSG_ERROR(["diff" not found in \$PATH, install it])
   371         kx fi
   371         kx AC_SUBST([DIFF])
   371         kx 
   371         kx AC_PATH_PROG(UNIQ, uniq)
   371         kx if test -z "$UNIQ"; then
   371         kx     AC_MSG_ERROR(["uniq" not found in \$PATH, install it])
   371         kx fi
   371         kx AC_SUBST([UNIQ])
   371         kx 
   371         kx dnl ***************************************
   371         kx dnl Checking for patch
   371         kx dnl ***************************************
   371         kx AC_PATH_PROG(PATCH, patch)
   371         kx if test -z "$PATCH"; then
   371         kx     AC_MSG_ERROR(["patch" not found in \$PATH, install it])
   371         kx fi
   371         kx 
   371         kx dnl On Solaris or macOS, check if --with-gnu-patch was used
   371         kx if test "$_os" = "SunOS" -o "$_os" = "Darwin"; then
   371         kx     if test -z "$with_gnu_patch"; then
   371         kx         GNUPATCH=$PATCH
   371         kx     else
   371         kx         if test -x "$with_gnu_patch"; then
   371         kx             GNUPATCH=$with_gnu_patch
   371         kx         else
   371         kx             AC_MSG_ERROR([--with-gnu-patch did not point to an executable])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $GNUPATCH is GNU patch])
   371         kx     if $GNUPATCH --version | grep "Free Software Foundation" >/dev/null 2>/dev/null; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         if $GNUPATCH --version | grep "2\.0-.*-Apple" >/dev/null 2>/dev/null; then
   371         kx             AC_MSG_RESULT([no, but accepted (Apple patch)])
   371         kx             add_warning "patch utility is not GNU patch. Apple's patch should work OK, but it might experience issues where GNU patch doesn't."
   371         kx         else
   371         kx             AC_MSG_ERROR([no, GNU patch needed. install or specify with --with-gnu-patch=/path/to/it])
   371         kx         fi
   371         kx     fi
   371         kx else
   371         kx     GNUPATCH=$PATCH
   371         kx fi
   371         kx 
   371         kx if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx     GNUPATCH=`cygpath -m $GNUPATCH`
   371         kx fi
   371         kx 
   371         kx dnl We also need to check for --with-gnu-cp
   371         kx 
   371         kx if test -z "$with_gnu_cp"; then
   371         kx     # check the place where the good stuff is hidden on Solaris...
   371         kx     if test -x /usr/gnu/bin/cp; then
   371         kx         GNUCP=/usr/gnu/bin/cp
   371         kx     else
   371         kx         AC_PATH_PROGS(GNUCP, gnucp cp)
   371         kx     fi
   371         kx     if test -z $GNUCP; then
   371         kx         AC_MSG_ERROR([Neither gnucp nor cp found. Install GNU cp and/or specify --with-gnu-cp=/path/to/it])
   371         kx     fi
   371         kx else
   371         kx     if test -x "$with_gnu_cp"; then
   371         kx         GNUCP=$with_gnu_cp
   371         kx     else
   371         kx         AC_MSG_ERROR([--with-gnu-cp did not point to an executable])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx     GNUCP=`cygpath -m $GNUCP`
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether $GNUCP is GNU cp from coreutils with preserve= support])
   371         kx if $GNUCP --version 2>/dev/null | grep "coreutils" >/dev/null 2>/dev/null; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx elif $GNUCP --version 2>/dev/null | grep "GNU fileutils" >/dev/null 2>/dev/null; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     case "$build_os" in
   371         kx     darwin*|netbsd*|openbsd*|freebsd*|dragonfly*)
   371         kx         x_GNUCP=[\#]
   371         kx         GNUCP=''
   371         kx         AC_MSG_RESULT([no gnucp found - using the system's cp command])
   371         kx         ;;
   371         kx     *)
   371         kx         AC_MSG_ERROR([no, GNU cp needed. install or specify with --with-gnu-cp=/path/to/it])
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx AC_SUBST(GNUPATCH)
   371         kx AC_SUBST(GNUCP)
   371         kx AC_SUBST(x_GNUCP)
   371         kx 
   371         kx dnl ***************************************
   371         kx dnl testing assembler path
   371         kx dnl ***************************************
   371         kx ML_EXE=""
   371         kx if test "$_os" = "WINNT"; then
   371         kx     case "$WIN_HOST_ARCH" in
   371         kx     x86) assembler=ml.exe ;;
   371         kx     x64) assembler=ml64.exe ;;
   371         kx     arm64) assembler=armasm64.exe ;;
   371         kx     esac
   371         kx 
   371         kx     AC_MSG_CHECKING([for the MSVC assembler ($assembler)])
   371         kx     if test -f "$MSVC_HOST_PATH/$assembler"; then
   371         kx         ML_EXE=`win_short_path_for_make "$MSVC_HOST_PATH/$assembler"`
   371         kx         AC_MSG_RESULT([$ML_EXE])
   371         kx     else
   371         kx         AC_MSG_ERROR([not found in $MSVC_HOST_PATH])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ML_EXE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl We need zip and unzip
   371         kx dnl ===================================================================
   371         kx AC_PATH_PROG(ZIP, zip)
   371         kx test -z "$ZIP" && AC_MSG_ERROR([zip is required])
   371         kx if ! "$ZIP" --filesync < /dev/null 2>/dev/null > /dev/null; then
   371         kx     AC_MSG_ERROR([Zip version 3.0 or newer is required to build, please install it and make sure it is the one found first in PATH],,)
   371         kx fi
   371         kx 
   371         kx AC_PATH_PROG(UNZIP, unzip)
   371         kx test -z "$UNZIP" && AC_MSG_ERROR([unzip is required])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Zip must be a specific type for different build types.
   371         kx dnl ===================================================================
   371         kx if test $build_os = cygwin; then
   371         kx     if test -n "`$ZIP -h | $GREP -i WinNT`"; then
   371         kx         AC_MSG_ERROR([$ZIP is not the required Cygwin version of Info-ZIP's zip.exe.])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl We need touch with -h option support.
   371         kx dnl ===================================================================
   371         kx AC_PATH_PROG(TOUCH, touch)
   371         kx test -z "$TOUCH" && AC_MSG_ERROR([touch is required])
   371         kx touch "$WARNINGS_FILE"
   371         kx if ! "$TOUCH" -h "$WARNINGS_FILE" 2>/dev/null > /dev/null; then
   371         kx     AC_MSG_ERROR([touch version with -h option support is required to build, please install it and make sure it is the one found first in PATH],,)
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for system epoxy
   371         kx dnl ===================================================================
   371         kx EPOXY_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/epoxy/include"
   371         kx libo_CHECK_SYSTEM_MODULE([epoxy], [EPOXY], [epoxy >= 1.2])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Show which vclplugs will be built.
   371         kx dnl ===================================================================
   371         kx R=""
   371         kx 
   371         kx libo_ENABLE_VCLPLUG([gen])
   371         kx libo_ENABLE_VCLPLUG([gtk3])
   371         kx libo_ENABLE_VCLPLUG([gtk3_kde5])
   371         kx libo_ENABLE_VCLPLUG([gtk4])
   371         kx libo_ENABLE_VCLPLUG([kf5])
   371         kx libo_ENABLE_VCLPLUG([kf6])
   371         kx libo_ENABLE_VCLPLUG([qt5])
   371         kx libo_ENABLE_VCLPLUG([qt6])
   371         kx 
   371         kx if test "$_os" = "WINNT"; then
   371         kx     R="$R win"
   371         kx elif test "$_os" = "Darwin"; then
   371         kx     R="$R osx"
   371         kx elif test "$_os" = "iOS"; then
   371         kx     R="ios"
   371         kx elif test "$_os" = Android; then
   371         kx     R="android"
   371         kx fi
   371         kx 
   371         kx build_vcl_plugins="$R"
   371         kx if test -z "$build_vcl_plugins"; then
   371         kx     build_vcl_plugins=" none"
   371         kx fi
   371         kx AC_MSG_NOTICE([VCLplugs to be built:${build_vcl_plugins}])
   371         kx VCL_PLUGIN_INFO=$R
   371         kx AC_SUBST([VCL_PLUGIN_INFO])
   371         kx 
   371         kx if test "$DISABLE_DYNLOADING" = TRUE -a -z "$DISABLE_GUI" -a \( -z "$R" -o $(echo "$R" | wc -w) -ne 1 \); then
   371         kx     AC_MSG_ERROR([Can't build --disable-dynamic-loading without --disable-gui and a single VCL plugin"])
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for GTK libraries
   371         kx dnl ===================================================================
   371         kx 
   371         kx GTK3_CFLAGS=""
   371         kx GTK3_LIBS=""
   371         kx ENABLE_GTKTILEDVIEWER=""
   371         kx if test "$test_gtk3" = yes -a "x$enable_gtk3" = "xyes" -o "x$enable_gtk3_kde5" = "xyes"; then
   371         kx     if test "$with_system_cairo" = no; then
   371         kx         add_warning 'Non-system cairo combined with gtk3 is known to cause trouble (eg. broken image in the splashscreen). Use --with-system-cairo unless you know what you are doing.'
   371         kx     fi
   371         kx     : ${with_system_cairo:=yes}
   371         kx     PKG_CHECK_MODULES(GTK3, gtk+-3.0 >= 3.20 gtk+-unix-print-3.0 gmodule-no-export-2.0 glib-2.0 >= 2.38 atk >= 2.28.1 cairo)
   371         kx     GTK3_CFLAGS=$(printf '%s' "$GTK3_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     GTK3_CFLAGS="$GTK3_CFLAGS -DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED"
   371         kx     FilterLibs "${GTK3_LIBS}"
   371         kx     GTK3_LIBS="${filteredlibs}"
   371         kx 
   371         kx     dnl We require egl only for the gtk3 plugin. Otherwise we use glx.
   371         kx     if test "$with_system_epoxy" != "yes"; then
   371         kx         AC_CHECK_LIB(EGL, eglMakeCurrent, [:], AC_MSG_ERROR([libEGL required.]))
   371         kx         AC_CHECK_HEADER(EGL/eglplatform.h, [],
   371         kx                         [AC_MSG_ERROR(EGL headers not found. install mesa-libEGL-devel)], [])
   371         kx     fi
   371         kx elif test -n "$with_gtk3_build" -a "$OS" = "WNT"; then
   371         kx     PathFormat "${with_gtk3_build}/lib/pkgconfig"
   371         kx     if test "$build_os" = "cygwin"; then
   371         kx         dnl cygwin's pkg-config does not recognize "C:/..."-style paths, only "/cygdrive/c/..."
   371         kx         formatted_path_unix=`cygpath -au "$formatted_path_unix"`
   371         kx     fi
   371         kx 
   371         kx     PKG_CONFIG_PATH="$formatted_path_unix"; export PKG_CONFIG_PATH
   371         kx     PKG_CHECK_MODULES(GTK3, cairo gdk-3.0 gio-2.0 glib-2.0 gobject-2.0 gtk+-3.0)
   371         kx     GTK3_CFLAGS="$GTK3_CFLAGS -DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED"
   371         kx     FilterLibs "${GTK3_LIBS}"
   371         kx     GTK3_LIBS="${filteredlibs}"
   371         kx     ENABLE_GTKTILEDVIEWER="yes"
   371         kx fi
   371         kx AC_SUBST(GTK3_LIBS)
   371         kx AC_SUBST(GTK3_CFLAGS)
   371         kx AC_SUBST(ENABLE_GTKTILEDVIEWER)
   371         kx 
   371         kx GTK4_CFLAGS=""
   371         kx GTK4_LIBS=""
   371         kx if test "$test_gtk4" = yes -a "x$enable_gtk4" = "xyes"; then
   371         kx     if test "$with_system_cairo" = no; then
   371         kx         add_warning 'Non-system cairo combined with gtk4 is assumed to cause trouble; proceed at your own risk.'
   371         kx     fi
   371         kx     : ${with_system_cairo:=yes}
   371         kx     PKG_CHECK_MODULES(GTK4, gtk4 gmodule-no-export-2.0 glib-2.0 >= 2.38 cairo atk)
   371         kx     GTK4_CFLAGS=$(printf '%s' "$GTK4_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     GTK4_CFLAGS="$GTK4_CFLAGS -DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED"
   371         kx     FilterLibs "${GTK4_LIBS}"
   371         kx     GTK4_LIBS="${filteredlibs}"
   371         kx 
   371         kx     dnl We require egl only for the gtk4 plugin. Otherwise we use glx.
   371         kx     if test "$with_system_epoxy" != "yes"; then
   371         kx         AC_CHECK_LIB(EGL, eglMakeCurrent, [:], AC_MSG_ERROR([libEGL required.]))
   371         kx         AC_CHECK_HEADER(EGL/eglplatform.h, [],
   371         kx                         [AC_MSG_ERROR(EGL headers not found. install mesa-libEGL-devel)], [])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(GTK4_LIBS)
   371         kx AC_SUBST(GTK4_CFLAGS)
   371         kx 
   371         kx if test "$enable_introspection" = yes; then
   371         kx     if test "$ENABLE_GTK3" = "TRUE" -o "$ENABLE_GTK3_KDE5" = "TRUE"; then
   371         kx         GOBJECT_INTROSPECTION_REQUIRE(INTROSPECTION_REQUIRED_VERSION)
   371         kx     else
   371         kx         AC_MSG_ERROR([--enable-introspection requires --enable-gtk3])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx # AT-SPI2 tests require gtk3, xvfb-run, dbus-launch and atspi-2
   371         kx if ! test "$ENABLE_GTK3" = TRUE; then
   371         kx     if test "$enable_atspi_tests" = yes; then
   371         kx         AC_MSG_ERROR([--enable-atspi-tests requires --enable-gtk3])
   371         kx     fi
   371         kx     enable_atspi_tests=no
   371         kx fi
   371         kx if ! test "$enable_atspi_tests" = no; then
   371         kx     AC_PATH_PROGS([XVFB_RUN], [xvfb-run], no)
   371         kx     if ! test "$XVFB_RUN" = no; then
   371         kx         dnl make sure the found xvfb-run actually works
   371         kx         AC_MSG_CHECKING([whether $XVFB_RUN works...])
   371         kx         if $XVFB_RUN --auto-servernum true >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD; then
   371         kx             AC_MSG_RESULT([yes])
   371         kx         else
   371         kx             AC_MSG_RESULT([no])
   371         kx             XVFB_RUN=no
   371         kx         fi
   371         kx     fi
   371         kx     if test "$XVFB_RUN" = no; then
   371         kx         if test "$enable_atspi_tests" = yes; then
   371         kx             AC_MSG_ERROR([xvfb-run required by --enable-atspi-tests not found])
   371         kx         fi
   371         kx         enable_atspi_tests=no
   371         kx     fi
   371         kx fi
   371         kx if ! test "$enable_atspi_tests" = no; then
   371         kx     AC_PATH_PROGS([DBUS_LAUNCH], [dbus-launch], no)
   371         kx     if test "$DBUS_LAUNCH" = no; then
   371         kx         if test "$enable_atspi_tests" = yes; then
   371         kx             AC_MSG_ERROR([dbus-launch required by --enable-atspi-tests not found])
   371         kx         fi
   371         kx         enable_atspi_tests=no
   371         kx     fi
   371         kx fi
   371         kx if ! test "$enable_atspi_tests" = no; then
   371         kx     PKG_CHECK_MODULES([ATSPI2], [atspi-2 gobject-2.0],,
   371         kx                       [if test "$enable_atspi_tests" = yes; then
   371         kx                            AC_MSG_ERROR([$ATSPI2_PKG_ERRORS])
   371         kx                        else
   371         kx                            enable_atspi_tests=no
   371         kx                        fi])
   371         kx fi
   371         kx if ! test "x$enable_atspi_tests" = xno; then
   371         kx     PKG_CHECK_MODULES([ATSPI2_2_32], [atspi-2 >= 2.32],
   371         kx                       [have_atspi_scroll_to=1],
   371         kx                       [have_atspi_scroll_to=0])
   371         kx     AC_DEFINE_UNQUOTED([HAVE_ATSPI2_SCROLL_TO], [$have_atspi_scroll_to],
   371         kx                        [Whether AT-SPI2 has the scrollTo API])
   371         kx fi
   371         kx ENABLE_ATSPI_TESTS=
   371         kx test "$enable_atspi_tests" = no || ENABLE_ATSPI_TESTS=TRUE
   371         kx AC_SUBST([ENABLE_ATSPI_TESTS])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl check for dbus support
   371         kx dnl ===================================================================
   371         kx ENABLE_DBUS=""
   371         kx DBUS_CFLAGS=""
   371         kx DBUS_LIBS=""
   371         kx DBUS_GLIB_CFLAGS=""
   371         kx DBUS_GLIB_LIBS=""
   371         kx DBUS_HAVE_GLIB=""
   371         kx 
   371         kx if test "$enable_dbus" = "no"; then
   371         kx     test_dbus=no
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable DBUS support])
   371         kx if test "$test_dbus" = "yes"; then
   371         kx     ENABLE_DBUS="TRUE"
   371         kx     AC_MSG_RESULT([yes])
   371         kx     PKG_CHECK_MODULES(DBUS, dbus-1 >= 0.60)
   371         kx     AC_DEFINE(ENABLE_DBUS)
   371         kx     DBUS_CFLAGS=$(printf '%s' "$DBUS_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${DBUS_LIBS}"
   371         kx     DBUS_LIBS="${filteredlibs}"
   371         kx 
   371         kx     # Glib is needed for BluetoothServer
   371         kx     # Sets also DBUS_GLIB_CFLAGS/DBUS_GLIB_LIBS if successful.
   371         kx     PKG_CHECK_MODULES(DBUS_GLIB,[glib-2.0 >= 2.4],
   371         kx         [
   371         kx             DBUS_HAVE_GLIB="TRUE"
   371         kx             AC_DEFINE(DBUS_HAVE_GLIB,1)
   371         kx         ],
   371         kx         AC_MSG_WARN([[No Glib found, Bluetooth support will be disabled]])
   371         kx     )
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_DBUS)
   371         kx AC_SUBST(DBUS_CFLAGS)
   371         kx AC_SUBST(DBUS_LIBS)
   371         kx AC_SUBST(DBUS_GLIB_CFLAGS)
   371         kx AC_SUBST(DBUS_GLIB_LIBS)
   371         kx AC_SUBST(DBUS_HAVE_GLIB)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable Impress remote control])
   371         kx if test -n "$enable_sdremote" -a "$enable_sdremote" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_SDREMOTE=TRUE
   371         kx     SDREMOTE_ENTITLEMENT="	<key>com.apple.security.network.server</key>
   371         kx 	<true/>"
   371         kx     AC_MSG_CHECKING([whether to enable Bluetooth support in Impress remote control])
   371         kx 
   371         kx     if test $OS = MACOSX && test "$MACOSX_SDK_VERSION" -ge 101500; then
   371         kx         # The Bluetooth code doesn't compile with macOS SDK 10.15
   371         kx         if test "$enable_sdremote_bluetooth" = yes; then
   371         kx             AC_MSG_ERROR([macOS SDK $macosx_sdk does not currently support --enable-sdremote-bluetooth])
   371         kx         fi
   371         kx         add_warning "not building the bluetooth part of the sdremote - used api was removed from macOS SDK 10.15"
   371         kx         enable_sdremote_bluetooth=no
   371         kx     fi
   371         kx     # If not explicitly enabled or disabled, default
   371         kx     if test -z "$enable_sdremote_bluetooth"; then
   371         kx         case "$OS" in
   371         kx         LINUX|MACOSX|WNT)
   371         kx             # Default to yes for these
   371         kx             enable_sdremote_bluetooth=yes
   371         kx             ;;
   371         kx         *)
   371         kx             # otherwise no
   371         kx             enable_sdremote_bluetooth=no
   371         kx             ;;
   371         kx         esac
   371         kx     fi
   371         kx     # $enable_sdremote_bluetooth is guaranteed non-empty now
   371         kx 
   371         kx     if test "$enable_sdremote_bluetooth" != "no"; then
   371         kx         if test "$OS" = "LINUX"; then
   371         kx             if test "$ENABLE_DBUS" = "TRUE" -a "$DBUS_HAVE_GLIB" = "TRUE"; then
   371         kx                 AC_MSG_RESULT([yes])
   371         kx                 ENABLE_SDREMOTE_BLUETOOTH=TRUE
   371         kx                 dnl ===================================================================
   371         kx                 dnl Check for system bluez
   371         kx                 dnl ===================================================================
   371         kx                 AC_MSG_CHECKING([which Bluetooth header to use])
   371         kx                 if test "$with_system_bluez" = "yes"; then
   371         kx                     AC_MSG_RESULT([external])
   371         kx                     AC_CHECK_HEADER(bluetooth/bluetooth.h, [],
   371         kx                         [AC_MSG_ERROR(bluetooth.h not found. install bluez)], [])
   371         kx                     SYSTEM_BLUEZ=TRUE
   371         kx                 else
   371         kx                     AC_MSG_RESULT([internal])
   371         kx                     SYSTEM_BLUEZ=
   371         kx                 fi
   371         kx             else
   371         kx                 AC_MSG_RESULT([no, dbus disabled])
   371         kx                 ENABLE_SDREMOTE_BLUETOOTH=
   371         kx                 SYSTEM_BLUEZ=
   371         kx             fi
   371         kx         else
   371         kx             AC_MSG_RESULT([yes])
   371         kx             ENABLE_SDREMOTE_BLUETOOTH=TRUE
   371         kx             SYSTEM_BLUEZ=
   371         kx             SDREMOTE_ENTITLEMENT="$SDREMOTE_ENTITLEMENT
   371         kx 	<key>com.apple.security.device.bluetooth</key>
   371         kx 	<true/>"
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx         ENABLE_SDREMOTE_BLUETOOTH=
   371         kx         SYSTEM_BLUEZ=
   371         kx     fi
   371         kx else
   371         kx     ENABLE_SDREMOTE=
   371         kx     SYSTEM_BLUEZ=
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_SDREMOTE)
   371         kx AC_SUBST(ENABLE_SDREMOTE_BLUETOOTH)
   371         kx AC_SUBST(SDREMOTE_ENTITLEMENT)
   371         kx AC_SUBST(SYSTEM_BLUEZ)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check whether to enable GIO support
   371         kx dnl ===================================================================
   371         kx if test "$ENABLE_GTK4" = "TRUE" -o "$ENABLE_GTK3" = "TRUE" -o "$ENABLE_GTK3_KDE5" = "TRUE"; then
   371         kx     AC_MSG_CHECKING([whether to enable GIO support])
   371         kx     if test "$_os" != "WINNT" -a "$_os" != "Darwin" -a "$enable_gio" = "yes"; then
   371         kx         dnl Need at least 2.26 for the dbus support.
   371         kx         PKG_CHECK_MODULES([GIO], [gio-2.0 >= 2.26],
   371         kx                           [ENABLE_GIO="TRUE"], [ENABLE_GIO=""])
   371         kx         if test "$ENABLE_GIO" = "TRUE"; then
   371         kx             AC_DEFINE(ENABLE_GIO)
   371         kx             GIO_CFLAGS=$(printf '%s' "$GIO_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx             FilterLibs "${GIO_LIBS}"
   371         kx             GIO_LIBS="${filteredlibs}"
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_GIO)
   371         kx AC_SUBST(GIO_CFLAGS)
   371         kx AC_SUBST(GIO_LIBS)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx 
   371         kx SPLIT_APP_MODULES=""
   371         kx if test "$enable_split_app_modules" = "yes"; then
   371         kx     SPLIT_APP_MODULES="TRUE"
   371         kx fi
   371         kx AC_SUBST(SPLIT_APP_MODULES)
   371         kx 
   371         kx SPLIT_OPT_FEATURES=""
   371         kx if test "$enable_split_opt_features" = "yes"; then
   371         kx     SPLIT_OPT_FEATURES="TRUE"
   371         kx fi
   371         kx AC_SUBST(SPLIT_OPT_FEATURES)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check whether the GStreamer libraries are available.
   371         kx dnl ===================================================================
   371         kx 
   371         kx ENABLE_GSTREAMER_1_0=""
   371         kx 
   371         kx if test "$test_gstreamer_1_0" = yes; then
   371         kx 
   371         kx     AC_MSG_CHECKING([whether to enable the GStreamer 1.0 avmedia backend])
   371         kx     if test "$enable_avmedia" = yes -a "$enable_gstreamer_1_0" != no; then
   371         kx         ENABLE_GSTREAMER_1_0="TRUE"
   371         kx         AC_MSG_RESULT([yes])
   371         kx         PKG_CHECK_MODULES( [GSTREAMER_1_0], [gstreamer-1.0 gstreamer-plugins-base-1.0 gstreamer-pbutils-1.0 gstreamer-video-1.0] )
   371         kx         GSTREAMER_1_0_CFLAGS=$(printf '%s' "$GSTREAMER_1_0_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${GSTREAMER_1_0_LIBS}"
   371         kx         GSTREAMER_1_0_LIBS="${filteredlibs}"
   371         kx         AC_DEFINE(ENABLE_GSTREAMER_1_0)
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(GSTREAMER_1_0_CFLAGS)
   371         kx AC_SUBST(GSTREAMER_1_0_LIBS)
   371         kx AC_SUBST(ENABLE_GSTREAMER_1_0)
   371         kx 
   371         kx ENABLE_OPENGL_TRANSITIONS=
   371         kx ENABLE_OPENGL_CANVAS=
   371         kx if test $_os = iOS -o $_os = Android -o "$ENABLE_FUZZERS" = "TRUE"; then
   371         kx    : # disable
   371         kx elif test "$_os" = "Darwin"; then
   371         kx     # We use frameworks on macOS, no need for detail checks
   371         kx     ENABLE_OPENGL_TRANSITIONS=TRUE
   371         kx     AC_DEFINE(HAVE_FEATURE_OPENGL,1)
   371         kx     ENABLE_OPENGL_CANVAS=TRUE
   371         kx elif test $_os = WINNT; then
   371         kx     ENABLE_OPENGL_TRANSITIONS=TRUE
   371         kx     AC_DEFINE(HAVE_FEATURE_OPENGL,1)
   371         kx     ENABLE_OPENGL_CANVAS=TRUE
   371         kx else
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         AC_CHECK_LIB(GL, glBegin, [:], AC_MSG_ERROR([libGL required.]))
   371         kx         ENABLE_OPENGL_TRANSITIONS=TRUE
   371         kx         AC_DEFINE(HAVE_FEATURE_OPENGL,1)
   371         kx         ENABLE_OPENGL_CANVAS=TRUE
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_OPENGL_TRANSITIONS)
   371         kx AC_SUBST(ENABLE_OPENGL_CANVAS)
   371         kx 
   371         kx dnl =================================================
   371         kx dnl Check whether to build with OpenCL support.
   371         kx dnl =================================================
   371         kx 
   371         kx if test $_os != iOS -a $_os != Android -a "$ENABLE_FUZZERS" != "TRUE" -a "$enable_opencl" = "yes"; then
   371         kx     # OPENCL in BUILD_TYPE and HAVE_FEATURE_OPENCL tell that OpenCL is potentially available on the
   371         kx     # platform (optional at run-time, used through clew).
   371         kx     BUILD_TYPE="$BUILD_TYPE OPENCL"
   371         kx     AC_DEFINE(HAVE_FEATURE_OPENCL)
   371         kx fi
   371         kx 
   371         kx dnl =================================================
   371         kx dnl Check whether to build with dconf support.
   371         kx dnl =================================================
   371         kx 
   371         kx if test $_os != Android -a $_os != iOS -a "$enable_dconf" != no; then
   371         kx     PKG_CHECK_MODULES([DCONF], [dconf >= 0.40.0], [], [
   371         kx         if test "$enable_dconf" = yes; then
   371         kx             AC_MSG_ERROR([dconf not found])
   371         kx         else
   371         kx             enable_dconf=no
   371         kx         fi])
   371         kx fi
   371         kx AC_MSG_CHECKING([whether to enable dconf])
   371         kx if test $_os = Android -o $_os = iOS -o "$enable_dconf" = no; then
   371         kx     DCONF_CFLAGS=
   371         kx     DCONF_LIBS=
   371         kx     ENABLE_DCONF=
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     ENABLE_DCONF=TRUE
   371         kx     AC_DEFINE(ENABLE_DCONF)
   371         kx     AC_MSG_RESULT([yes])
   371         kx fi
   371         kx AC_SUBST([DCONF_CFLAGS])
   371         kx AC_SUBST([DCONF_LIBS])
   371         kx AC_SUBST([ENABLE_DCONF])
   371         kx 
   371         kx # pdf import?
   371         kx AC_MSG_CHECKING([whether to build the PDF import feature])
   371         kx ENABLE_PDFIMPORT=
   371         kx if test -z "$enable_pdfimport" -o "$enable_pdfimport" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_PDFIMPORT=TRUE
   371         kx     AC_DEFINE(HAVE_FEATURE_PDFIMPORT)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx # Pdfium?
   371         kx AC_MSG_CHECKING([whether to build PDFium])
   371         kx ENABLE_PDFIUM=
   371         kx if test \( -z "$enable_pdfium" -a "$ENABLE_PDFIMPORT" = "TRUE" \) -o "$enable_pdfium" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_PDFIUM=TRUE
   371         kx     BUILD_TYPE="$BUILD_TYPE PDFIUM"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_PDFIUM)
   371         kx 
   371         kx if test "$ENABLE_PDFIUM" = "TRUE"; then
   371         kx     AC_MSG_CHECKING([which OpenJPEG library to use])
   371         kx     if test "$with_system_openjpeg" = "yes"; then
   371         kx         SYSTEM_OPENJPEG2=TRUE
   371         kx         AC_MSG_RESULT([external])
   371         kx         PKG_CHECK_MODULES( OPENJPEG2, libopenjp2 )
   371         kx         OPENJPEG2_CFLAGS=$(printf '%s' "$OPENJPEG2_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${OPENJPEG2_LIBS}"
   371         kx         OPENJPEG2_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         SYSTEM_OPENJPEG2=FALSE
   371         kx         AC_MSG_RESULT([internal])
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([which Abseil library to use])
   371         kx     if test "$with_system_abseil" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_ABSEIL=TRUE
   371         kx         AC_LANG_PUSH([C++])
   371         kx         AC_CHECK_HEADER(absl/types/bad_optional_access.h, [],
   371         kx                         [AC_MSG_ERROR(abseil headers not found.)], [])
   371         kx         AC_CHECK_HEADER(absl/types/bad_variant_access.h, [],
   371         kx                         [AC_MSG_ERROR(abseil headers not found.)], [])
   371         kx         AC_CHECK_LIB([absl_bad_optional_access], [main], [],
   371         kx                      [AC_MSG_ERROR([libabsl_bad_optional_access library not found.])])
   371         kx         AC_CHECK_LIB([absl_bad_variant_access], [main], [],
   371         kx                      [AC_MSG_ERROR([libabsl_bad_variant_access library not found.])])
   371         kx         ABSEIL_LIBS="-labsl_bad_optional_access -labsl_bad_variant_access"
   371         kx         AC_LANG_POP([C++])
   371         kx         ABSEIL_CFLAGS=$(printf '%s' "$ABSEIL_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${ABSEIL_LIBS}"
   371         kx         ABSEIL_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_OPENJPEG2)
   371         kx AC_SUBST(SYSTEM_ABSEIL)
   371         kx AC_SUBST(ABSEIL_CFLAGS)
   371         kx AC_SUBST(ABSEIL_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for poppler
   371         kx dnl ===================================================================
   371         kx ENABLE_POPPLER=
   371         kx AC_MSG_CHECKING([whether to build Poppler])
   371         kx if test \( -z "$enable_poppler" -a "$ENABLE_PDFIMPORT" = "TRUE" -a $_os != Android \) -o "$enable_poppler" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_POPPLER=TRUE
   371         kx     AC_DEFINE(HAVE_FEATURE_POPPLER)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_POPPLER)
   371         kx 
   371         kx if test "$ENABLE_PDFIMPORT" = "TRUE" -a "$ENABLE_POPPLER" != "TRUE" -a "$ENABLE_PDFIUM" != "TRUE"; then
   371         kx     AC_MSG_ERROR([Cannot import PDF without either Pdfium or Poppler; please enable either of them.])
   371         kx fi
   371         kx 
   371         kx if test "$ENABLE_PDFIMPORT" != "TRUE" -a \( "$ENABLE_POPPLER" = "TRUE" -o "$ENABLE_PDFIUM" = "TRUE" \); then
   371         kx     AC_MSG_ERROR([Cannot enable Pdfium or Poppler when PDF importing is disabled; please enable PDF import first.])
   371         kx fi
   371         kx 
   371         kx if test "$ENABLE_PDFIMPORT" = "TRUE" -a "$ENABLE_POPPLER" = "TRUE"; then
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system poppler
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which PDF import poppler to use])
   371         kx     if test "$with_system_poppler" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_POPPLER=TRUE
   371         kx         PKG_CHECK_MODULES(POPPLER,[poppler >= 0.14 poppler-cpp])
   371         kx         POPPLER_CFLAGS=$(printf '%s' "$POPPLER_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${POPPLER_LIBS}"
   371         kx         POPPLER_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_POPPLER=
   371         kx         BUILD_TYPE="$BUILD_TYPE POPPLER"
   371         kx     fi
   371         kx     AC_DEFINE([ENABLE_PDFIMPORT],1)
   371         kx fi
   371         kx AC_SUBST(ENABLE_PDFIMPORT)
   371         kx AC_SUBST(SYSTEM_POPPLER)
   371         kx AC_SUBST(POPPLER_CFLAGS)
   371         kx AC_SUBST(POPPLER_LIBS)
   371         kx 
   371         kx # Skia?
   371         kx ENABLE_SKIA=
   371         kx if test "$enable_skia" != "no" -a "$build_skia" = "yes" -a -z "$DISABLE_GUI"; then
   371         kx     # Skia now requires at least freetype2 >= 2.8.1, which is less that what LO requires as system freetype.
   371         kx     if test "$SYSTEM_FREETYPE" = TRUE; then
   371         kx         PKG_CHECK_EXISTS(freetype2 >= 21.0.15, # 21.0.15 = 2.8.1
   371         kx             [skia_freetype_ok=yes],
   371         kx             [skia_freetype_ok=no])
   371         kx     else # internal is ok
   371         kx         skia_freetype_ok=yes
   371         kx     fi
   371         kx     AC_MSG_CHECKING([whether to build Skia])
   371         kx     if test "$skia_freetype_ok" = "yes"; then
   371         kx         if test "$enable_skia" = "debug"; then
   371         kx             AC_MSG_RESULT([yes (debug)])
   371         kx             ENABLE_SKIA_DEBUG=TRUE
   371         kx         else
   371         kx             AC_MSG_RESULT([yes])
   371         kx             ENABLE_SKIA_DEBUG=
   371         kx         fi
   371         kx         ENABLE_SKIA=TRUE
   371         kx         if test "$ENDIANNESS" = "big" && test "$ENABLE_SKIA" = "TRUE"; then
   371         kx             AC_MSG_ERROR([skia doesn't work/isn't supported upstream on big-endian. Use --disable-skia])
   371         kx         fi
   371         kx 
   371         kx         AC_DEFINE(HAVE_FEATURE_SKIA)
   371         kx         BUILD_TYPE="$BUILD_TYPE SKIA"
   371         kx 
   371         kx         if test "$OS" = "MACOSX"; then
   371         kx             AC_DEFINE(SK_GANESH,1)
   371         kx             AC_DEFINE(SK_METAL,1)
   371         kx             SKIA_GPU=METAL
   371         kx             AC_SUBST(SKIA_GPU)
   371         kx         else
   371         kx             AC_DEFINE(SK_GANESH,1)
   371         kx             AC_DEFINE(SK_VULKAN,1)
   371         kx             SKIA_GPU=VULKAN
   371         kx             AC_SUBST(SKIA_GPU)
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([no (freetype too old)])
   371         kx         add_warning "freetype version is too old for Skia library, at least 2.8.1 required, Skia support disabled"
   371         kx     fi
   371         kx 
   371         kx else
   371         kx     AC_MSG_CHECKING([whether to build Skia])
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_SKIA)
   371         kx AC_SUBST(ENABLE_SKIA_DEBUG)
   371         kx 
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_SSE2=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_SSSE3=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_SSE41=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_SSE42=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_AVX=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_AVX2=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_AVX512=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_AVX512F=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_F16C=
   371         kx LO_CLANG_CXXFLAGS_INTRINSICS_FMA=
   371         kx LO_CLANG_VERSION=
   371         kx HAVE_LO_CLANG_DLLEXPORTINLINES=
   371         kx 
   371         kx if test "$ENABLE_SKIA" = TRUE -a "$COM_IS_CLANG" != TRUE; then
   371         kx     if test -n "$LO_CLANG_CC" -a -n "$LO_CLANG_CXX"; then
   371         kx         AC_MSG_CHECKING([for Clang])
   371         kx         AC_MSG_RESULT([$LO_CLANG_CC / $LO_CLANG_CXX])
   371         kx     else
   371         kx         if test "$_os" = "WINNT"; then
   371         kx             AC_MSG_CHECKING([for clang-cl])
   371         kx             if test -x "$VC_PRODUCT_DIR/Tools/Llvm/bin/clang-cl.exe"; then
   371         kx                 LO_CLANG_CC=`win_short_path_for_make "$VC_PRODUCT_DIR/Tools/Llvm/bin/clang-cl.exe"`
   371         kx             elif test -n "$PROGRAMFILES" -a -x "$(cygpath -u "$PROGRAMFILES/LLVM/bin/clang-cl.exe")"; then
   371         kx                 LO_CLANG_CC=`win_short_path_for_make "$PROGRAMFILES/LLVM/bin/clang-cl.exe"`
   371         kx             elif test -x "$(cygpath -u "c:/Program Files/LLVM/bin/clang-cl.exe")"; then
   371         kx                 LO_CLANG_CC=`win_short_path_for_make "c:/Program Files/LLVM/bin/clang-cl.exe"`
   371         kx             fi
   371         kx             if test -n "$LO_CLANG_CC"; then
   371         kx                 dnl explicitly set -m32/-m64
   371         kx                 LO_CLANG_CC="$LO_CLANG_CC -m$WIN_HOST_BITS"
   371         kx                 LO_CLANG_CXX="$LO_CLANG_CC"
   371         kx                 AC_MSG_RESULT([$LO_CLANG_CC])
   371         kx             else
   371         kx                 AC_MSG_RESULT([no])
   371         kx             fi
   371         kx 
   371         kx             AC_MSG_CHECKING([the dependency generation prefix (clang.exe -showIncludes)])
   371         kx             echo "#include <stdlib.h>" > conftest.c
   371         kx             LO_CLANG_SHOWINCLUDES_PREFIX=`VSLANG=1033 $LO_CLANG_CC $CFLAGS -c -showIncludes conftest.c 2>/dev/null | \
   371         kx                 grep 'stdlib\.h' | head -n1 | sed 's/ [[[:alpha:]]]:.*//'`
   371         kx             rm -f conftest.c conftest.obj
   371         kx             if test -z "$LO_CLANG_SHOWINCLUDES_PREFIX"; then
   371         kx                 AC_MSG_ERROR([cannot determine the -showIncludes prefix])
   371         kx             else
   371         kx                 AC_MSG_RESULT(["$LO_CLANG_SHOWINCLUDES_PREFIX"])
   371         kx             fi
   371         kx         else
   371         kx             AC_CHECK_PROG(LO_CLANG_CC,clang,clang,[])
   371         kx             AC_CHECK_PROG(LO_CLANG_CXX,clang++,clang++,[])
   371         kx         fi
   371         kx     fi
   371         kx     if test -n "$LO_CLANG_CC" -a -n "$LO_CLANG_CXX"; then
   371         kx         clang2_version=`echo __clang_major__.__clang_minor__.__clang_patchlevel__ | $LO_CLANG_CC -E - | tail -1 | sed 's/ //g'`
   371         kx         LO_CLANG_VERSION=`echo "$clang2_version" | $AWK -F. '{ print \$1*10000+(\$2<100?\$2:99)*100+(\$3<100?\$3:99) }'`
   371         kx         if test "$LO_CLANG_VERSION" -lt 50002; then
   371         kx             AC_MSG_WARN(["$clang2_version" is too old or unrecognized, must be at least Clang 5.0.2])
   371         kx             LO_CLANG_CC=
   371         kx             LO_CLANG_CXX=
   371         kx         fi
   371         kx     fi
   371         kx     if test -n "$LO_CLANG_CC" -a -n "$LO_CLANG_CXX" -a "$_os" = "WINNT"; then
   371         kx         save_CXX="$CXX"
   371         kx         CXX="$LO_CLANG_CXX"
   371         kx         AC_MSG_CHECKING([whether $CXX supports -Zc:dllexportInlines-])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS -Werror -Zc:dllexportInlines-"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE()], [
   371         kx                 HAVE_LO_CLANG_DLLEXPORTINLINES=TRUE
   371         kx                 AC_MSG_RESULT([yes])
   371         kx             ], [AC_MSG_RESULT([no])])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_LANG_POP([C++])
   371         kx         CXX="$save_CXX"
   371         kx         if test -z "$HAVE_LO_CLANG_DLLEXPORTINLINES"; then
   371         kx             AC_MSG_ERROR([Clang compiler does not support -Zc:dllexportInlines-. The Skia library needs to be built using a newer Clang version, or use --disable-skia.])
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$LO_CLANG_CC" -o -z "$LO_CLANG_CXX"; then
   371         kx         # Skia is the default on Windows and Mac, so hard-require Clang.
   371         kx         # Elsewhere it's used just by the 'gen' VCL backend which is rarely used.
   371         kx         if test "$_os" = "WINNT" -o "$_os" = "Darwin"; then
   371         kx             AC_MSG_ERROR([Clang compiler not found. The Skia library needs to be built using Clang, or use --disable-skia.])
   371         kx         else
   371         kx             AC_MSG_WARN([Clang compiler not found.])
   371         kx         fi
   371         kx     else
   371         kx 
   371         kx         save_CXX="$CXX"
   371         kx         CXX="$LO_CLANG_CXX"
   371         kx         # copy&paste (and adjust) of intrinsics checks, since MSVC's -arch doesn't work well for Clang-cl
   371         kx         flag_sse2=-msse2
   371         kx         flag_ssse3=-mssse3
   371         kx         flag_sse41=-msse4.1
   371         kx         flag_sse42=-msse4.2
   371         kx         flag_avx=-mavx
   371         kx         flag_avx2=-mavx2
   371         kx         flag_avx512="-mavx512f -mavx512vl -mavx512bw -mavx512dq -mavx512cd"
   371         kx         flag_avx512f=-mavx512f
   371         kx         flag_f16c=-mf16c
   371         kx         flag_fma=-mfma
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile SSE2 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_sse2"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <emmintrin.h>
   371         kx             int main () {
   371         kx                 __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx                 c = _mm_xor_si128 (a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_sse2=yes],
   371         kx             [can_compile_sse2=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_sse2}])
   371         kx         if test "${can_compile_sse2}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_SSE2="$flag_sse2"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile SSSE3 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_ssse3"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <tmmintrin.h>
   371         kx             int main () {
   371         kx                 __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx                 c = _mm_maddubs_epi16 (a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_ssse3=yes],
   371         kx             [can_compile_ssse3=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_ssse3}])
   371         kx         if test "${can_compile_ssse3}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_SSSE3="$flag_ssse3"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile SSE4.1 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_sse41"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <smmintrin.h>
   371         kx             int main () {
   371         kx                 __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx                 c = _mm_cmpeq_epi64 (a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_sse41=yes],
   371         kx             [can_compile_sse41=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_sse41}])
   371         kx         if test "${can_compile_sse41}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_SSE41="$flag_sse41"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile SSE4.2 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_sse42"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <nmmintrin.h>
   371         kx             int main () {
   371         kx                 __m128i a = _mm_set1_epi32 (0), b = _mm_set1_epi32 (0), c;
   371         kx                 c = _mm_cmpgt_epi64 (a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_sse42=yes],
   371         kx             [can_compile_sse42=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_sse42}])
   371         kx         if test "${can_compile_sse42}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_SSE42="$flag_sse42"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile AVX intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_avx"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <immintrin.h>
   371         kx             int main () {
   371         kx                 __m256 a = _mm256_set1_ps (0.0f), b = _mm256_set1_ps (0.0f), c;
   371         kx                 c = _mm256_xor_ps(a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_avx=yes],
   371         kx             [can_compile_avx=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_avx}])
   371         kx         if test "${can_compile_avx}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_AVX="$flag_avx"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile AVX2 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_avx2"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <immintrin.h>
   371         kx             int main () {
   371         kx                 __m256i a = _mm256_set1_epi32 (0), b = _mm256_set1_epi32 (0), c;
   371         kx                 c = _mm256_maddubs_epi16(a, b);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_avx2=yes],
   371         kx             [can_compile_avx2=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_avx2}])
   371         kx         if test "${can_compile_avx2}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_AVX2="$flag_avx2"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile AVX512 intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_avx512"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <immintrin.h>
   371         kx             int main () {
   371         kx                 __m512i a = _mm512_loadu_si512(0);
   371         kx                 __m512d v1 = _mm512_load_pd(0);
   371         kx                 // https://gcc.gnu.org/git/?p=gcc.git;a=commit;f=gcc/config/i386/avx512fintrin.h;h=23bce99cbe7016a04e14c2163ed3fe6a5a64f4e2
   371         kx                 __m512d v2 = _mm512_abs_pd(v1);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_avx512=yes],
   371         kx             [can_compile_avx512=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_avx512}])
   371         kx         if test "${can_compile_avx512}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_AVX512="$flag_avx512"
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_AVX512F="$flag_avx512f"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile F16C intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_f16c"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <immintrin.h>
   371         kx             int main () {
   371         kx                 __m128i a = _mm_set1_epi32 (0);
   371         kx                 __m128 c;
   371         kx                 c = _mm_cvtph_ps(a);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_f16c=yes],
   371         kx             [can_compile_f16c=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_f16c}])
   371         kx         if test "${can_compile_f16c}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_F16C="$flag_f16c"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_CHECKING([whether $CXX can compile FMA intrinsics])
   371         kx         AC_LANG_PUSH([C++])
   371         kx         save_CXXFLAGS=$CXXFLAGS
   371         kx         CXXFLAGS="$CXXFLAGS $flag_fma"
   371         kx         AC_COMPILE_IFELSE([AC_LANG_SOURCE([
   371         kx             #include <immintrin.h>
   371         kx             int main () {
   371         kx                 __m256 a = _mm256_set1_ps (0.0f), b = _mm256_set1_ps (0.0f), c = _mm256_set1_ps (0.0f), d;
   371         kx                 d = _mm256_fmadd_ps(a, b, c);
   371         kx                 return 0;
   371         kx             }
   371         kx             ])],
   371         kx             [can_compile_fma=yes],
   371         kx             [can_compile_fma=no])
   371         kx         AC_LANG_POP([C++])
   371         kx         CXXFLAGS=$save_CXXFLAGS
   371         kx         AC_MSG_RESULT([${can_compile_fma}])
   371         kx         if test "${can_compile_fma}" = "yes" ; then
   371         kx             LO_CLANG_CXXFLAGS_INTRINSICS_FMA="$flag_fma"
   371         kx         fi
   371         kx 
   371         kx         CXX="$save_CXX"
   371         kx     fi
   371         kx fi
   371         kx #
   371         kx # prefix LO_CLANG_CC/LO_CLANG_CXX with ccache if needed
   371         kx #
   371         kx if test "$CCACHE" != "" -a -n "$LO_CLANG_CC" -a -n "$LO_CLANG_CXX"; then
   371         kx     AC_MSG_CHECKING([whether $LO_CLANG_CC is already ccached])
   371         kx     AC_LANG_PUSH([C])
   371         kx     save_CC="$CC"
   371         kx     CC="$LO_CLANG_CC"
   371         kx     save_CFLAGS=$CFLAGS
   371         kx     CFLAGS="$CFLAGS --ccache-skip -O2 -Werror"
   371         kx     dnl an empty program will do, we're checking the compiler flags
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[])],
   371         kx                       [use_ccache=yes], [use_ccache=no])
   371         kx     CFLAGS=$save_CFLAGS
   371         kx     CC=$save_CC
   371         kx     if test $use_ccache = yes -a "${CCACHE/*sccache*/}" != ""; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         LO_CLANG_CC="$CCACHE $LO_CLANG_CC"
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx     AC_LANG_POP([C])
   371         kx 
   371         kx     AC_MSG_CHECKING([whether $LO_CLANG_CXX is already ccached])
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXX="$CXX"
   371         kx     CXX="$LO_CLANG_CXX"
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS --ccache-skip -O2 -Werror"
   371         kx     dnl an empty program will do, we're checking the compiler flags
   371         kx     AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],[])],
   371         kx                       [use_ccache=yes], [use_ccache=no])
   371         kx     if test $use_ccache = yes -a "${CCACHE/*sccache*/}" != ""; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx     else
   371         kx         LO_CLANG_CXX="$CCACHE $LO_CLANG_CXX"
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     CXX=$save_CXX
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(LO_CLANG_CC)
   371         kx AC_SUBST(LO_CLANG_CXX)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_SSE2)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_SSSE3)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_SSE41)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_SSE42)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_AVX)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_AVX2)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_AVX512)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_AVX512F)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_F16C)
   371         kx AC_SUBST(LO_CLANG_CXXFLAGS_INTRINSICS_FMA)
   371         kx AC_SUBST(LO_CLANG_SHOWINCLUDES_PREFIX)
   371         kx AC_SUBST(LO_CLANG_VERSION)
   371         kx AC_SUBST(CLANG_USE_LD)
   371         kx AC_SUBST([HAVE_LO_CLANG_DLLEXPORTINLINES])
   371         kx 
   371         kx SYSTEM_GPGMEPP=
   371         kx 
   371         kx AC_MSG_CHECKING([whether to enable gpgmepp])
   371         kx if test "$enable_gpgmepp" = no; then
   371         kx     AC_MSG_RESULT([no])
   371         kx elif test "$enable_mpl_subset" = "yes"; then
   371         kx     AC_MSG_RESULT([no (MPL only)])
   371         kx elif test "$enable_fuzzers" = "yes"; then
   371         kx     AC_MSG_RESULT([no (oss-fuzz)])
   371         kx elif test \( \( "$_os" = "Linux" -o "$_os" = "Darwin" \) -a "$ENABLE_NSS" = TRUE \) -o "$_os" = "WINNT" ; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system gpgme
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which gpgmepp to use])
   371         kx     if test "$with_system_gpgmepp" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_GPGMEPP=TRUE
   371         kx 
   371         kx         # C++ library doesn't come with fancy gpgmepp-config, check for headers the old-fashioned way
   371         kx         AC_CHECK_HEADER(gpgme++/gpgmepp_version.h, [ GPGMEPP_CFLAGS=-I/usr/include/gpgme++ ],
   371         kx             [AC_MSG_ERROR([gpgmepp headers not found, install gpgmepp >= 1.14 development package])], [])
   371         kx         AC_CHECK_HEADER(gpgme.h, [],
   371         kx             [AC_MSG_ERROR([gpgme headers not found, install gpgme development package])], [])
   371         kx         AC_CHECK_LIB(gpgmepp, main, [],
   371         kx             [AC_MSG_ERROR(gpgmepp not found or not functional)], [])
   371         kx         GPGMEPP_LIBS=-lgpgmepp
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         BUILD_TYPE="$BUILD_TYPE LIBGPGERROR LIBASSUAN GPGMEPP"
   371         kx 
   371         kx         GPG_ERROR_CFLAGS="-I${WORKDIR}/UnpackedTarball/libgpg-error/src"
   371         kx         LIBASSUAN_CFLAGS="-I${WORKDIR}/UnpackedTarball/libassuan/src"
   371         kx         if test "$_os" != "WINNT"; then
   371         kx             GPG_ERROR_LIBS="-L${WORKDIR}/UnpackedTarball/libgpg-error/src/.libs -lgpg-error"
   371         kx             LIBASSUAN_LIBS="-L${WORKDIR}/UnpackedTarball/libassuan/src/.libs -lassuan"
   371         kx         fi
   371         kx     fi
   371         kx     ENABLE_GPGMEPP=TRUE
   371         kx     AC_DEFINE([HAVE_FEATURE_GPGME])
   371         kx     AC_PATH_PROG(GPG, gpg)
   371         kx     # TODO: Windows's cygwin gpg does not seem to work with our gpgme,
   371         kx     # so let's exclude that manually for the moment
   371         kx     if test -n "$GPG" -a "$_os" != "WINNT"; then
   371         kx         # make sure we not only have a working gpgme, but a full working
   371         kx         # gpg installation to run OpenPGP signature verification
   371         kx         AC_DEFINE([HAVE_FEATURE_GPGVERIFY])
   371         kx     fi
   371         kx     if test "$_os" = "Linux"; then
   371         kx       uid=`id -u`
   371         kx       AC_MSG_CHECKING([for /run/user/$uid])
   371         kx       if test -d /run/user/$uid; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         AC_PATH_PROG(GPGCONF, gpgconf)
   371         kx 
   371         kx         # Older versions of gpgconf are not working as expected, since
   371         kx         # `gpgconf --remove-socketdir` fails to exit any gpg-agent daemon operating
   371         kx         # on that socket dir that has (indirectly) been started by the tests in xmlsecurity/qa/unit/signing/signing.cxx
   371         kx         # (see commit message of f0305ec0a7d199e605511844d9d6af98b66d4bfd%5E )
   371         kx         AC_MSG_CHECKING([whether version of gpgconf is suitable ... ])
   371         kx         GPGCONF_VERSION=`"$GPGCONF" --version | "$AWK" '/^gpgconf \(GnuPG\)/{print $3}'`
   371         kx         GPGCONF_NUMVER=`echo $GPGCONF_VERSION | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
   371         kx         if test "$GPGCONF_VERSION" = "2.2_OOo" -o "$GPGCONF_NUMVER" -ge "020200"; then
   371         kx           AC_MSG_RESULT([yes, $GPGCONF_VERSION])
   371         kx           AC_MSG_CHECKING([for gpgconf --create-socketdir... ])
   371         kx           if $GPGCONF --dump-options > /dev/null ; then
   371         kx             if $GPGCONF --dump-options | grep -q create-socketdir ; then
   371         kx               AC_MSG_RESULT([yes])
   371         kx               AC_DEFINE([HAVE_GPGCONF_SOCKETDIR])
   371         kx               AC_DEFINE_UNQUOTED([GPGME_GPGCONF], ["$GPGCONF"])
   371         kx             else
   371         kx               AC_MSG_RESULT([no])
   371         kx             fi
   371         kx           else
   371         kx             AC_MSG_RESULT([no. missing or broken gpgconf?])
   371         kx           fi
   371         kx         else
   371         kx           AC_MSG_RESULT([no, $GPGCONF_VERSION])
   371         kx         fi
   371         kx       else
   371         kx         AC_MSG_RESULT([no])
   371         kx      fi
   371         kx    fi
   371         kx else
   371         kx     AC_MSG_RESULT([no (unsupported OS or missing NSS)])
   371         kx fi
   371         kx AC_SUBST(ENABLE_GPGMEPP)
   371         kx AC_SUBST(SYSTEM_GPGMEPP)
   371         kx AC_SUBST(GPG_ERROR_CFLAGS)
   371         kx AC_SUBST(GPG_ERROR_LIBS)
   371         kx AC_SUBST(LIBASSUAN_CFLAGS)
   371         kx AC_SUBST(LIBASSUAN_LIBS)
   371         kx AC_SUBST(GPGMEPP_CFLAGS)
   371         kx AC_SUBST(GPGMEPP_LIBS)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build Java Websocket for the UNO remote websocket client])
   371         kx if test "$with_java" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_JAVA_WEBSOCKET=TRUE
   371         kx     BUILD_TYPE="$BUILD_TYPE JAVA_WEBSOCKET"
   371         kx     NEED_ANT=TRUE
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_JAVA_WEBSOCKET=
   371         kx fi
   371         kx AC_SUBST(ENABLE_JAVA_WEBSOCKET)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build the Wiki Publisher extension])
   371         kx if test "x$enable_ext_wiki_publisher" = "xyes" -a "x$enable_extension_integration" != "xno" -a "$with_java" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_MEDIAWIKI=TRUE
   371         kx     BUILD_TYPE="$BUILD_TYPE XSLTML"
   371         kx     if test  "x$with_java" = "xno"; then
   371         kx         AC_MSG_ERROR([Wiki Publisher requires Java! Enable Java if you want to build it.])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_MEDIAWIKI=
   371         kx     SCPDEFS="$SCPDEFS -DWITHOUT_EXTENSION_MEDIAWIKI"
   371         kx fi
   371         kx AC_SUBST(ENABLE_MEDIAWIKI)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build the Report Builder])
   371         kx if test "$enable_report_builder" != "no" -a "$with_java" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_REPORTBUILDER=TRUE
   371         kx     AC_MSG_CHECKING([which jfreereport libs to use])
   371         kx     if test "$with_system_jfreereport" = "yes"; then
   371         kx         SYSTEM_JFREEREPORT=TRUE
   371         kx         AC_MSG_RESULT([external])
   371         kx         if test -z $SAC_JAR; then
   371         kx             SAC_JAR=/usr/share/java/sac.jar
   371         kx         fi
   371         kx         if ! test -f $SAC_JAR; then
   371         kx              AC_MSG_ERROR(sac.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBXML_JAR; then
   371         kx             if test -f /usr/share/java/libxml-1.0.0.jar; then
   371         kx                 LIBXML_JAR=/usr/share/java/libxml-1.0.0.jar
   371         kx             elif test -f /usr/share/java/libxml.jar; then
   371         kx                 LIBXML_JAR=/usr/share/java/libxml.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libxml.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBXML_JAR; then
   371         kx             AC_MSG_ERROR(libxml.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $FLUTE_JAR; then
   371         kx             if test -f /usr/share/java/flute-1.3.0.jar; then
   371         kx                 FLUTE_JAR=/usr/share/java/flute-1.3.0.jar
   371         kx             elif test -f /usr/share/java/flute.jar; then
   371         kx                 FLUTE_JAR=/usr/share/java/flute.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(flute-1.3.0.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $FLUTE_JAR; then
   371         kx             AC_MSG_ERROR(flute-1.3.0.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $JFREEREPORT_JAR; then
   371         kx             if test -f /usr/share/java/flow-engine-0.9.2.jar; then
   371         kx                 JFREEREPORT_JAR=/usr/share/java/flow-engine-0.9.2.jar
   371         kx             elif test -f /usr/share/java/flow-engine.jar; then
   371         kx                 JFREEREPORT_JAR=/usr/share/java/flow-engine.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(jfreereport.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f  $JFREEREPORT_JAR; then
   371         kx                 AC_MSG_ERROR(jfreereport.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBLAYOUT_JAR; then
   371         kx             if test -f /usr/share/java/liblayout-0.2.9.jar; then
   371         kx                 LIBLAYOUT_JAR=/usr/share/java/liblayout-0.2.9.jar
   371         kx             elif test -f /usr/share/java/liblayout.jar; then
   371         kx                 LIBLAYOUT_JAR=/usr/share/java/liblayout.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(liblayout.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBLAYOUT_JAR; then
   371         kx                 AC_MSG_ERROR(liblayout.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBLOADER_JAR; then
   371         kx             if test -f /usr/share/java/libloader-1.0.0.jar; then
   371         kx                 LIBLOADER_JAR=/usr/share/java/libloader-1.0.0.jar
   371         kx             elif test -f /usr/share/java/libloader.jar; then
   371         kx                 LIBLOADER_JAR=/usr/share/java/libloader.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libloader.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f  $LIBLOADER_JAR; then
   371         kx             AC_MSG_ERROR(libloader.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBFORMULA_JAR; then
   371         kx             if test -f /usr/share/java/libformula-0.2.0.jar; then
   371         kx                 LIBFORMULA_JAR=/usr/share/java/libformula-0.2.0.jar
   371         kx             elif test -f /usr/share/java/libformula.jar; then
   371         kx                 LIBFORMULA_JAR=/usr/share/java/libformula.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libformula.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBFORMULA_JAR; then
   371         kx                 AC_MSG_ERROR(libformula.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBREPOSITORY_JAR; then
   371         kx             if test -f /usr/share/java/librepository-1.0.0.jar; then
   371         kx                 LIBREPOSITORY_JAR=/usr/share/java/librepository-1.0.0.jar
   371         kx             elif test -f /usr/share/java/librepository.jar; then
   371         kx                 LIBREPOSITORY_JAR=/usr/share/java/librepository.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(librepository.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBREPOSITORY_JAR; then
   371         kx             AC_MSG_ERROR(librepository.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBFONTS_JAR; then
   371         kx             if test -f /usr/share/java/libfonts-1.0.0.jar; then
   371         kx                 LIBFONTS_JAR=/usr/share/java/libfonts-1.0.0.jar
   371         kx             elif test -f /usr/share/java/libfonts.jar; then
   371         kx                 LIBFONTS_JAR=/usr/share/java/libfonts.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libfonts.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBFONTS_JAR; then
   371         kx                 AC_MSG_ERROR(libfonts.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBSERIALIZER_JAR; then
   371         kx             if test -f /usr/share/java/libserializer-1.0.0.jar; then
   371         kx                 LIBSERIALIZER_JAR=/usr/share/java/libserializer-1.0.0.jar
   371         kx             elif test -f /usr/share/java/libserializer.jar; then
   371         kx                 LIBSERIALIZER_JAR=/usr/share/java/libserializer.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libserializer.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBSERIALIZER_JAR; then
   371         kx                 AC_MSG_ERROR(libserializer.jar not found.)
   371         kx         fi
   371         kx 
   371         kx         if test -z $LIBBASE_JAR; then
   371         kx             if test -f /usr/share/java/libbase-1.0.0.jar; then
   371         kx                 LIBBASE_JAR=/usr/share/java/libbase-1.0.0.jar
   371         kx             elif test -f /usr/share/java/libbase.jar; then
   371         kx                 LIBBASE_JAR=/usr/share/java/libbase.jar
   371         kx             else
   371         kx                 AC_MSG_ERROR(libbase.jar replacement not found.)
   371         kx             fi
   371         kx         elif ! test -f $LIBBASE_JAR; then
   371         kx             AC_MSG_ERROR(libbase.jar not found.)
   371         kx         fi
   371         kx 
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_JFREEREPORT=
   371         kx         BUILD_TYPE="$BUILD_TYPE JFREEREPORT"
   371         kx         NEED_ANT=TRUE
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_REPORTBUILDER=
   371         kx     SYSTEM_JFREEREPORT=
   371         kx fi
   371         kx AC_SUBST(ENABLE_REPORTBUILDER)
   371         kx AC_SUBST(SYSTEM_JFREEREPORT)
   371         kx AC_SUBST(SAC_JAR)
   371         kx AC_SUBST(LIBXML_JAR)
   371         kx AC_SUBST(FLUTE_JAR)
   371         kx AC_SUBST(JFREEREPORT_JAR)
   371         kx AC_SUBST(LIBBASE_JAR)
   371         kx AC_SUBST(LIBLAYOUT_JAR)
   371         kx AC_SUBST(LIBLOADER_JAR)
   371         kx AC_SUBST(LIBFORMULA_JAR)
   371         kx AC_SUBST(LIBREPOSITORY_JAR)
   371         kx AC_SUBST(LIBFONTS_JAR)
   371         kx AC_SUBST(LIBSERIALIZER_JAR)
   371         kx 
   371         kx # scripting provider for BeanShell?
   371         kx AC_MSG_CHECKING([whether to build support for scripts in BeanShell])
   371         kx if test "${enable_scripting_beanshell}" != "no" -a "x$with_java" != "xno"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_SCRIPTING_BEANSHELL=TRUE
   371         kx 
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system beanshell
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which beanshell to use])
   371         kx     if test "$with_system_beanshell" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_BSH=TRUE
   371         kx         if test -z $BSH_JAR; then
   371         kx             BSH_JAR=/usr/share/java/bsh.jar
   371         kx         fi
   371         kx         if ! test -f $BSH_JAR; then
   371         kx             AC_MSG_ERROR(bsh.jar not found.)
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_BSH=
   371         kx         BUILD_TYPE="$BUILD_TYPE BSH"
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_SCRIPTING_BEANSHELL=
   371         kx     SCPDEFS="$SCPDEFS -DWITHOUT_SCRIPTING_BEANSHELL"
   371         kx fi
   371         kx AC_SUBST(ENABLE_SCRIPTING_BEANSHELL)
   371         kx AC_SUBST(SYSTEM_BSH)
   371         kx AC_SUBST(BSH_JAR)
   371         kx 
   371         kx # scripting provider for JavaScript?
   371         kx AC_MSG_CHECKING([whether to build support for scripts in JavaScript])
   371         kx if test "${enable_scripting_javascript}" != "no" -a "x$with_java" != "xno"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_SCRIPTING_JAVASCRIPT=TRUE
   371         kx 
   371         kx     dnl ===================================================================
   371         kx     dnl Check for system rhino
   371         kx     dnl ===================================================================
   371         kx     AC_MSG_CHECKING([which rhino to use])
   371         kx     if test "$with_system_rhino" = "yes"; then
   371         kx         AC_MSG_RESULT([external])
   371         kx         SYSTEM_RHINO=TRUE
   371         kx         if test -z $RHINO_JAR; then
   371         kx             RHINO_JAR=/usr/share/java/js.jar
   371         kx         fi
   371         kx         if ! test -f $RHINO_JAR; then
   371         kx             AC_MSG_ERROR(js.jar not found.)
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([internal])
   371         kx         SYSTEM_RHINO=
   371         kx         BUILD_TYPE="$BUILD_TYPE RHINO"
   371         kx         NEED_ANT=TRUE
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_SCRIPTING_JAVASCRIPT=
   371         kx     SCPDEFS="$SCPDEFS -DWITHOUT_SCRIPTING_JAVASCRIPT"
   371         kx fi
   371         kx AC_SUBST(ENABLE_SCRIPTING_JAVASCRIPT)
   371         kx AC_SUBST(SYSTEM_RHINO)
   371         kx AC_SUBST(RHINO_JAR)
   371         kx 
   371         kx # This is only used in Qt5/Qt6/KF5/KF6 checks to determine if /usr/lib64
   371         kx # paths should be added to library search path. So lets put all 64-bit
   371         kx # platforms there.
   371         kx supports_multilib=
   371         kx case "$host_cpu" in
   371         kx x86_64 | powerpc64 | powerpc64le | s390x | aarch64 | mips64 | mips64el | loongarch64 | riscv64)
   371         kx     if test "$SAL_TYPES_SIZEOFLONG" = "8"; then
   371         kx         supports_multilib="yes"
   371         kx     fi
   371         kx     ;;
   371         kx *)
   371         kx     ;;
   371         kx esac
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl QT5 Integration
   371         kx dnl ===================================================================
   371         kx 
   371         kx QT5_CFLAGS=""
   371         kx QT5_LIBS=""
   371         kx QMAKE5="qmake"
   371         kx MOC5="moc"
   371         kx QT5_GOBJECT_CFLAGS=""
   371         kx QT5_GOBJECT_LIBS=""
   371         kx QT5_HAVE_GOBJECT=""
   371         kx QT5_PLATFORMS_SRCDIR=""
   371         kx if test \( "$test_kf5" = "yes" -a "$ENABLE_KF5" = "TRUE" \) -o \
   371         kx         \( "$test_qt5" = "yes" -a "$ENABLE_QT5" = "TRUE" \) -o \
   371         kx         \( "$test_gtk3_kde5" = "yes" -a "$ENABLE_GTK3_KDE5" = "TRUE" \)
   371         kx then
   371         kx     qt5_incdirs="$QT5INC /usr/include/qt5 /usr/include $x_includes"
   371         kx     qt5_libdirs="$QT5LIB /usr/lib/qt5 /usr/lib $x_libraries"
   371         kx 
   371         kx     if test -n "$supports_multilib"; then
   371         kx         qt5_libdirs="$qt5_libdirs /usr/lib64/qt5 /usr/lib64/qt /usr/lib64"
   371         kx     fi
   371         kx 
   371         kx     qt5_test_include="QtWidgets/qapplication.h"
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         qt5_test_library="libQt5Widgets.a"
   371         kx     else
   371         kx         qt5_test_library="libQt5Widgets.so"
   371         kx     fi
   371         kx 
   371         kx     dnl Check for qmake5
   371         kx     if test -n "$QT5DIR"; then
   371         kx         AC_PATH_PROG(QMAKE5, [qmake], no, [$QT5DIR/bin])
   371         kx     else
   371         kx         AC_PATH_PROGS(QMAKE5, [qmake-qt5 qmake], no)
   371         kx     fi
   371         kx     if test "$QMAKE5" = "no"; then
   371         kx         AC_MSG_ERROR([Qmake not found.  Please specify the root of your Qt5 installation by exporting QT5DIR before running "configure".])
   371         kx     else
   371         kx         qmake5_test_ver="`$QMAKE5 -v 2>&1 | $SED -n -e 's/^Using Qt version \(5\.[[0-9.]]\+\).*$/\1/p'`"
   371         kx         if test -z "$qmake5_test_ver"; then
   371         kx             AC_MSG_ERROR([Wrong qmake for Qt5 found. Please specify the root of your Qt5 installation by exporting QT5DIR before running "configure".])
   371         kx         fi
   371         kx         qmake5_minor_version="`echo $qmake5_test_ver | cut -d. -f2`"
   371         kx         qt5_minimal_minor="15"
   371         kx         if test "$qmake5_minor_version" -lt "$qt5_minimal_minor"; then
   371         kx             AC_MSG_ERROR([The minimal supported Qt5 version is 5.${qt5_minimal_minor}, but your 'qmake -v' reports Qt5 version $qmake5_test_ver.])
   371         kx         else
   371         kx             AC_MSG_NOTICE([Detected Qt5 version: $qmake5_test_ver])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     qt5_incdirs="`$QMAKE5 -query QT_INSTALL_HEADERS` $qt5_incdirs"
   371         kx     qt5_libdirs="`$QMAKE5 -query QT_INSTALL_LIBS` $qt5_libdirs"
   371         kx     qt5_platformsdir="`$QMAKE5 -query QT_INSTALL_PLUGINS`/platforms"
   371         kx     QT5_PLATFORMS_SRCDIR="$qt5_platformsdir"
   371         kx 
   371         kx     AC_MSG_CHECKING([for Qt5 headers])
   371         kx     qt5_incdir="no"
   371         kx     for inc_dir in $qt5_incdirs; do
   371         kx         if test -r "$inc_dir/$qt5_test_include"; then
   371         kx             qt5_incdir="$inc_dir"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$qt5_incdir])
   371         kx     if test "x$qt5_incdir" = "xno"; then
   371         kx         AC_MSG_ERROR([Qt5 headers not found.  Please specify the root of your Qt5 installation by exporting QT5DIR before running "configure".])
   371         kx     fi
   371         kx     # check for scenario: qt5-qtbase-devel-*.86_64 installed but host is i686
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CPPFLAGS=$CPPFLAGS
   371         kx     CPPFLAGS="${CPPFLAGS} -I${qt5_incdir}"
   371         kx     AC_CHECK_HEADER(QtCore/qconfig.h, [],
   371         kx         [AC_MSG_ERROR(qconfig.h header not found.)], [])
   371         kx     CPPFLAGS=$save_CPPFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([for Qt5 libraries])
   371         kx     qt5_libdir="no"
   371         kx     for lib_dir in $qt5_libdirs; do
   371         kx         if test -r "$lib_dir/$qt5_test_library"; then
   371         kx             qt5_libdir="$lib_dir"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$qt5_libdir])
   371         kx     if test "x$qt5_libdir" = "xno"; then
   371         kx         AC_MSG_ERROR([Qt5 libraries not found.  Please specify the root of your Qt5 installation by exporting QT5DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         if test ! -f "$QT5_PLATFORMS_SRCDIR"/wasm_shell.html ; then
   371         kx             QT5_PLATFORMS_SRCDIR="${QT5_PLATFORMS_SRCDIR/plugins/src\/plugins}/wasm"
   371         kx         fi
   371         kx         if test ! -f "${qt5_platformsdir}"/libqwasm.a -o ! -f "$QT5_PLATFORMS_SRCDIR"/wasm_shell.html; then
   371         kx             AC_MSG_ERROR([No Qt5 WASM QPA plugin found in ${qt5_platformsdir} or ${QT5_PLATFORMS_SRCDIR}])
   371         kx         fi
   371         kx 
   371         kx         EMSDK_LLVM_NM="$(em-config LLVM_ROOT)"/llvm-nm
   371         kx         if ! test -x "$EMSDK_LLVM_NM"; then
   371         kx             AC_MSG_ERROR([Missing llvm-nm expected to be found at "$EMSDK_LLVM_NM".])
   371         kx         fi
   371         kx         if test ! -f "${qt5_libdir}"/libQt5Gui.a; then
   371         kx             AC_MSG_ERROR([No Qt5 WASM libQt5Gui.a in ${qt5_libdir}])
   371         kx         fi
   371         kx         QT5_WASM_SJLJ="`${EMSDK_LLVM_NM} "${qt5_libdir}"/libQt5Gui.a 2>/dev/null | $GREP emscripten_longjmp`"
   371         kx         if test "$ENABLE_WASM_EXCEPTIONS" = TRUE -a -n "$QT5_WASM_SJLJ"; then
   371         kx             AC_MSG_ERROR(['emscripten_longjmp' symbol found in libQt5Gui.a (missing '-s SUPPORT_LONGJMP=wasm'). See static/README.wasm.md.])
   371         kx         fi
   371         kx         if test "$ENABLE_WASM_EXCEPTIONS" != TRUE -a -z "$QT5_WASM_SJLJ"; then
   371         kx             AC_MSG_ERROR(['emscripten_longjmp' symbol not found in libQt5Gui.a. You probably use an incompatible Qt build with '-s SUPPORT_LONGJMP=wasm'.])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     QT5_CFLAGS="-I$qt5_incdir -DQT_CLEAN_NAMESPACE -DQT_THREAD_SUPPORT -DQT_NO_VERSION_TAGGING"
   371         kx     QT5_CFLAGS=$(printf '%s' "$QT5_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     QT5_LIBS="-L$qt5_libdir -lQt5Core -lQt5Gui -lQt5Widgets -lQt5Network"
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         QT5_LIBS="$QT5_LIBS -lqtpcre2 -lQt5EventDispatcherSupport -lQt5FontDatabaseSupport -L${qt5_platformsdir} -lqwasm"
   371         kx     fi
   371         kx 
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         PKG_CHECK_MODULES(QT5_XCB,[xcb],,[AC_MSG_ERROR([XCB not found, which is needed for correct app grouping in X11.])])
   371         kx         QT5_CFLAGS="$QT5_CFLAGS $QT5_XCB_CFLAGS $QT5_XCB_ICCCM_CFLAGS"
   371         kx         QT5_LIBS="$QT5_LIBS $QT5_XCB_LIBS $QT5_XCB_ICCCM_LIBS -lQt5X11Extras"
   371         kx         QT5_USING_X11=1
   371         kx         AC_DEFINE(QT5_USING_X11)
   371         kx     fi
   371         kx 
   371         kx     dnl Check for Meta Object Compiler
   371         kx 
   371         kx     AC_PATH_PROGS( MOC5, [moc-qt5 moc], no, [`dirname $qt5_libdir`/bin:$QT5DIR/bin:$PATH])
   371         kx     if test "$MOC5" = "no"; then
   371         kx         AC_MSG_ERROR([Qt Meta Object Compiler not found.  Please specify
   371         kx the root of your Qt installation by exporting QT5DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     if test "$test_gstreamer_1_0" = yes; then
   371         kx         PKG_CHECK_MODULES(QT5_GOBJECT,[gobject-2.0], [
   371         kx                 QT5_HAVE_GOBJECT=1
   371         kx                 AC_DEFINE(QT5_HAVE_GOBJECT)
   371         kx             ],
   371         kx             AC_MSG_WARN([[No GObject found, can't use QWidget GStreamer sink on wayland!]])
   371         kx         )
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(QT5_CFLAGS)
   371         kx AC_SUBST(QT5_LIBS)
   371         kx AC_SUBST(MOC5)
   371         kx AC_SUBST(QT5_GOBJECT_CFLAGS)
   371         kx AC_SUBST(QT5_GOBJECT_LIBS)
   371         kx AC_SUBST(QT5_HAVE_GOBJECT)
   371         kx AC_SUBST(QT5_PLATFORMS_SRCDIR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl QT6 Integration
   371         kx dnl ===================================================================
   371         kx 
   371         kx QT6_CFLAGS=""
   371         kx QT6_LIBS=""
   371         kx QMAKE6="qmake"
   371         kx MOC6="moc"
   371         kx QT6_PLATFORMS_SRCDIR=""
   371         kx if test \( "$test_kf6" = "yes" -a "$ENABLE_KF6" = "TRUE" \) -o \
   371         kx         \( "$test_qt6" = "yes" -a "$ENABLE_QT6" = "TRUE" \)
   371         kx then
   371         kx     qt6_incdirs="$QT6INC /usr/include/qt6 /usr/include $x_includes"
   371         kx     qt6_libdirs="$QT6LIB /usr/lib/qt6 /usr/lib $x_libraries"
   371         kx 
   371         kx     if test -n "$supports_multilib"; then
   371         kx         qt6_libdirs="$qt6_libdirs /usr/lib64/qt6 /usr/lib64/qt /usr/lib64"
   371         kx     fi
   371         kx 
   371         kx     qt6_test_include="QtWidgets/qapplication.h"
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         qt6_test_library="libQt6Widgets.a"
   371         kx     else
   371         kx         qt6_test_library="libQt6Widgets.so"
   371         kx     fi
   371         kx 
   371         kx     dnl Check for qmake6
   371         kx     if test -n "$QT6DIR"; then
   371         kx         AC_PATH_PROG(QMAKE6, [qmake], no, [$QT6DIR/bin])
   371         kx     else
   371         kx         AC_PATH_PROGS(QMAKE6, [qmake-qt6 qmake6 qmake], no)
   371         kx     fi
   371         kx     if test "$QMAKE6" = "no"; then
   371         kx         AC_MSG_ERROR([Qmake not found.  Please specify the root of your Qt6 installation by exporting QT6DIR before running "configure".])
   371         kx     else
   371         kx         qmake6_test_ver="`$QMAKE6 -v 2>&1 | $SED -n -e 's/^Using Qt version \(6\.[[0-9.]]\+\).*$/\1/p'`"
   371         kx         if test -z "$qmake6_test_ver"; then
   371         kx             AC_MSG_ERROR([Wrong qmake for Qt6 found. Please specify the root of your Qt6 installation by exporting QT6DIR before running "configure".])
   371         kx         fi
   371         kx         AC_MSG_NOTICE([Detected Qt6 version: $qmake6_test_ver])
   371         kx     fi
   371         kx 
   371         kx     qt6_incdirs="`$QMAKE6 -query QT_INSTALL_HEADERS` $qt6_incdirs"
   371         kx     qt6_libdirs="`$QMAKE6 -query QT_INSTALL_LIBS` $qt6_libdirs"
   371         kx     qt6_platformsdir="`$QMAKE6 -query QT_INSTALL_PLUGINS`/platforms"
   371         kx     QT6_PLATFORMS_SRCDIR="$qt6_platformsdir"
   371         kx 
   371         kx     AC_MSG_CHECKING([for Qt6 headers])
   371         kx     qt6_incdir="no"
   371         kx     for inc_dir in $qt6_incdirs; do
   371         kx         if test -r "$inc_dir/$qt6_test_include"; then
   371         kx             qt6_incdir="$inc_dir"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$qt6_incdir])
   371         kx     if test "x$qt6_incdir" = "xno"; then
   371         kx         AC_MSG_ERROR([Qt6 headers not found.  Please specify the root of your Qt6 installation by exporting QT6DIR before running "configure".])
   371         kx     fi
   371         kx     # check for scenario: qt6-qtbase-devel-*.86_64 installed but host is i686
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CPPFLAGS=$CPPFLAGS
   371         kx     CPPFLAGS="${CPPFLAGS} -I${qt6_incdir}"
   371         kx     AC_CHECK_HEADER(QtCore/qconfig.h, [],
   371         kx         [AC_MSG_ERROR(qconfig.h header not found.)], [])
   371         kx     CPPFLAGS=$save_CPPFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx 
   371         kx     AC_MSG_CHECKING([for Qt6 libraries])
   371         kx     qt6_libdir="no"
   371         kx     for lib_dir in $qt6_libdirs; do
   371         kx         if test -r "$lib_dir/$qt6_test_library"; then
   371         kx             qt6_libdir="$lib_dir"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$qt6_libdir])
   371         kx     if test "x$qt6_libdir" = "xno"; then
   371         kx         AC_MSG_ERROR([Qt6 libraries not found.  Please specify the root of your Qt6 installation by exporting QT6DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         if test ! -f "$QT6_PLATFORMS_SRCDIR"/wasm_shell.html ; then
   371         kx             QT6_PLATFORMS_SRCDIR="${QT6_PLATFORMS_SRCDIR/plugins/src\/plugins}/wasm"
   371         kx         fi
   371         kx         if test ! -f "${qt6_platformsdir}"/libqwasm.a -o ! -f "$QT6_PLATFORMS_SRCDIR"/wasm_shell.html; then
   371         kx             AC_MSG_ERROR([No Qt6 WASM QPA plugin found in ${qt6_platformsdir} or ${QT6_PLATFORMS_SRCDIR}])
   371         kx         fi
   371         kx     fi
   371         kx 
   371         kx     QT6_CFLAGS="-I$qt6_incdir -DQT_CLEAN_NAMESPACE -DQT_THREAD_SUPPORT -DQT_NO_VERSION_TAGGING"
   371         kx     QT6_CFLAGS=$(printf '%s' "$QT6_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     QT6_LIBS="-L$qt6_libdir -lQt6Core -lQt6Gui -lQt6Widgets -lQt6Network"
   371         kx     if test "$_os" = "Emscripten"; then
   371         kx         QT6_LIBS="$QT6_LIBS -lqtpcre2 -lQt6EventDispatcherSupport -lQt6FontDatabaseSupport -L${qt6_platformsdir} -lqwasm"
   371         kx     fi
   371         kx 
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         PKG_CHECK_MODULES(QT6_XCB,[xcb],,[AC_MSG_ERROR([XCB not found, which is needed for key modifier handling in X11.])])
   371         kx         QT6_CFLAGS="$QT6_CFLAGS $QT6_XCB_CFLAGS"
   371         kx         QT6_LIBS="$QT6_LIBS $QT6_XCB_LIBS"
   371         kx         QT6_USING_X11=1
   371         kx         AC_DEFINE(QT6_USING_X11)
   371         kx     fi
   371         kx 
   371         kx     dnl Check for Meta Object Compiler
   371         kx 
   371         kx     for lib_dir in $qt6_libdirs; do
   371         kx         if test -z "$qt6_libexec_dirs"; then
   371         kx             qt6_libexec_dirs="$lib_dir/libexec"
   371         kx         else
   371         kx             qt6_libexec_dirs="$qt6_libexec_dirs:$lib_dir/libexec"
   371         kx         fi
   371         kx     done
   371         kx     AC_PATH_PROGS( MOC6, [moc-qt6 moc], no, [`dirname $qt6_libdir`/libexec:$QT6DIR/libexec:$qt6_libexec_dirs:`echo $qt6_libdirs | $SED -e 's/ /:/g'`:$PATH])
   371         kx     if test "$MOC6" = "no"; then
   371         kx         AC_MSG_ERROR([Qt Meta Object Compiler not found.  Please specify
   371         kx the root of your Qt installation by exporting QT6DIR before running "configure".])
   371         kx     else
   371         kx         moc6_test_ver="`$MOC6 -v 2>&1 | $SED -n -e 's/^moc \(6.*\)/\1/p'`"
   371         kx         if test -z "$moc6_test_ver"; then
   371         kx             AC_MSG_ERROR([Wrong moc for Qt6 found.])
   371         kx         fi
   371         kx         AC_MSG_NOTICE([Detected moc version: $moc_test_ver])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(QT6_CFLAGS)
   371         kx AC_SUBST(QT6_LIBS)
   371         kx AC_SUBST(MOC6)
   371         kx AC_SUBST(QT6_PLATFORMS_SRCDIR)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl KF5 Integration
   371         kx dnl ===================================================================
   371         kx 
   371         kx KF5_CFLAGS=""
   371         kx KF5_LIBS=""
   371         kx KF5_CONFIG="kf5-config"
   371         kx if test \( "$test_kf5" = "yes" -a "$ENABLE_KF5" = "TRUE" \) -o \
   371         kx         \( "$test_gtk3_kde5" = "yes" -a "$ENABLE_GTK3_KDE5" = "TRUE" \)
   371         kx then
   371         kx     if test "$OS" = "HAIKU"; then
   371         kx         haiku_arch="`echo $RTL_ARCH | tr X x`"
   371         kx         kf5_haiku_incdirs="`findpaths -c ' ' -a $haiku_arch B_FIND_PATH_HEADERS_DIRECTORY`"
   371         kx         kf5_haiku_libdirs="`findpaths -c ' ' -a $haiku_arch B_FIND_PATH_DEVELOP_LIB_DIRECTORY`"
   371         kx     fi
   371         kx 
   371         kx     kf5_incdirs="$KF5INC /usr/include $kf5_haiku_incdirs $x_includes"
   371         kx     kf5_libdirs="$KF5LIB /usr/lib /usr/lib/kf5 /usr/lib/kf5/devel $kf5_haiku_libdirs $x_libraries"
   371         kx     if test -n "$supports_multilib"; then
   371         kx         kf5_libdirs="$kf5_libdirs /usr/lib64 /usr/lib64/kf5 /usr/lib64/kf5/devel"
   371         kx     fi
   371         kx 
   371         kx     kf5_test_include="KF5/KIOFileWidgets/KFileWidget"
   371         kx     kf5_test_library="libKF5KIOFileWidgets.so"
   371         kx     kf5_libdirs="$qt5_libdir $kf5_libdirs"
   371         kx 
   371         kx     dnl kf5 KDE4 support compatibility installed
   371         kx     AC_PATH_PROG( KF5_CONFIG, $KF5_CONFIG, no, )
   371         kx     if test "$KF5_CONFIG" != "no"; then
   371         kx         kf5_incdirs="`$KF5_CONFIG --path include` $kf5_incdirs"
   371         kx         kf5_libdirs="`$KF5_CONFIG --path lib` $kf5_libdirs"
   371         kx     fi
   371         kx 
   371         kx     dnl Check for KF5 headers
   371         kx     AC_MSG_CHECKING([for KF5 headers])
   371         kx     kf5_incdir="no"
   371         kx     for kf5_check in $kf5_incdirs; do
   371         kx         if test -r "$kf5_check/$kf5_test_include"; then
   371         kx             kf5_incdir="$kf5_check/KF5"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$kf5_incdir])
   371         kx     if test "x$kf5_incdir" = "xno"; then
   371         kx         AC_MSG_ERROR([KF5 headers not found.  Please specify the root of your KF5 installation by exporting KF5DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     dnl Check for KF5 libraries
   371         kx     AC_MSG_CHECKING([for KF5 libraries])
   371         kx     kf5_libdir="no"
   371         kx     for kf5_check in $kf5_libdirs; do
   371         kx         if test -r "$kf5_check/$kf5_test_library"; then
   371         kx             kf5_libdir="$kf5_check"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     AC_MSG_RESULT([$kf5_libdir])
   371         kx     if test "x$kf5_libdir" = "xno"; then
   371         kx         AC_MSG_ERROR([KF5 libraries not found.  Please specify the root of your KF5 installation by exporting KF5DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     KF5_CFLAGS="-I$kf5_incdir -I$kf5_incdir/KCoreAddons -I$kf5_incdir/KI18n -I$kf5_incdir/KConfigCore -I$kf5_incdir/KWindowSystem -I$kf5_incdir/KIOCore -I$kf5_incdir/KIOWidgets -I$kf5_incdir/KIOFileWidgets -I$qt5_incdir -I$qt5_incdir/QtCore -I$qt5_incdir/QtGui -I$qt5_incdir/QtWidgets -I$qt5_incdir/QtNetwork -DQT_CLEAN_NAMESPACE -DQT_THREAD_SUPPORT -DQT_NO_VERSION_TAGGING"
   371         kx     KF5_LIBS="-L$kf5_libdir -lKF5CoreAddons -lKF5I18n -lKF5ConfigCore -lKF5WindowSystem -lKF5KIOCore -lKF5KIOWidgets -lKF5KIOFileWidgets -L$qt5_libdir -lQt5Core -lQt5Gui -lQt5Widgets -lQt5Network"
   371         kx     KF5_CFLAGS=$(printf '%s' "$KF5_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx 
   371         kx     if test "$USING_X11" = TRUE; then
   371         kx         KF5_LIBS="$KF5_LIBS -lQt5X11Extras"
   371         kx     fi
   371         kx 
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $KF5_CFLAGS"
   371         kx     AC_MSG_CHECKING([whether KDE is >= 5.0])
   371         kx        AC_RUN_IFELSE([AC_LANG_SOURCE([[
   371         kx #include <kcoreaddons_version.h>
   371         kx 
   371         kx int main(int argc, char **argv) {
   371         kx        if (KCOREADDONS_VERSION_MAJOR == 5 && KCOREADDONS_VERSION_MINOR >= 0) return 0;
   371         kx        else return 1;
   371         kx }
   371         kx        ]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([KDE version too old])],[])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST(KF5_CFLAGS)
   371         kx AC_SUBST(KF5_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl KF6 Integration
   371         kx dnl ===================================================================
   371         kx 
   371         kx KF6_CFLAGS=""
   371         kx KF6_LIBS=""
   371         kx if test \( "$test_kf6" = "yes" -a "$ENABLE_KF6" = "TRUE" \)
   371         kx then
   371         kx     if test "$OS" = "HAIKU"; then
   371         kx         haiku_arch="`echo $RTL_ARCH | tr X x`"
   371         kx         kf6_haiku_incdirs="`findpaths -c ' ' -a $haiku_arch B_FIND_PATH_HEADERS_DIRECTORY`"
   371         kx         kf6_haiku_libdirs="`findpaths -c ' ' -a $haiku_arch B_FIND_PATH_DEVELOP_LIB_DIRECTORY`"
   371         kx     fi
   371         kx 
   371         kx     kf6_incdirs="$KF6INC /usr/include $kf6_haiku_incdirs $x_includes"
   371         kx     kf6_libdirs="$KF6LIB /usr/lib /usr/lib/kf6 /usr/lib/kf6/devel $kf6_haiku_libdirs $x_libraries"
   371         kx     if test -n "$supports_multilib"; then
   371         kx         kf6_libdirs="$kf6_libdirs /usr/lib64 /usr/lib64/kf6 /usr/lib64/kf6/devel"
   371         kx     fi
   371         kx 
   371         kx     kf6_test_include="KF6/KIOFileWidgets/KFileWidget"
   371         kx     kf6_test_library="libKF6KIOFileWidgets.so"
   371         kx     kf6_libdirs="$qt6_libdir $kf6_libdirs"
   371         kx 
   371         kx     dnl Check for KF6 headers
   371         kx     AC_MSG_CHECKING([for KF6 headers])
   371         kx     kf6_incdir="no"
   371         kx     for kf6_check in $kf6_incdirs; do
   371         kx         if test -r "$kf6_check/$kf6_test_include"; then
   371         kx             kf6_incdir="$kf6_check/KF6"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx     AC_MSG_RESULT([$kf6_incdir])
   371         kx     if test "x$kf6_incdir" = "xno"; then
   371         kx         AC_MSG_ERROR([KF6 headers not found.  Please specify the root of your KF6 installation by exporting KF6DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     dnl Check for KF6 libraries
   371         kx     AC_MSG_CHECKING([for KF6 libraries])
   371         kx     kf6_libdir="no"
   371         kx     for kf6_check in $kf6_libdirs; do
   371         kx         if test -r "$kf6_check/$kf6_test_library"; then
   371         kx             kf6_libdir="$kf6_check"
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx 
   371         kx     AC_MSG_RESULT([$kf6_libdir])
   371         kx     if test "x$kf6_libdir" = "xno"; then
   371         kx         AC_MSG_ERROR([KF6 libraries not found.  Please specify the root of your KF6 installation by exporting KF6DIR before running "configure".])
   371         kx     fi
   371         kx 
   371         kx     KF6_CFLAGS="-I$kf6_incdir -I$kf6_incdir/KCoreAddons -I$kf6_incdir/KI18n -I$kf6_incdir/KConfigCore -I$kf6_incdir/KWindowSystem -I$kf6_incdir/KIO -I$kf6_incdir/KIOCore -I$kf6_incdir/KIOWidgets -I$kf6_incdir/KIOFileWidgets -I$qt6_incdir -I$qt6_incdir/QtCore -I$qt6_incdir/QtGui -I$qt6_incdir/QtWidgets -I$qt6_incdir/QtNetwork -DQT_CLEAN_NAMESPACE -DQT_THREAD_SUPPORT -DQT_NO_VERSION_TAGGING"
   371         kx     KF6_LIBS="-L$kf6_libdir -lKF6CoreAddons -lKF6I18n -lKF6ConfigCore -lKF6WindowSystem -lKF6KIOCore -lKF6KIOWidgets -lKF6KIOFileWidgets -L$qt6_libdir -lQt6Core -lQt6Gui -lQt6Widgets -lQt6Network"
   371         kx     KF6_CFLAGS=$(printf '%s' "$KF6_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx 
   371         kx     AC_LANG_PUSH([C++])
   371         kx     save_CXXFLAGS=$CXXFLAGS
   371         kx     CXXFLAGS="$CXXFLAGS $KF6_CFLAGS"
   371         kx     dnl KF6 development version as of 2023-06 uses version number 5.240
   371         kx     AC_MSG_CHECKING([whether KDE is >= 5.240])
   371         kx        AC_RUN_IFELSE([AC_LANG_SOURCE([[
   371         kx #include <kcoreaddons_version.h>
   371         kx 
   371         kx int main(int argc, char **argv) {
   371         kx        if (KCOREADDONS_VERSION_MAJOR == 6 || (KCOREADDONS_VERSION_MAJOR == 5 && KCOREADDONS_VERSION_MINOR >= 240)) return 0;
   371         kx        else return 1;
   371         kx }
   371         kx        ]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([KDE version too old])],[])
   371         kx     CXXFLAGS=$save_CXXFLAGS
   371         kx     AC_LANG_POP([C++])
   371         kx fi
   371         kx AC_SUBST(KF6_CFLAGS)
   371         kx AC_SUBST(KF6_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to include Evolution 2 support
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable evolution 2 support])
   371         kx if test "$enable_evolution2" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     PKG_CHECK_MODULES(GOBJECT, gobject-2.0)
   371         kx     GOBJECT_CFLAGS=$(printf '%s' "$GOBJECT_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${GOBJECT_LIBS}"
   371         kx     GOBJECT_LIBS="${filteredlibs}"
   371         kx     ENABLE_EVOAB2="TRUE"
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_EVOAB2)
   371         kx AC_SUBST(GOBJECT_CFLAGS)
   371         kx AC_SUBST(GOBJECT_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test which themes to include
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which themes to include])
   371         kx # if none given use default subset of available themes
   371         kx if test "x$with_theme" = "x" -o "x$with_theme" = "xyes"; then
   371         kx     with_theme="breeze breeze_dark breeze_dark_svg breeze_svg colibre colibre_svg colibre_dark colibre_dark_svg elementary elementary_svg karasa_jaga karasa_jaga_svg sifr sifr_svg sifr_dark sifr_dark_svg sukapura sukapura_dark sukapura_dark_svg sukapura_svg"
   371         kx fi
   371         kx 
   371         kx WITH_THEMES=""
   371         kx if test "x$with_theme" != "xno"; then
   371         kx     for theme in $with_theme; do
   371         kx         case $theme in
   371         kx         breeze|breeze_dark|breeze_dark_svg|breeze_svg|colibre|colibre_svg|colibre_dark|colibre_dark_svg|elementary|elementary_svg|karasa_jaga|karasa_jaga_svg|sifr|sifr_svg|sifr_dark|sifr_dark_svg|sukapura|sukapura_dark|sukapura_dark_svg|sukapura_svg) WITH_THEMES="${WITH_THEMES:+$WITH_THEMES }$theme" ;;
   371         kx         *) AC_MSG_ERROR([Unknown value for --with-theme: $theme]) ;;
   371         kx         esac
   371         kx     done
   371         kx fi
   371         kx AC_MSG_RESULT([$WITH_THEMES])
   371         kx AC_SUBST([WITH_THEMES])
   371         kx 
   371         kx ###############################################################################
   371         kx # Extensions checking
   371         kx ###############################################################################
   371         kx AC_MSG_CHECKING([for extensions integration])
   371         kx if test "x$enable_extension_integration" != "xno"; then
   371         kx     WITH_EXTENSION_INTEGRATION=TRUE
   371         kx     SCPDEFS="$SCPDEFS -DWITH_EXTENSION_INTEGRATION"
   371         kx     AC_MSG_RESULT([yes, use integration])
   371         kx else
   371         kx     WITH_EXTENSION_INTEGRATION=
   371         kx     AC_MSG_RESULT([no, do not integrate])
   371         kx fi
   371         kx AC_SUBST(WITH_EXTENSION_INTEGRATION)
   371         kx 
   371         kx dnl Should any extra extensions be included?
   371         kx dnl There are standalone tests for each of these below.
   371         kx WITH_EXTRA_EXTENSIONS=
   371         kx AC_SUBST([WITH_EXTRA_EXTENSIONS])
   371         kx 
   371         kx libo_CHECK_EXTENSION([Numbertext],[NUMBERTEXT],[numbertext],[numbertext],[b7cae45ad2c23551fd6ccb8ae2c1f59e-numbertext_0.9.5.oxt])
   371         kx if test "x$with_java" != "xno"; then
   371         kx     libo_CHECK_EXTENSION([NLPSolver],[NLPSOLVER],[nlpsolver],[nlpsolver],[])
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to build opens___.ttf])
   371         kx if test "$enable_build_opensymbol" = "yes"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     AC_PATH_PROG(FONTFORGE, fontforge)
   371         kx     if test -z "$FONTFORGE"; then
   371         kx         AC_MSG_ERROR([fontforge not installed])
   371         kx     fi
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     BUILD_TYPE="$BUILD_TYPE OPENSYMBOL"
   371         kx fi
   371         kx AC_SUBST(FONTFORGE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to include fonts
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to include third-party fonts])
   371         kx if test "$with_fonts" != "no"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     WITH_FONTS=TRUE
   371         kx     BUILD_TYPE="$BUILD_TYPE MORE_FONTS"
   371         kx     AC_DEFINE(HAVE_MORE_FONTS)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx     WITH_FONTS=
   371         kx     SCPDEFS="$SCPDEFS -DWITHOUT_FONTS"
   371         kx fi
   371         kx AC_SUBST(WITH_FONTS)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to enable online update service
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable online update])
   371         kx ENABLE_ONLINE_UPDATE=
   371         kx if test "$enable_online_update" = ""; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     if test "$enable_online_update" = "mar"; then
   371         kx         AC_MSG_ERROR([--enable-online-update=mar is deprecated, use --enable-online-update-mar instead])
   371         kx     elif test "$enable_online_update" = "yes"; then
   371         kx         if test "$enable_curl" != "yes"; then
   371         kx             AC_MSG_ERROR([--disable-online-update must be used when --disable-curl is used])
   371         kx         fi
   371         kx         AC_MSG_RESULT([yes])
   371         kx         ENABLE_ONLINE_UPDATE="TRUE"
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ENABLE_ONLINE_UPDATE)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to enable mar online update service
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable mar online update])
   371         kx ENABLE_ONLINE_UPDATE_MAR=
   371         kx if test "$enable_online_update_mar" = yes; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     BUILD_TYPE="$BUILD_TYPE ONLINEUPDATE"
   371         kx     ENABLE_ONLINE_UPDATE_MAR="TRUE"
   371         kx     AC_DEFINE(HAVE_FEATURE_UPDATE_MAR)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_ONLINE_UPDATE_MAR)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update baseurl])
   371         kx ONLINEUPDATE_MAR_BASEURL=$with_online_update_mar_baseurl
   371         kx if test -n "$ONLINEUPDATE_MAR_BASEURL"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_BASEURL)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update certificateder])
   371         kx ONLINEUPDATE_MAR_CERTIFICATEDER=$with_online_update_mar_certificateder
   371         kx if test -n "$ONLINEUPDATE_MAR_CERTIFICATEDER"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_CERTIFICATEDER)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update certificatename])
   371         kx ONLINEUPDATE_MAR_CERTIFICATENAME=$with_online_update_mar_certificatename
   371         kx if test -n "$ONLINEUPDATE_MAR_CERTIFICATENAME"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_CERTIFICATENAME)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update certificatepath])
   371         kx ONLINEUPDATE_MAR_CERTIFICATEPATH=$with_online_update_mar_certificatepath
   371         kx if test -n "$ONLINEUPDATE_MAR_CERTIFICATEPATH"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_CERTIFICATEPATH)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update serverurl])
   371         kx ONLINEUPDATE_MAR_SERVERURL=$with_online_update_mar_serverurl
   371         kx if test -n "$ONLINEUPDATE_MAR_SERVERURL"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_SERVERURL)
   371         kx 
   371         kx AC_MSG_CHECKING([for mar online update uploadurl])
   371         kx ONLINEUPDATE_MAR_UPLOADURL=$with_online_update_mar_uploadurl
   371         kx if test -n "$ONLINEUPDATE_MAR_UPLOADURL"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ONLINEUPDATE_MAR_UPLOADURL)
   371         kx 
   371         kx 
   371         kx PRIVACY_POLICY_URL="$with_privacy_policy_url"
   371         kx if test "$ENABLE_ONLINE_UPDATE" = TRUE -o "$ENABLE_BREAKPAD" = "TRUE"; then
   371         kx     if test "x$with_privacy_policy_url" = "xundefined"; then
   371         kx         AC_MSG_FAILURE([online update or breakpad/crashreporting are enabled, but no --with-privacy-policy-url=... was provided])
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(PRIVACY_POLICY_URL)
   371         kx dnl ===================================================================
   371         kx dnl Test whether we need bzip2
   371         kx dnl ===================================================================
   371         kx SYSTEM_BZIP2=
   371         kx if test "$ENABLE_ONLINE_UPDATE_MAR" = "TRUE" -o "$enable_python" = internal; then
   371         kx     AC_MSG_CHECKING([whether to use system bzip2])
   371         kx     if test "$with_system_bzip2" = yes; then
   371         kx         SYSTEM_BZIP2=TRUE
   371         kx         AC_MSG_RESULT([yes])
   371         kx         PKG_CHECK_MODULES(BZIP2, bzip2)
   371         kx         FilterLibs "${BZIP2_LIBS}"
   371         kx         BZIP2_LIBS="${filteredlibs}"
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx         BUILD_TYPE="$BUILD_TYPE BZIP2"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_BZIP2)
   371         kx AC_SUBST(BZIP2_CFLAGS)
   371         kx AC_SUBST(BZIP2_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to enable extension update
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable extension update])
   371         kx ENABLE_EXTENSION_UPDATE=
   371         kx if test "x$enable_extension_update" = "xno"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_EXTENSION_UPDATE="TRUE"
   371         kx     AC_DEFINE(ENABLE_EXTENSION_UPDATE)
   371         kx     SCPDEFS="$SCPDEFS -DENABLE_EXTENSION_UPDATE"
   371         kx fi
   371         kx AC_SUBST(ENABLE_EXTENSION_UPDATE)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to create MSI with LIMITUI=1 (silent install)
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to create MSI with LIMITUI=1 (silent install)])
   371         kx if test "$enable_silent_msi" = "" -o "$enable_silent_msi" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_SILENT_MSI=
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     ENABLE_SILENT_MSI=TRUE
   371         kx     SCPDEFS="$SCPDEFS -DENABLE_SILENT_MSI"
   371         kx fi
   371         kx AC_SUBST(ENABLE_SILENT_MSI)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for WiX tools.
   371         kx dnl ===================================================================
   371         kx if test "$enable_wix" = "" -o "enable_wix" = "no"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx     ENABLE_WIX=
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx     # FIXME: this should do proper detection, but the path is currently
   371         kx     # hardcoded in msicreator/createmsi.py
   371         kx     if ! test -x "/cygdrive/c/Program Files (x86)/WiX Toolset v3.11/bin/candle"; then
   371         kx       AC_MSG_ERROR([WiX requested but WiX toolset v3.11 not found at the expected location])
   371         kx     fi
   371         kx     ENABLE_WIX=TRUE
   371         kx fi
   371         kx AC_SUBST(ENABLE_WIX)
   371         kx 
   371         kx AC_MSG_CHECKING([whether and how to use Xinerama])
   371         kx if test "$USING_X11" = TRUE; then
   371         kx     if test "$x_libraries" = "default_x_libraries"; then
   371         kx         XINERAMALIB=`$PKG_CONFIG --variable=libdir xinerama`
   371         kx         if test "x$XINERAMALIB" = x; then
   371         kx            XINERAMALIB="/usr/lib"
   371         kx         fi
   371         kx     else
   371         kx         XINERAMALIB="$x_libraries"
   371         kx     fi
   371         kx     if test -e "$XINERAMALIB/libXinerama.so" -a -e "$XINERAMALIB/libXinerama.a"; then
   371         kx         # we have both versions, let the user decide but use the dynamic one
   371         kx         # per default
   371         kx         USE_XINERAMA=TRUE
   371         kx         if test -z "$with_static_xinerama" -o -n "$with_system_libs"; then
   371         kx             XINERAMA_LINK=dynamic
   371         kx         else
   371         kx             XINERAMA_LINK=static
   371         kx         fi
   371         kx     elif test -e "$XINERAMALIB/libXinerama.so" -a ! -e "$XINERAMALIB/libXinerama.a"; then
   371         kx         # we have only the dynamic version
   371         kx         USE_XINERAMA=TRUE
   371         kx         XINERAMA_LINK=dynamic
   371         kx     elif test -e "$XINERAMALIB/libXinerama.a"; then
   371         kx         # static version
   371         kx         if echo $host_cpu | $GREP -E 'i[[3456]]86' 2>/dev/null >/dev/null; then
   371         kx             USE_XINERAMA=TRUE
   371         kx             XINERAMA_LINK=static
   371         kx         else
   371         kx             USE_XINERAMA=
   371         kx             XINERAMA_LINK=none
   371         kx         fi
   371         kx     else
   371         kx         # no Xinerama
   371         kx         USE_XINERAMA=
   371         kx         XINERAMA_LINK=none
   371         kx     fi
   371         kx     if test "$USE_XINERAMA" = "TRUE"; then
   371         kx         AC_MSG_RESULT([yes, with $XINERAMA_LINK linking])
   371         kx         AC_CHECK_HEADER(X11/extensions/Xinerama.h, [],
   371         kx             [AC_MSG_ERROR(Xinerama header not found.)], [])
   371         kx         XEXTLIBS=`$PKG_CONFIG --variable=libs xext`
   371         kx         if test "x$XEXTLIB" = x; then
   371         kx            XEXTLIBS="-L$XLIB -L$XINERAMALIB -lXext"
   371         kx         fi
   371         kx         XINERAMA_EXTRA_LIBS="$XEXTLIBS"
   371         kx         if test "$_os" = "FreeBSD"; then
   371         kx             XINERAMA_EXTRA_LIBS="$XINERAMA_EXTRA_LIBS -lXt"
   371         kx         fi
   371         kx         if test "$_os" = "Linux"; then
   371         kx             XINERAMA_EXTRA_LIBS="$XINERAMA_EXTRA_LIBS -ldl"
   371         kx         fi
   371         kx         AC_CHECK_LIB([Xinerama], [XineramaIsActive], [:],
   371         kx             [AC_MSG_ERROR(Xinerama not functional?)], [$XINERAMA_EXTRA_LIBS])
   371         kx     else
   371         kx         AC_MSG_ERROR([libXinerama not found or wrong architecture.])
   371         kx     fi
   371         kx else
   371         kx     USE_XINERAMA=
   371         kx     XINERAMA_LINK=none
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(XINERAMA_LINK)
   371         kx 
   371         kx AC_MSG_CHECKING([whether to use non-standard RGBA32 cairo pixel order])
   371         kx if test -z "$enable_cairo_rgba" -a "$_os" = "Android"; then
   371         kx     enable_cairo_rgba=yes
   371         kx fi
   371         kx if test "$enable_cairo_rgba" = yes; then
   371         kx     AC_DEFINE(ENABLE_CAIRO_RGBA)
   371         kx     ENABLE_CAIRO_RGBA=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     ENABLE_CAIRO_RGBA=
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ENABLE_CAIRO_RGBA)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to build cairo or rely on the system version
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test "$test_cairo" = "yes"; then
   371         kx     AC_MSG_CHECKING([whether to use the system cairo])
   371         kx 
   371         kx     : ${with_system_cairo:=$with_system_libs}
   371         kx     if test "$with_system_cairo" = "yes" -a "$enable_cairo_rgba" != "yes"; then
   371         kx         SYSTEM_CAIRO=TRUE
   371         kx         AC_MSG_RESULT([yes])
   371         kx 
   371         kx         PKG_CHECK_MODULES( CAIRO, cairo >= 1.12.0 )
   371         kx         CAIRO_CFLAGS=$(printf '%s' "$CAIRO_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx         FilterLibs "${CAIRO_LIBS}"
   371         kx         CAIRO_LIBS="${filteredlibs}"
   371         kx 
   371         kx         if test "$test_xrender" = "yes"; then
   371         kx             AC_MSG_CHECKING([whether Xrender.h defines PictStandardA8])
   371         kx             AC_LANG_PUSH([C])
   371         kx             AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <X11/extensions/Xrender.h>]],[[
   371         kx #ifdef PictStandardA8
   371         kx #else
   371         kx       return fail;
   371         kx #endif
   371         kx ]])],[AC_MSG_RESULT([yes])],[AC_MSG_ERROR([no, X headers too old.])])
   371         kx 
   371         kx             AC_LANG_POP([C])
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx         BUILD_TYPE="$BUILD_TYPE CAIRO"
   371         kx     fi
   371         kx 
   371         kx     if test "$enable_cairo_canvas" != no; then
   371         kx         AC_DEFINE(ENABLE_CAIRO_CANVAS)
   371         kx         ENABLE_CAIRO_CANVAS=TRUE
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx AC_SUBST(CAIRO_CFLAGS)
   371         kx AC_SUBST(CAIRO_LIBS)
   371         kx AC_SUBST(ENABLE_CAIRO_CANVAS)
   371         kx AC_SUBST(SYSTEM_CAIRO)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to use avahi
   371         kx dnl ===================================================================
   371         kx if test "$_os" = "WINNT"; then
   371         kx     # Windows uses bundled mDNSResponder
   371         kx     BUILD_TYPE="$BUILD_TYPE MDNSRESPONDER"
   371         kx elif test "$_os" != "Darwin" -a "$enable_avahi" = "yes"; then
   371         kx     PKG_CHECK_MODULES([AVAHI], [avahi-client >= 0.6.10],
   371         kx                       [ENABLE_AVAHI="TRUE"])
   371         kx     AC_DEFINE(HAVE_FEATURE_AVAHI)
   371         kx     AVAHI_CFLAGS=$(printf '%s' "$AVAHI_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${AVAHI_LIBS}"
   371         kx     AVAHI_LIBS="${filteredlibs}"
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_AVAHI)
   371         kx AC_SUBST(AVAHI_CFLAGS)
   371         kx AC_SUBST(AVAHI_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to use liblangtag
   371         kx dnl ===================================================================
   371         kx SYSTEM_LIBLANGTAG=
   371         kx AC_MSG_CHECKING([whether to use system liblangtag])
   371         kx if test "$with_system_liblangtag" = yes; then
   371         kx     SYSTEM_LIBLANGTAG=TRUE
   371         kx     AC_MSG_RESULT([yes])
   371         kx     PKG_CHECK_MODULES( LIBLANGTAG, liblangtag >= 0.4.0)
   371         kx     dnl cf. <https://bitbucket.org/tagoh/liblangtag/commits/9324836a0d1c> "Fix a build issue with inline keyword"
   371         kx     PKG_CHECK_EXISTS([liblangtag >= 0.5.5], [], [AC_DEFINE([LIBLANGTAG_INLINE_FIX])])
   371         kx     LIBLANGTAG_CFLAGS=$(printf '%s' "$LIBLANGTAG_CFLAGS" | sed -e "s/-I/${ISYSTEM?}/g")
   371         kx     FilterLibs "${LIBLANGTAG_LIBS}"
   371         kx     LIBLANGTAG_LIBS="${filteredlibs}"
   371         kx else
   371         kx     SYSTEM_LIBLANGTAG=
   371         kx     AC_MSG_RESULT([no])
   371         kx     BUILD_TYPE="$BUILD_TYPE LIBLANGTAG"
   371         kx     LIBLANGTAG_CFLAGS="-I${WORKDIR}/UnpackedTarball/liblangtag"
   371         kx     if test "$COM" = "MSC"; then
   371         kx         LIBLANGTAG_LIBS="${WORKDIR}/UnpackedTarball/liblangtag/liblangtag/.libs/liblangtag.lib"
   371         kx     else
   371         kx         LIBLANGTAG_LIBS="-L${WORKDIR}/UnpackedTarball/liblangtag/liblangtag/.libs -llangtag"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(SYSTEM_LIBLANGTAG)
   371         kx AC_SUBST(LIBLANGTAG_CFLAGS)
   371         kx AC_SUBST(LIBLANGTAG_LIBS)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to build libpng or rely on the system version
   371         kx dnl ===================================================================
   371         kx 
   371         kx LIBPNG_CFLAGS_internal="-I${WORKDIR}/UnpackedTarball/libpng"
   371         kx LIBPNG_LIBS_internal="-L${WORKDIR}/LinkTarget/StaticLibrary -llibpng"
   371         kx libo_CHECK_SYSTEM_MODULE([libpng],[LIBPNG],[libpng])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to build libtiff or rely on the system version
   371         kx dnl ===================================================================
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libtiff],[LIBTIFF],[libtiff-4])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test whether to build libwebp or rely on the system version
   371         kx dnl ===================================================================
   371         kx 
   371         kx libo_CHECK_SYSTEM_MODULE([libwebp],[LIBWEBP],[libwebp])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Check for runtime JVM search path
   371         kx dnl ===================================================================
   371         kx if test "$ENABLE_JAVA" != ""; then
   371         kx     AC_MSG_CHECKING([whether to use specific JVM search path at runtime])
   371         kx     if test -n "$with_jvm_path" -a "$with_jvm_path" != "no"; then
   371         kx         AC_MSG_RESULT([yes])
   371         kx         if ! test -d "$with_jvm_path"; then
   371         kx             AC_MSG_ERROR(["$with_jvm_path" not a directory])
   371         kx         fi
   371         kx         if ! test -d "$with_jvm_path"jvm; then
   371         kx             AC_MSG_ERROR(["$with_jvm_path"jvm not found, point with_jvm_path to \[/path/to/\]jvm])
   371         kx         fi
   371         kx         JVM_ONE_PATH_CHECK="$with_jvm_path"
   371         kx         AC_SUBST(JVM_ONE_PATH_CHECK)
   371         kx     else
   371         kx         AC_MSG_RESULT([no])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Test for the presence of Ant and that it works
   371         kx dnl ===================================================================
   371         kx 
   371         kx # java takes the encoding from LC_ALL, and since autoconf forces it to C it
   371         kx # breaks filename decoding, so for the ant section, set it to LANG
   371         kx LC_ALL=$LANG
   371         kx if test "$ENABLE_JAVA" != "" -a "$NEED_ANT" = "TRUE" -a "$cross_compiling" != "yes"; then
   371         kx     ANT_HOME=; export ANT_HOME
   371         kx     WITH_ANT_HOME=; export WITH_ANT_HOME
   371         kx     if test -z "$with_ant_home" -a -n "$LODE_HOME" ; then
   371         kx         if test -x "$LODE_HOME/opt/ant/bin/ant" ; then
   371         kx             if test "$_os" = "WINNT"; then
   371         kx                 with_ant_home="`cygpath -m $LODE_HOME/opt/ant`"
   371         kx             else
   371         kx                 with_ant_home="$LODE_HOME/opt/ant"
   371         kx             fi
   371         kx         elif test -x  "$LODE_HOME/opt/bin/ant" ; then
   371         kx             with_ant_home="$LODE_HOME/opt/ant"
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$with_ant_home"; then
   371         kx         AC_PATH_PROGS(ANT, [ant ant.sh ant.bat ant.cmd])
   371         kx     else
   371         kx         if test "$_os" = "WINNT"; then
   371         kx             # AC_PATH_PROGS needs unix path
   371         kx             with_ant_home=`cygpath -u "$with_ant_home"`
   371         kx         fi
   371         kx         AbsolutePath "$with_ant_home"
   371         kx         with_ant_home=$absolute_path
   371         kx         AC_PATH_PROGS(ANT, [ant ant.sh ant.bat ant.cmd],,$with_ant_home/bin:$PATH)
   371         kx         WITH_ANT_HOME=$with_ant_home
   371         kx         ANT_HOME=$with_ant_home
   371         kx     fi
   371         kx 
   371         kx     if test -z "$ANT"; then
   371         kx         AC_MSG_ERROR([Ant not found - Make sure it's in the path or use --with-ant-home])
   371         kx     else
   371         kx         # resolve relative or absolute symlink
   371         kx         while test -h "$ANT"; do
   371         kx             a_cwd=`pwd`
   371         kx             a_basename=`basename "$ANT"`
   371         kx             a_script=`ls -l "$ANT" | $SED "s/.*${a_basename} -> //g"`
   371         kx             cd "`dirname "$ANT"`"
   371         kx             cd "`dirname "$a_script"`"
   371         kx             ANT="`pwd`"/"`basename "$a_script"`"
   371         kx             cd "$a_cwd"
   371         kx         done
   371         kx 
   371         kx         AC_MSG_CHECKING([if $ANT works])
   371         kx         mkdir -p conftest.dir
   371         kx         a_cwd=$(pwd)
   371         kx         cd conftest.dir
   371         kx         cat > conftest.java << EOF
   371         kx         public class conftest {
   371         kx             int testmethod(int a, int b) {
   371         kx                     return a + b;
   371         kx             }
   371         kx         }
   371         kx EOF
   371         kx 
   371         kx         cat > conftest.xml << EOF
   371         kx         <project name="conftest" default="conftest">
   371         kx         <target name="conftest">
   371         kx             <javac srcdir="." includes="conftest.java">
   371         kx             </javac>
   371         kx         </target>
   371         kx         </project>
   371         kx EOF
   371         kx 
   371         kx         AC_TRY_COMMAND("$ANT" -buildfile conftest.xml 1>&2)
   371         kx         if test $? = 0 -a -f ./conftest.class; then
   371         kx             AC_MSG_RESULT([Ant works])
   371         kx             if test -z "$WITH_ANT_HOME"; then
   371         kx                 ANT_HOME=`"$ANT" -diagnostics | $EGREP "ant.home :" | $SED -e "s#ant.home : ##g"`
   371         kx                 if test -z "$ANT_HOME"; then
   371         kx                     ANT_HOME=`echo "$ANT" | $SED -n "s/\/bin\/ant.*\$//p"`
   371         kx                 fi
   371         kx             else
   371         kx                 ANT_HOME="$WITH_ANT_HOME"
   371         kx             fi
   371         kx         else
   371         kx             echo "configure: Ant test failed" >&5
   371         kx             cat conftest.java >&5
   371         kx             cat conftest.xml >&5
   371         kx             AC_MSG_ERROR([Ant does not work - Some Java projects will not build!])
   371         kx         fi
   371         kx         cd "$a_cwd"
   371         kx         rm -fr conftest.dir
   371         kx     fi
   371         kx     if test -z "$ANT_HOME"; then
   371         kx         ANT_HOME="NO_ANT_HOME"
   371         kx     else
   371         kx         PathFormat "$ANT_HOME"
   371         kx         ANT_HOME="$formatted_path"
   371         kx         PathFormat "$ANT"
   371         kx         ANT="$formatted_path"
   371         kx     fi
   371         kx 
   371         kx     dnl Checking for ant.jar
   371         kx     if test "$ANT_HOME" != "NO_ANT_HOME"; then
   371         kx         AC_MSG_CHECKING([Ant lib directory])
   371         kx         if test -f $ANT_HOME/lib/ant.jar; then
   371         kx             ANT_LIB="$ANT_HOME/lib"
   371         kx         else
   371         kx             if test -f $ANT_HOME/ant.jar; then
   371         kx                 ANT_LIB="$ANT_HOME"
   371         kx             else
   371         kx                 if test -f /usr/share/java/ant.jar; then
   371         kx                     ANT_LIB=/usr/share/java
   371         kx                 else
   371         kx                     if test -f /usr/share/ant-core/lib/ant.jar; then
   371         kx                         ANT_LIB=/usr/share/ant-core/lib
   371         kx                     else
   371         kx                         if test -f $ANT_HOME/lib/ant/ant.jar; then
   371         kx                             ANT_LIB="$ANT_HOME/lib/ant"
   371         kx                         else
   371         kx                             if test -f /usr/share/lib/ant/ant.jar; then
   371         kx                                 ANT_LIB=/usr/share/lib/ant
   371         kx                             else
   371         kx                                 AC_MSG_ERROR([Ant libraries not found!])
   371         kx                             fi
   371         kx                         fi
   371         kx                     fi
   371         kx                 fi
   371         kx             fi
   371         kx         fi
   371         kx         PathFormat "$ANT_LIB"
   371         kx         ANT_LIB="$formatted_path"
   371         kx         AC_MSG_RESULT([Ant lib directory found.])
   371         kx     fi
   371         kx 
   371         kx     ant_minver=1.6.0
   371         kx     ant_minminor1=`echo $ant_minver | cut -d"." -f2`
   371         kx 
   371         kx     AC_MSG_CHECKING([whether Ant is >= $ant_minver])
   371         kx     ant_version=`"$ANT" -version | $AWK '$3 == "version" { print $4; }'`
   371         kx     ant_version_major=`echo $ant_version | cut -d. -f1`
   371         kx     ant_version_minor=`echo $ant_version | cut -d. -f2`
   371         kx     echo "configure: ant_version $ant_version " >&5
   371         kx     echo "configure: ant_version_major $ant_version_major " >&5
   371         kx     echo "configure: ant_version_minor $ant_version_minor " >&5
   371         kx     if test "$ant_version_major" -ge "2"; then
   371         kx         AC_MSG_RESULT([yes, $ant_version])
   371         kx     elif test "$ant_version_major" = "1" -a "$ant_version_minor" -ge "$ant_minminor1"; then
   371         kx         AC_MSG_RESULT([yes, $ant_version])
   371         kx     else
   371         kx         AC_MSG_ERROR([no, you need at least Ant >= $ant_minver])
   371         kx     fi
   371         kx 
   371         kx     rm -f conftest* core core.* *.core
   371         kx fi
   371         kx AC_SUBST(ANT)
   371         kx AC_SUBST(ANT_HOME)
   371         kx AC_SUBST(ANT_LIB)
   371         kx 
   371         kx OOO_JUNIT_JAR=
   371         kx HAMCREST_JAR=
   371         kx if test "$ENABLE_JAVA" != "" -a "$with_junit" != "no" -a "$cross_compiling" != "yes"; then
   371         kx     AC_MSG_CHECKING([for JUnit 4])
   371         kx     if test "$with_junit" = "yes"; then
   371         kx         if test -n "$LODE_HOME" -a -e "$LODE_HOME/opt/share/java/junit.jar" ; then
   371         kx             OOO_JUNIT_JAR="$LODE_HOME/opt/share/java/junit.jar"
   371         kx         elif test -e /usr/share/java/junit4.jar; then
   371         kx             OOO_JUNIT_JAR=/usr/share/java/junit4.jar
   371         kx         else
   371         kx            if test -e /usr/share/lib/java/junit.jar; then
   371         kx               OOO_JUNIT_JAR=/usr/share/lib/java/junit.jar
   371         kx            else
   371         kx               OOO_JUNIT_JAR=/usr/share/java/junit.jar
   371         kx            fi
   371         kx         fi
   371         kx     else
   371         kx         OOO_JUNIT_JAR=$with_junit
   371         kx     fi
   371         kx     if test "$_os" = "WINNT"; then
   371         kx         OOO_JUNIT_JAR=`cygpath -m "$OOO_JUNIT_JAR"`
   371         kx     fi
   371         kx     printf 'import org.junit.Before;' > conftest.java
   371         kx     if "$JAVACOMPILER" -classpath "$OOO_JUNIT_JAR" conftest.java >&5 2>&5; then
   371         kx         AC_MSG_RESULT([$OOO_JUNIT_JAR])
   371         kx     else
   371         kx         AC_MSG_ERROR(
   371         kx [cannot find JUnit 4 jar; please install one in the default location (/usr/share/java),
   371         kx  specify its pathname via --with-junit=..., or disable it via --without-junit])
   371         kx     fi
   371         kx     rm -f conftest.class conftest.java
   371         kx     if test $OOO_JUNIT_JAR != ""; then
   371         kx         BUILD_TYPE="$BUILD_TYPE QADEVOOO"
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_CHECKING([for included Hamcrest])
   371         kx     printf 'import org.hamcrest.BaseDescription;' > conftest.java
   371         kx     if "$JAVACOMPILER" -classpath "$OOO_JUNIT_JAR" conftest.java >&5 2>&5; then
   371         kx         AC_MSG_RESULT([Included in $OOO_JUNIT_JAR])
   371         kx     else
   371         kx         AC_MSG_RESULT([Not included])
   371         kx         AC_MSG_CHECKING([for standalone hamcrest jar.])
   371         kx         if test "$with_hamcrest" = "yes"; then
   371         kx             if test -e /usr/share/lib/java/hamcrest.jar; then
   371         kx                 HAMCREST_JAR=/usr/share/lib/java/hamcrest.jar
   371         kx             elif test -e /usr/share/java/hamcrest/core.jar; then
   371         kx                 HAMCREST_JAR=/usr/share/java/hamcrest/core.jar
   371         kx             elif test -e /usr/share/java/hamcrest/hamcrest.jar; then
   371         kx                 HAMCREST_JAR=/usr/share/java/hamcrest/hamcrest.jar
   371         kx             else
   371         kx                 HAMCREST_JAR=/usr/share/java/hamcrest.jar
   371         kx             fi
   371         kx         else
   371         kx             HAMCREST_JAR=$with_hamcrest
   371         kx         fi
   371         kx         if test "$_os" = "WINNT"; then
   371         kx             HAMCREST_JAR=`cygpath -m "$HAMCREST_JAR"`
   371         kx         fi
   371         kx         if "$JAVACOMPILER" -classpath "$HAMCREST_JAR" conftest.java >&5 2>&5; then
   371         kx             AC_MSG_RESULT([$HAMCREST_JAR])
   371         kx         else
   371         kx             AC_MSG_ERROR([junit does not contain hamcrest; please use a junit jar that includes hamcrest, install a hamcrest jar in the default location (/usr/share/java),
   371         kx                           specify its path with --with-hamcrest=..., or disable junit with --without-junit])
   371         kx         fi
   371         kx     fi
   371         kx     rm -f conftest.class conftest.java
   371         kx fi
   371         kx AC_SUBST(OOO_JUNIT_JAR)
   371         kx AC_SUBST(HAMCREST_JAR)
   371         kx # set back LC_ALL to C after the java related tests...
   371         kx LC_ALL=C
   371         kx 
   371         kx AC_SUBST(SCPDEFS)
   371         kx 
   371         kx #
   371         kx # check for wget and curl
   371         kx #
   371         kx WGET=
   371         kx CURL=
   371         kx 
   371         kx if test "$enable_fetch_external" != "no"; then
   371         kx 
   371         kx CURL=`which curl 2>/dev/null`
   371         kx 
   371         kx for i in wget /usr/bin/wget /usr/local/bin/wget /usr/sfw/bin/wget /opt/sfw/bin/wget /opt/local/bin/wget; do
   371         kx     # wget new enough?
   371         kx     $i --help 2> /dev/null | $GREP no-use-server-timestamps 2>&1 > /dev/null
   371         kx     if test $? -eq 0; then
   371         kx         WGET=$i
   371         kx         break
   371         kx     fi
   371         kx done
   371         kx 
   371         kx if test -z "$WGET" -a -z "$CURL"; then
   371         kx     AC_MSG_ERROR([neither wget nor curl found!])
   371         kx fi
   371         kx 
   371         kx fi
   371         kx 
   371         kx AC_SUBST(WGET)
   371         kx AC_SUBST(CURL)
   371         kx 
   371         kx #
   371         kx # check for sha256sum
   371         kx #
   371         kx SHA256SUM=
   371         kx 
   371         kx for i in shasum /usr/local/bin/shasum /usr/sfw/bin/shasum /opt/sfw/bin/shasum /opt/local/bin/shasum; do
   371         kx     eval "$i -a 256 --version" > /dev/null 2>&1
   371         kx     ret=$?
   371         kx     if test $ret -eq 0; then
   371         kx         SHA256SUM="$i -a 256"
   371         kx         break
   371         kx     fi
   371         kx done
   371         kx 
   371         kx if test -z "$SHA256SUM"; then
   371         kx     for i in sha256sum /usr/local/bin/sha256sum /usr/sfw/bin/sha256sum /opt/sfw/bin/sha256sum /opt/local/bin/sha256sum; do
   371         kx         eval "$i --version" > /dev/null 2>&1
   371         kx         ret=$?
   371         kx         if test $ret -eq 0; then
   371         kx             SHA256SUM=$i
   371         kx             break
   371         kx         fi
   371         kx     done
   371         kx fi
   371         kx 
   371         kx if test -z "$SHA256SUM"; then
   371         kx     AC_MSG_ERROR([no sha256sum found!])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(SHA256SUM)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Dealing with l10n options
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([which languages to be built])
   371         kx # get list of all languages
   371         kx # generate shell variable from completelangiso= from solenv/inc/langlist.mk
   371         kx # the sed command does the following:
   371         kx #   + if a line ends with a backslash, append the next line to it
   371         kx #   + adds " on the beginning of the value (after =)
   371         kx #   + adds " at the end of the value
   371         kx #   + removes en-US; we want to put it on the beginning
   371         kx #   + prints just the section starting with 'completelangiso=' and ending with the " at the end of line
   371         kx [eval $(sed -e :a -e '/\\$/N; s/\\\n//; ta' -n -e 's/=/="/;s/\([^\\]\)$/\1"/;s/en-US//;/^completelangiso/p' $SRC_ROOT/solenv/inc/langlist.mk)]
   371         kx ALL_LANGS="en-US $completelangiso"
   371         kx # check the configured localizations
   371         kx WITH_LANG="$with_lang"
   371         kx 
   371         kx # Check for --without-lang which turns up as $with_lang being "no". Luckily there is no language with code "no".
   371         kx # (Norwegian is "nb" and "nn".)
   371         kx if test "$WITH_LANG" = "no"; then
   371         kx     WITH_LANG=
   371         kx fi
   371         kx 
   371         kx if test -z "$WITH_LANG" -o "$WITH_LANG" = "en-US"; then
   371         kx     AC_MSG_RESULT([en-US])
   371         kx else
   371         kx     AC_MSG_RESULT([$WITH_LANG])
   371         kx     GIT_NEEDED_SUBMODULES="translations $GIT_NEEDED_SUBMODULES"
   371         kx     if test -z "$MSGFMT"; then
   371         kx         if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/msgfmt" ; then
   371         kx             MSGFMT="$LODE_HOME/opt/bin/msgfmt"
   371         kx         elif test -x "/opt/lo/bin/msgfmt"; then
   371         kx             MSGFMT="/opt/lo/bin/msgfmt"
   371         kx         else
   371         kx             AC_CHECK_PROGS(MSGFMT, [msgfmt])
   371         kx             if test -z "$MSGFMT"; then
   371         kx                 AC_MSG_ERROR([msgfmt not found. Install GNU gettext, or re-run without languages.])
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx     if test -z "$MSGUNIQ"; then
   371         kx         if test -n "$LODE_HOME" -a -x "$LODE_HOME/opt/bin/msguniq" ; then
   371         kx             MSGUNIQ="$LODE_HOME/opt/bin/msguniq"
   371         kx         elif test -x "/opt/lo/bin/msguniq"; then
   371         kx             MSGUNIQ="/opt/lo/bin/msguniq"
   371         kx         else
   371         kx             AC_CHECK_PROGS(MSGUNIQ, [msguniq])
   371         kx             if test -z "$MSGUNIQ"; then
   371         kx                 AC_MSG_ERROR([msguniq not found. Install GNU gettext, or re-run without languages.])
   371         kx             fi
   371         kx         fi
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(MSGFMT)
   371         kx AC_SUBST(MSGUNIQ)
   371         kx # check that the list is valid
   371         kx for lang in $WITH_LANG; do
   371         kx     test "$lang" = "ALL" && continue
   371         kx     # need to check for the exact string, so add space before and after the list of all languages
   371         kx     for vl in $ALL_LANGS; do
   371         kx         if test "$vl" = "$lang"; then
   371         kx            break
   371         kx         fi
   371         kx     done
   371         kx     if test "$vl" != "$lang"; then
   371         kx         # if you're reading this - you prolly quoted your languages remove the quotes ...
   371         kx         AC_MSG_ERROR([invalid language: '$lang' (vs '$v1'); supported languages are: $ALL_LANGS])
   371         kx     fi
   371         kx done
   371         kx if test -n "$WITH_LANG" -a "$WITH_LANG" != "ALL"; then
   371         kx     echo $WITH_LANG | grep -q en-US
   371         kx     test $? -ne 1 || WITH_LANG=`echo $WITH_LANG en-US`
   371         kx fi
   371         kx # list with substituted ALL
   371         kx WITH_LANG_LIST=`echo $WITH_LANG | sed "s/ALL/$ALL_LANGS/"`
   371         kx test -z "$WITH_LANG_LIST" && WITH_LANG_LIST="en-US"
   371         kx test "$WITH_LANG" = "en-US" && WITH_LANG=
   371         kx if test "$enable_release_build" = "" -o "$enable_release_build" = "no"; then
   371         kx     test "$WITH_LANG_LIST" = "en-US" || WITH_LANG_LIST=`echo $WITH_LANG_LIST qtz`
   371         kx     ALL_LANGS=`echo $ALL_LANGS qtz`
   371         kx fi
   371         kx AC_SUBST(ALL_LANGS)
   371         kx AC_DEFINE_UNQUOTED(WITH_LANG,"$WITH_LANG")
   371         kx AC_SUBST(WITH_LANG)
   371         kx AC_SUBST(WITH_LANG_LIST)
   371         kx AC_SUBST(GIT_NEEDED_SUBMODULES)
   371         kx 
   371         kx WITH_POOR_HELP_LOCALIZATIONS=
   371         kx if test -d "$SRC_ROOT/translations/source"; then
   371         kx     for l in `ls -1 $SRC_ROOT/translations/source`; do
   371         kx         if test ! -d "$SRC_ROOT/translations/source/$l/helpcontent2"; then
   371         kx             WITH_POOR_HELP_LOCALIZATIONS="$WITH_POOR_HELP_LOCALIZATIONS $l"
   371         kx         fi
   371         kx     done
   371         kx fi
   371         kx AC_SUBST(WITH_POOR_HELP_LOCALIZATIONS)
   371         kx 
   371         kx if test -n "$with_locales" -a "$with_locales" != ALL; then
   371         kx     WITH_LOCALES="$with_locales"
   371         kx 
   371         kx     just_langs="`echo $WITH_LOCALES | sed -e 's/_[A-Z]*//g'`"
   371         kx     # Only languages and scripts for which we actually have ifdefs need to be handled. Also see
   371         kx     # config_host/config_locales.h.in
   371         kx     for locale in $WITH_LOCALES; do
   371         kx         lang=${locale%_*}
   371         kx 
   371         kx         AC_DEFINE_UNQUOTED(WITH_LOCALE_$lang, 1)
   371         kx 
   371         kx         case $lang in
   371         kx         hi|mr*ne)
   371         kx             AC_DEFINE(WITH_LOCALE_FOR_SCRIPT_Deva)
   371         kx             ;;
   371         kx         bg|ru)
   371         kx             AC_DEFINE(WITH_LOCALE_FOR_SCRIPT_Cyrl)
   371         kx             ;;
   371         kx         esac
   371         kx     done
   371         kx else
   371         kx     AC_DEFINE(WITH_LOCALE_ALL)
   371         kx fi
   371         kx AC_SUBST(WITH_LOCALES)
   371         kx 
   371         kx dnl git submodule update --reference
   371         kx dnl ===================================================================
   371         kx if test -n "${GIT_REFERENCE_SRC}"; then
   371         kx     for repo in ${GIT_NEEDED_SUBMODULES}; do
   371         kx         if ! test -d "${GIT_REFERENCE_SRC}"/${repo}; then
   371         kx             AC_MSG_ERROR([referenced git: required repository does not exist: ${GIT_REFERENCE_SRC}/${repo}])
   371         kx         fi
   371         kx     done
   371         kx fi
   371         kx AC_SUBST(GIT_REFERENCE_SRC)
   371         kx 
   371         kx dnl git submodules linked dirs
   371         kx dnl ===================================================================
   371         kx if test -n "${GIT_LINK_SRC}"; then
   371         kx     for repo in ${GIT_NEEDED_SUBMODULES}; do
   371         kx         if ! test -d "${GIT_LINK_SRC}"/${repo}; then
   371         kx             AC_MSG_ERROR([linked git: required repository does not exist: ${GIT_LINK_SRC}/${repo}])
   371         kx         fi
   371         kx     done
   371         kx fi
   371         kx AC_SUBST(GIT_LINK_SRC)
   371         kx 
   371         kx dnl branding
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([for alternative branding images directory])
   371         kx # initialize mapped arrays
   371         kx BRAND_INTRO_IMAGES="intro.png intro-highres.png"
   371         kx brand_files="$BRAND_INTRO_IMAGES logo.svg logo_inverted.svg logo-sc.svg logo-sc_inverted.svg about.svg"
   371         kx 
   371         kx if test -z "$with_branding" -o "$with_branding" = "no"; then
   371         kx     AC_MSG_RESULT([none])
   371         kx     DEFAULT_BRAND_IMAGES="$brand_files"
   371         kx else
   371         kx     if ! test -d $with_branding ; then
   371         kx         AC_MSG_ERROR([No directory $with_branding, falling back to default branding])
   371         kx     else
   371         kx         AC_MSG_RESULT([$with_branding])
   371         kx         CUSTOM_BRAND_DIR="$with_branding"
   371         kx         for lfile in $brand_files
   371         kx         do
   371         kx             if ! test -f $with_branding/$lfile ; then
   371         kx                 AC_MSG_WARN([Branded file $lfile does not exist, using the default one])
   371         kx                 DEFAULT_BRAND_IMAGES="$DEFAULT_BRAND_IMAGES $lfile"
   371         kx             else
   371         kx                 CUSTOM_BRAND_IMAGES="$CUSTOM_BRAND_IMAGES $lfile"
   371         kx             fi
   371         kx         done
   371         kx         check_for_progress="yes"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST([BRAND_INTRO_IMAGES])
   371         kx AC_SUBST([CUSTOM_BRAND_DIR])
   371         kx AC_SUBST([CUSTOM_BRAND_IMAGES])
   371         kx AC_SUBST([DEFAULT_BRAND_IMAGES])
   371         kx 
   371         kx 
   371         kx AC_MSG_CHECKING([for 'intro' progress settings])
   371         kx PROGRESSBARCOLOR=
   371         kx PROGRESSSIZE=
   371         kx PROGRESSPOSITION=
   371         kx PROGRESSFRAMECOLOR=
   371         kx PROGRESSTEXTCOLOR=
   371         kx PROGRESSTEXTBASELINE=
   371         kx 
   371         kx if test "$check_for_progress" = "yes" -a -f "$with_branding/progress.conf" ; then
   371         kx     source "$with_branding/progress.conf"
   371         kx     AC_MSG_RESULT([settings found in $with_branding/progress.conf])
   371         kx else
   371         kx     AC_MSG_RESULT([none])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(PROGRESSBARCOLOR)
   371         kx AC_SUBST(PROGRESSSIZE)
   371         kx AC_SUBST(PROGRESSPOSITION)
   371         kx AC_SUBST(PROGRESSFRAMECOLOR)
   371         kx AC_SUBST(PROGRESSTEXTCOLOR)
   371         kx AC_SUBST(PROGRESSTEXTBASELINE)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Custom build version
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([for extra build ID])
   371         kx if test -n "$with_extra_buildid" -a "$with_extra_buildid" != "yes" ; then
   371         kx     EXTRA_BUILDID="$with_extra_buildid"
   371         kx fi
   371         kx # in tinderboxes, it is easier to set EXTRA_BUILDID via the environment variable instead of configure switch
   371         kx if test -n "$EXTRA_BUILDID" ; then
   371         kx     AC_MSG_RESULT([$EXTRA_BUILDID])
   371         kx else
   371         kx     AC_MSG_RESULT([not set])
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED([EXTRA_BUILDID], ["$EXTRA_BUILDID"])
   371         kx 
   371         kx OOO_VENDOR=
   371         kx AC_MSG_CHECKING([for vendor])
   371         kx if test -z "$with_vendor" -o "$with_vendor" = "no"; then
   371         kx     OOO_VENDOR="$USERNAME"
   371         kx 
   371         kx     if test -z "$OOO_VENDOR"; then
   371         kx         OOO_VENDOR="$USER"
   371         kx     fi
   371         kx 
   371         kx     if test -z "$OOO_VENDOR"; then
   371         kx         OOO_VENDOR="`id -u -n`"
   371         kx     fi
   371         kx 
   371         kx     AC_MSG_RESULT([not set, using $OOO_VENDOR])
   371         kx else
   371         kx     OOO_VENDOR="$with_vendor"
   371         kx     AC_MSG_RESULT([$OOO_VENDOR])
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED(OOO_VENDOR,"$OOO_VENDOR")
   371         kx AC_SUBST(OOO_VENDOR)
   371         kx 
   371         kx if test "$_os" = "Android" ; then
   371         kx     ANDROID_PACKAGE_NAME=
   371         kx     AC_MSG_CHECKING([for Android package name])
   371         kx     if test -z "$with_android_package_name" -o "$with_android_package_name" = "no"; then
   371         kx         if test -n "$ENABLE_DEBUG"; then
   371         kx             # Default to the package name that makes ndk-gdb happy.
   371         kx             ANDROID_PACKAGE_NAME="org.libreoffice"
   371         kx         else
   371         kx             ANDROID_PACKAGE_NAME="org.example.libreoffice"
   371         kx         fi
   371         kx 
   371         kx         AC_MSG_RESULT([not set, using $ANDROID_PACKAGE_NAME])
   371         kx     else
   371         kx         ANDROID_PACKAGE_NAME="$with_android_package_name"
   371         kx         AC_MSG_RESULT([$ANDROID_PACKAGE_NAME])
   371         kx     fi
   371         kx     AC_SUBST(ANDROID_PACKAGE_NAME)
   371         kx fi
   371         kx 
   371         kx AC_MSG_CHECKING([whether to install the compat oo* wrappers])
   371         kx if test "$with_compat_oowrappers" = "yes"; then
   371         kx     WITH_COMPAT_OOWRAPPERS=TRUE
   371         kx     AC_MSG_RESULT(yes)
   371         kx else
   371         kx     WITH_COMPAT_OOWRAPPERS=
   371         kx     AC_MSG_RESULT(no)
   371         kx fi
   371         kx AC_SUBST(WITH_COMPAT_OOWRAPPERS)
   371         kx 
   371         kx INSTALLDIRNAME=`echo AC_PACKAGE_NAME | $AWK '{print tolower($0)}'`
   371         kx AC_MSG_CHECKING([for install dirname])
   371         kx if test -n "$with_install_dirname" -a "$with_install_dirname" != "no" -a "$with_install_dirname" != "yes"; then
   371         kx     INSTALLDIRNAME="$with_install_dirname"
   371         kx fi
   371         kx AC_MSG_RESULT([$INSTALLDIRNAME])
   371         kx AC_SUBST(INSTALLDIRNAME)
   371         kx 
   371         kx AC_MSG_CHECKING([for prefix])
   371         kx test "x$prefix" = xNONE && prefix=$ac_default_prefix
   371         kx test "x$exec_prefix" = xNONE && exec_prefix=$prefix
   371         kx PREFIXDIR="$prefix"
   371         kx AC_MSG_RESULT([$PREFIXDIR])
   371         kx AC_SUBST(PREFIXDIR)
   371         kx 
   371         kx LIBDIR=[$(eval echo $(eval echo $libdir))]
   371         kx AC_SUBST(LIBDIR)
   371         kx 
   371         kx DATADIR=[$(eval echo $(eval echo $datadir))]
   371         kx AC_SUBST(DATADIR)
   371         kx 
   371         kx MANDIR=[$(eval echo $(eval echo $mandir))]
   371         kx AC_SUBST(MANDIR)
   371         kx 
   371         kx DOCDIR=[$(eval echo $(eval echo $docdir))]
   371         kx AC_SUBST(DOCDIR)
   371         kx 
   371         kx BINDIR=[$(eval echo $(eval echo $bindir))]
   371         kx AC_SUBST(BINDIR)
   371         kx 
   371         kx INSTALLDIR="$LIBDIR/$INSTALLDIRNAME"
   371         kx AC_SUBST(INSTALLDIR)
   371         kx 
   371         kx TESTINSTALLDIR="${BUILDDIR}/test-install"
   371         kx AC_SUBST(TESTINSTALLDIR)
   371         kx 
   371         kx 
   371         kx # ===================================================================
   371         kx # OAuth2 id and secrets
   371         kx # ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([for Google Drive client id and secret])
   371         kx if test "$with_gdrive_client_id" = "no" -o -z "$with_gdrive_client_id"; then
   371         kx     AC_MSG_RESULT([not set])
   371         kx     GDRIVE_CLIENT_ID="\"\""
   371         kx     GDRIVE_CLIENT_SECRET="\"\""
   371         kx else
   371         kx     AC_MSG_RESULT([set])
   371         kx     GDRIVE_CLIENT_ID="\"$with_gdrive_client_id\""
   371         kx     GDRIVE_CLIENT_SECRET="\"$with_gdrive_client_secret\""
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED(GDRIVE_CLIENT_ID, $GDRIVE_CLIENT_ID)
   371         kx AC_DEFINE_UNQUOTED(GDRIVE_CLIENT_SECRET, $GDRIVE_CLIENT_SECRET)
   371         kx 
   371         kx AC_MSG_CHECKING([for Alfresco Cloud client id and secret])
   371         kx if test "$with_alfresco_cloud_client_id" = "no" -o -z "$with_alfresco_cloud_client_id"; then
   371         kx     AC_MSG_RESULT([not set])
   371         kx     ALFRESCO_CLOUD_CLIENT_ID="\"\""
   371         kx     ALFRESCO_CLOUD_CLIENT_SECRET="\"\""
   371         kx else
   371         kx     AC_MSG_RESULT([set])
   371         kx     ALFRESCO_CLOUD_CLIENT_ID="\"$with_alfresco_cloud_client_id\""
   371         kx     ALFRESCO_CLOUD_CLIENT_SECRET="\"$with_alfresco_cloud_client_secret\""
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED(ALFRESCO_CLOUD_CLIENT_ID, $ALFRESCO_CLOUD_CLIENT_ID)
   371         kx AC_DEFINE_UNQUOTED(ALFRESCO_CLOUD_CLIENT_SECRET, $ALFRESCO_CLOUD_CLIENT_SECRET)
   371         kx 
   371         kx AC_MSG_CHECKING([for OneDrive client id and secret])
   371         kx if test "$with_onedrive_client_id" = "no" -o -z "$with_onedrive_client_id"; then
   371         kx     AC_MSG_RESULT([not set])
   371         kx     ONEDRIVE_CLIENT_ID="\"\""
   371         kx     ONEDRIVE_CLIENT_SECRET="\"\""
   371         kx else
   371         kx     AC_MSG_RESULT([set])
   371         kx     ONEDRIVE_CLIENT_ID="\"$with_onedrive_client_id\""
   371         kx     ONEDRIVE_CLIENT_SECRET="\"$with_onedrive_client_secret\""
   371         kx fi
   371         kx AC_DEFINE_UNQUOTED(ONEDRIVE_CLIENT_ID, $ONEDRIVE_CLIENT_ID)
   371         kx AC_DEFINE_UNQUOTED(ONEDRIVE_CLIENT_SECRET, $ONEDRIVE_CLIENT_SECRET)
   371         kx 
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Hook up LibreOffice's nodep environmental variable to automake's equivalent
   371         kx dnl --enable-dependency-tracking configure option
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to enable dependency tracking])
   371         kx if test "$enable_dependency_tracking" = "no"; then
   371         kx     nodep=TRUE
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx fi
   371         kx AC_SUBST(nodep)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Number of CPUs to use during the build
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([for number of processors to use])
   371         kx # plain --with-parallelism is just the default
   371         kx if test -n "$with_parallelism" -a "$with_parallelism" != "yes"; then
   371         kx     if test "$with_parallelism" = "no"; then
   371         kx         PARALLELISM=0
   371         kx     else
   371         kx         PARALLELISM=$with_parallelism
   371         kx     fi
   371         kx else
   371         kx     if test "$enable_icecream" = "yes"; then
   371         kx         PARALLELISM="40"
   371         kx     else
   371         kx         case `uname -s` in
   371         kx 
   371         kx         Darwin|FreeBSD|NetBSD|OpenBSD)
   371         kx             PARALLELISM=`sysctl -n hw.ncpu`
   371         kx             ;;
   371         kx 
   371         kx         Linux)
   371         kx             PARALLELISM=`getconf _NPROCESSORS_ONLN`
   371         kx         ;;
   371         kx         # what else than above does profit here *and* has /proc?
   371         kx         *)
   371         kx             PARALLELISM=`grep $'^processor\t*:' /proc/cpuinfo | wc -l`
   371         kx             ;;
   371         kx         esac
   371         kx 
   371         kx         # If we hit the catch-all case, but /proc/cpuinfo doesn't exist or has an
   371         kx         # unexpected format, 'wc -l' will have returned 0 (and we won't use -j at all).
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx if test $PARALLELISM -eq 0; then
   371         kx     AC_MSG_RESULT([explicit make -j option needed])
   371         kx else
   371         kx     AC_MSG_RESULT([$PARALLELISM])
   371         kx fi
   371         kx AC_SUBST(PARALLELISM)
   371         kx 
   371         kx #
   371         kx # Set up ILIB for MSVC build
   371         kx #
   371         kx ILIB1=
   371         kx if test "$build_os" = "cygwin" -o "$build_os" = "wsl"; then
   371         kx     ILIB="."
   371         kx     if test -n "$JAVA_HOME"; then
   371         kx         ILIB="$ILIB;$JAVA_HOME/lib"
   371         kx     fi
   371         kx     ILIB1=-link
   371         kx     PathFormat "${COMPATH}/lib/$WIN_HOST_ARCH"
   371         kx     ILIB="$ILIB;$formatted_path"
   371         kx     ILIB1="$ILIB1 -LIBPATH:$formatted_path"
   371         kx     ILIB="$ILIB;$WINDOWS_SDK_HOME/lib/$WIN_HOST_ARCH"
   371         kx     ILIB1="$ILIB1 -LIBPATH:$WINDOWS_SDK_HOME/lib/$WIN_HOST_ARCH"
   371         kx     if test $WINDOWS_SDK_VERSION = 80 -o $WINDOWS_SDK_VERSION = 81 -o $WINDOWS_SDK_VERSION = 10; then
   371         kx         ILIB="$ILIB;$WINDOWS_SDK_HOME/lib/$winsdklibsubdir/um/$WIN_HOST_ARCH"
   371         kx         ILIB1="$ILIB1 -LIBPATH:$WINDOWS_SDK_HOME/lib/$winsdklibsubdir/um/$WIN_HOST_ARCH"
   371         kx     fi
   371         kx     PathFormat "${UCRTSDKDIR}lib/$UCRTVERSION/ucrt/$WIN_HOST_ARCH"
   371         kx     ucrtlibpath_formatted=$formatted_path
   371         kx     ILIB="$ILIB;$ucrtlibpath_formatted"
   371         kx     ILIB1="$ILIB1 -LIBPATH:$ucrtlibpath_formatted"
   371         kx     if test -f "$DOTNET_FRAMEWORK_HOME/lib/mscoree.lib"; then
   371         kx         PathFormat "$DOTNET_FRAMEWORK_HOME/lib"
   371         kx         ILIB="$ILIB;$formatted_path"
   371         kx     else
   371         kx         PathFormat "$DOTNET_FRAMEWORK_HOME/Lib/um/$WIN_HOST_ARCH"
   371         kx         ILIB="$ILIB;$formatted_path"
   371         kx     fi
   371         kx 
   371         kx     if test "$cross_compiling" != "yes"; then
   371         kx         ILIB_FOR_BUILD="$ILIB"
   371         kx     fi
   371         kx fi
   371         kx AC_SUBST(ILIB)
   371         kx AC_SUBST(ILIB_FOR_BUILD)
   371         kx 
   371         kx AC_MSG_CHECKING([whether $CXX_BASE supports a working C++20 consteval])
   371         kx dnl ...that does not suffer from <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96994> "Missing code
   371         kx dnl from consteval constructor initializing const variable",
   371         kx dnl <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=98752> "wrong 'error: ‘this’ is not a constant
   371         kx dnl expression' with consteval constructor", <https://bugs.llvm.org/show_bug.cgi?id=50063> "code
   371         kx dnl using consteval: 'clang/lib/CodeGen/Address.h:38: llvm::Value*
   371         kx dnl clang::CodeGen::Address::getPointer() const: Assertion `isValid()' failed.'" (which should be
   371         kx dnl fixed since Clang 14), <https://developercommunity.visualstudio.com/t/1581879> "Bogus error
   371         kx dnl C7595 with consteval constructor in ternary expression (/std:c++latest)", or
   371         kx dnl <https://github.com/llvm/llvm-project/issues/54612> "C++20, consteval, anonymous union:
   371         kx dnl llvm/lib/IR/Instructions.cpp:1491: void llvm::StoreInst::AssertOK(): Assertion
   371         kx dnl `cast<PointerType>(getOperand(1)->getType())->isOpaqueOrPointeeTypeMatches(getOperand(0)->getType())
   371         kx dnl && "Ptr must be a pointer to Val type!"' failed." (which should be fixed since Clang 17):
   371         kx AC_LANG_PUSH([C++])
   371         kx save_CXX=$CXX
   371         kx if test "$COM" = MSC && test "$COM_IS_CLANG" != TRUE; then
   371         kx     CXX="env LIB=$ILIB $CXX"
   371         kx fi
   371         kx save_CXXFLAGS=$CXXFLAGS
   371         kx CXXFLAGS="$CXXFLAGS $CXXFLAGS_CXX11"
   371         kx AC_RUN_IFELSE([AC_LANG_PROGRAM([
   371         kx         struct S {
   371         kx             consteval S() { i = 1; }
   371         kx             int i = 0;
   371         kx         };
   371         kx         S const s;
   371         kx 
   371         kx         struct S1 {
   371         kx              int a;
   371         kx              consteval S1(int n): a(n) {}
   371         kx         };
   371         kx         struct S2 {
   371         kx             S1 x;
   371         kx             S2(): x(0) {}
   371         kx         };
   371         kx 
   371         kx         struct S3 {
   371         kx             consteval S3() {}
   371         kx             union {
   371         kx                 int a;
   371         kx                 unsigned b = 0;
   371         kx             };
   371         kx         };
   371         kx         void f() { S3(); }
   371         kx 
   371         kx         struct S4 { consteval S4() = default; };
   371         kx         void f4(bool b) { b ? S4() : S4(); }
   371         kx 
   371         kx         struct S5 {
   371         kx             consteval S5() { c = 0; }
   371         kx             char * f() { return &c; }
   371         kx             union {
   371         kx                 char c;
   371         kx                 int i;
   371         kx             };
   371         kx         };
   371         kx         auto s5 = S5().f();
   371         kx     ], [
   371         kx         return (s.i == 1) ? 0 : 1;
   371         kx     ])], [
   371         kx         AC_DEFINE([HAVE_CPP_CONSTEVAL],[1])
   371         kx         AC_MSG_RESULT([yes])
   371         kx     ], [AC_MSG_RESULT([no])], [AC_MSG_RESULT([assumed no (cross compiling)])])
   371         kx CXX=$save_CXX
   371         kx CXXFLAGS=$save_CXXFLAGS
   371         kx AC_LANG_POP([C++])
   371         kx 
   371         kx # ===================================================================
   371         kx # Creating bigger shared library to link against
   371         kx # ===================================================================
   371         kx AC_MSG_CHECKING([whether to create huge library])
   371         kx MERGELIBS=
   371         kx 
   371         kx if test $_os = iOS -o $_os = Android; then
   371         kx     # Never any point in mergelibs for these as we build just static
   371         kx     # libraries anyway...
   371         kx     enable_mergelibs=no
   371         kx fi
   371         kx 
   371         kx if test -n "$enable_mergelibs" -a "$enable_mergelibs" != "no"; then
   371         kx     if test $_os != Linux -a $_os != WINNT; then
   371         kx         add_warning "--enable-mergelibs is not tested for this platform"
   371         kx     fi
   371         kx     MERGELIBS="TRUE"
   371         kx     AC_MSG_RESULT([yes])
   371         kx     AC_DEFINE(ENABLE_MERGELIBS)
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST([MERGELIBS])
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl icerun is a wrapper that stops us spawning tens of processes
   371         kx dnl locally - for tools that can't be executed on the compile cluster
   371         kx dnl this avoids a dozen javac's ganging up on your laptop to kill it.
   371         kx dnl ===================================================================
   371         kx AC_MSG_CHECKING([whether to use icerun wrapper])
   371         kx ICECREAM_RUN=
   371         kx if test "$enable_icecream" = "yes" && which icerun >/dev/null 2>&1 ; then
   371         kx     ICECREAM_RUN=icerun
   371         kx     AC_MSG_RESULT([yes])
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx AC_SUBST(ICECREAM_RUN)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Setup the ICECC_VERSION for the build the same way it was set for
   371         kx dnl configure, so that CC/CXX and ICECC_VERSION are in sync
   371         kx dnl ===================================================================
   371         kx x_ICECC_VERSION=[\#]
   371         kx if test -n "$ICECC_VERSION" ; then
   371         kx     x_ICECC_VERSION=
   371         kx fi
   371         kx AC_SUBST(x_ICECC_VERSION)
   371         kx AC_SUBST(ICECC_VERSION)
   371         kx 
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([MPL subset])
   371         kx MPL_SUBSET=
   371         kx LICENSE="LGPL"
   371         kx 
   371         kx if test "$enable_mpl_subset" = "yes"; then
   371         kx     mpl_error_string=
   371         kx     newline=$'\n    *'
   371         kx     warn_report=false
   371         kx     if test "$enable_report_builder" != "no" -a "$with_java" != "no"; then
   371         kx         warn_report=true
   371         kx     elif test "$ENABLE_REPORTBUILDER" = "TRUE"; then
   371         kx         warn_report=true
   371         kx     fi
   371         kx     if test "$warn_report" = "true"; then
   371         kx         mpl_error_string="$mpl_error_string$newline Need to --disable-report-builder - extended database report builder."
   371         kx     fi
   371         kx     if test "x$enable_postgresql_sdbc" != "xno"; then
   371         kx         mpl_error_string="$mpl_error_string$newline Need to --disable-postgresql-sdbc - the PostgreSQL database backend."
   371         kx     fi
   371         kx     if test "$enable_lotuswordpro" = "yes"; then
   371         kx         mpl_error_string="$mpl_error_string$newline Need to --disable-lotuswordpro - a Lotus Word Pro file format import filter."
   371         kx     fi
   371         kx     if test -n "$ENABLE_POPPLER"; then
   371         kx         if test "x$SYSTEM_POPPLER" = "x"; then
   371         kx             mpl_error_string="$mpl_error_string$newline Need to disable PDF import via poppler (--disable-poppler) or use system library."
   371         kx         fi
   371         kx     fi
   371         kx     # cf. m4/libo_check_extension.m4
   371         kx     if test "x$WITH_EXTRA_EXTENSIONS" != "x"; then
   371         kx         mpl_error_string="$mpl_error_string$newline Need to disable extra extensions enabled using --enable-ext-XXXX."
   371         kx     fi
   371         kx     denied_themes=
   371         kx     filtered_themes=
   371         kx     for theme in $WITH_THEMES; do
   371         kx         case $theme in
   371         kx         breeze|breeze_dark|breeze_dark_svg|breeze_svg|elementary|elementary_svg|karasa_jaga|karasa_jaga_svg) #denylist of icon themes under GPL or LGPL
   371         kx             denied_themes="${denied_themes:+$denied_themes }$theme" ;;
   371         kx         *)
   371         kx             filtered_themes="${filtered_themes:+$filtered_themes }$theme" ;;
   371         kx         esac
   371         kx     done
   371         kx     if test "x$denied_themes" != "x"; then
   371         kx         if test "x$filtered_themes" == "x"; then
   371         kx             filtered_themes="colibre"
   371         kx         fi
   371         kx         mpl_error_string="$mpl_error_string$newline Need to disable icon themes: $denied_themes, use --with-theme=$filtered_themes."
   371         kx     fi
   371         kx 
   371         kx     ENABLE_OPENGL_TRANSITIONS=
   371         kx 
   371         kx     if test "$enable_lpsolve" != "no" -o "x$ENABLE_LPSOLVE" = "xTRUE"; then
   371         kx         mpl_error_string="$mpl_error_string$newline Need to --disable-lpsolve - calc linear programming solver."
   371         kx     fi
   371         kx 
   371         kx     if test "x$mpl_error_string" != "x"; then
   371         kx         AC_MSG_ERROR([$mpl_error_string])
   371         kx     fi
   371         kx 
   371         kx     MPL_SUBSET="TRUE"
   371         kx     LICENSE="MPL-2.0"
   371         kx     AC_DEFINE(MPL_HAVE_SUBSET)
   371         kx     AC_MSG_RESULT([only])
   371         kx else
   371         kx     AC_MSG_RESULT([no restrictions])
   371         kx fi
   371         kx AC_SUBST(MPL_SUBSET)
   371         kx AC_SUBST(LICENSE)
   371         kx 
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([formula logger])
   371         kx ENABLE_FORMULA_LOGGER=
   371         kx 
   371         kx if test "x$enable_formula_logger" = "xyes"; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     AC_DEFINE(ENABLE_FORMULA_LOGGER)
   371         kx     ENABLE_FORMULA_LOGGER=TRUE
   371         kx elif test -n "$ENABLE_DBGUTIL" ; then
   371         kx     AC_MSG_RESULT([yes])
   371         kx     AC_DEFINE(ENABLE_FORMULA_LOGGER)
   371         kx     ENABLE_FORMULA_LOGGER=TRUE
   371         kx else
   371         kx     AC_MSG_RESULT([no])
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ENABLE_FORMULA_LOGGER)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Checking for active Antivirus software.
   371         kx dnl ===================================================================
   371         kx 
   371         kx if test $_os = WINNT -a -f "$SRC_ROOT/antivirusDetection.vbs" ; then
   371         kx     AC_MSG_CHECKING([for active Antivirus software])
   371         kx     PathFormat "$SRC_ROOT/antivirusDetection.vbs"
   371         kx     ANTIVIRUS_LIST=`cscript.exe //Nologo ${formatted_path}`
   371         kx     if [ [ "$ANTIVIRUS_LIST" != "NULL" ] ]; then
   371         kx         if [ [ "$ANTIVIRUS_LIST" != "NOT_FOUND" ] ]; then
   371         kx             AC_MSG_RESULT([found])
   371         kx             EICAR_STRING='X5O!P%@AP@<:@4\PZX54(P^)7CC)7}$EICAR-STANDARD-ANTIVIRUS-TEST-FILE!$H+H*'
   371         kx             echo $EICAR_STRING > $SRC_ROOT/eicar
   371         kx             EICAR_TEMP_FILE_CONTENTS=`cat $SRC_ROOT/eicar`
   371         kx             rm $SRC_ROOT/eicar
   371         kx             if [ [ "$EICAR_STRING" != "$EICAR_TEMP_FILE_CONTENTS" ] ]; then
   371         kx                 AC_MSG_ERROR([Exclude the build and source directories associated with LibreOffice in the following Antivirus software: $ANTIVIRUS_LIST])
   371         kx             fi
   371         kx             echo $EICAR_STRING > $BUILDDIR/eicar
   371         kx             EICAR_TEMP_FILE_CONTENTS=`cat $BUILDDIR/eicar`
   371         kx             rm $BUILDDIR/eicar
   371         kx             if [ [ "$EICAR_STRING" != "$EICAR_TEMP_FILE_CONTENTS" ] ]; then
   371         kx                 AC_MSG_ERROR([Exclude the build and source directories associated with LibreOffice in the following Antivirus software: $ANTIVIRUS_LIST])
   371         kx             fi
   371         kx             add_warning "To speed up builds and avoid failures in unit tests, it is highly recommended that you exclude the build and source directories associated with LibreOffice in the following Antivirus software: $ANTIVIRUS_LIST"
   371         kx         else
   371         kx             AC_MSG_RESULT([not found])
   371         kx         fi
   371         kx     else
   371         kx         AC_MSG_RESULT([n/a])
   371         kx     fi
   371         kx fi
   371         kx 
   371         kx dnl ===================================================================
   371         kx 
   371         kx AC_MSG_CHECKING([for coredumpctl support])
   371         kx if test -z "$with_coredumpctl" && test $_os != Linux; then
   371         kx     with_coredumpctl=no
   371         kx fi
   371         kx if test "$with_coredumpctl" = no; then
   371         kx     WITH_COREDUMPCTL=
   371         kx else
   371         kx     AC_PATH_PROG(COREDUMPCTL, coredumpctl)
   371         kx     AC_PATH_PROG(JQ, jq)
   371         kx     AC_PATH_PROG(SYSTEMD_ESCAPE, systemd-escape)
   371         kx     AC_PATH_PROG(SYSTEMD_RUN, systemd-run)
   371         kx     if test -z "$COREDUMPCTL" || test -z "$JQ" || test -z "$SYSTEMD_ESCAPE" \
   371         kx         || test -z "$SYSTEMD_RUN"
   371         kx     then
   371         kx         if test -z "$with_coredumpctl"; then
   371         kx             WITH_COREDUMPCTL=
   371         kx         else
   371         kx             if test -z "$COREDUMPCTL"; then
   371         kx                 AC_MSG_ERROR([coredumpctl not found])
   371         kx             fi
   371         kx             if test -z "$JQ"; then
   371         kx                 AC_MSG_ERROR([jq not found])
   371         kx             fi
   371         kx             if test -z "$SYSTEMD_ESCAPE"; then
   371         kx                 AC_MSG_ERROR([systemd-escape not found])
   371         kx             fi
   371         kx             if test -z "$SYSTEMD_RUN"; then
   371         kx                 AC_MSG_ERROR([systemd-run not found])
   371         kx             fi
   371         kx         fi
   371         kx     else
   371         kx         WITH_COREDUMPCTL=TRUE
   371         kx     fi
   371         kx fi
   371         kx if test -z "$WITH_COREDUMPCTL"; then
   371         kx     AC_MSG_RESULT([no])
   371         kx else
   371         kx     AC_MSG_RESULT([yes])
   371         kx fi
   371         kx AC_SUBST(COREDUMPCTL)
   371         kx AC_SUBST(JQ)
   371         kx AC_SUBST(SYSTEMD_ESCAPE)
   371         kx AC_SUBST(SYSTEMD_RUN)
   371         kx AC_SUBST(WITH_COREDUMPCTL)
   371         kx 
   371         kx dnl ===================================================================
   371         kx dnl Setting up the environment.
   371         kx dnl ===================================================================
   371         kx AC_MSG_NOTICE([setting up the build environment variables...])
   371         kx 
   371         kx AC_SUBST(COMPATH)
   371         kx 
   371         kx if test "$build_os" = "cygwin" -o "$build_os" = wsl; then
   371         kx     if test -d "$COMPATH/atlmfc/lib/spectre"; then
   371         kx         ATL_LIB="$COMPATH/atlmfc/lib/spectre"
   371         kx         ATL_INCLUDE="$COMPATH/atlmfc/include"
   371         kx     elif test -d "$COMPATH/atlmfc/lib"; then
   371         kx         ATL_LIB="$COMPATH/atlmfc/lib"
   371         kx         ATL_INCLUDE="$COMPATH/atlmfc/include"
   371         kx     else
   371         kx         ATL_LIB="$WINDOWS_SDK_HOME/lib" # Doesn't exist for VSE
   371         kx         ATL_INCLUDE="$WINDOWS_SDK_HOME/include/atl"
   371         kx     fi
   371         kx     ATL_LIB="$ATL_LIB/$WIN_HOST_ARCH"
   371         kx     ATL_LIB=`win_short_path_for_make "$ATL_LIB"`
   371         kx     ATL_INCLUDE=`win_short_path_for_make "$ATL_INCLUDE"`
   371         kx fi
   371         kx 
   371         kx if test "$build_os" = "cygwin"; then
   371         kx     # sort.exe and find.exe also exist in C:/Windows/system32 so need /usr/bin/
   371         kx     PathFormat "/usr/bin/find.exe"
   371         kx     FIND="$formatted_path"
   371         kx     PathFormat "/usr/bin/sort.exe"
   371         kx     SORT="$formatted_path"
   371         kx     PathFormat "/usr/bin/grep.exe"
   371         kx     WIN_GREP="$formatted_path"
   371         kx     PathFormat "/usr/bin/ls.exe"
   371         kx     WIN_LS="$formatted_path"
   371         kx     PathFormat "/usr/bin/touch.exe"
   371         kx     WIN_TOUCH="$formatted_path"
   371         kx else
   371         kx     FIND=find
   371         kx     SORT=sort
   371         kx fi
   371         kx 
   371         kx AC_SUBST(ATL_INCLUDE)
   371         kx AC_SUBST(ATL_LIB)
   371         kx AC_SUBST(FIND)
   371         kx AC_SUBST(SORT)
   371         kx AC_SUBST(WIN_GREP)
   371         kx AC_SUBST(WIN_LS)
   371         kx AC_SUBST(WIN_TOUCH)
   371         kx 
   371         kx AC_SUBST(BUILD_TYPE)
   371         kx 
   371         kx AC_SUBST(SOLARINC)
   371         kx 
   371         kx PathFormat "$PERL"
   371         kx PERL="$formatted_path"
   371         kx AC_SUBST(PERL)
   371         kx 
   371         kx if test -n "$TMPDIR"; then
   371         kx     TEMP_DIRECTORY="$TMPDIR"
   371         kx else
   371         kx     TEMP_DIRECTORY="/tmp"
   371         kx fi
   371         kx CYGWIN_BASH="C:/cygwin64/bin/bash.exe"
   371         kx if test "$build_os" = "cygwin"; then
   371         kx     TEMP_DIRECTORY=`cygpath -m "$TEMP_DIRECTORY"`
   371         kx     CYGWIN_BASH=`cygpath -m /usr/bin/bash`
   371         kx fi
   371         kx AC_SUBST(TEMP_DIRECTORY)
   371         kx AC_SUBST(CYGWIN_BASH)
   371         kx 
   371         kx # setup the PATH for the environment
   371         kx if test -n "$LO_PATH_FOR_BUILD"; then
   371         kx     LO_PATH="$LO_PATH_FOR_BUILD"
   371         kx     case "$host_os" in
   371         kx     cygwin*|wsl*)
   371         kx         pathmunge "$MSVC_HOST_PATH" "before"
   371         kx         ;;
   371         kx     esac
   371         kx else
   371         kx     LO_PATH="$PATH"
   371         kx 
   371         kx     case "$host_os" in
   371         kx 
   371         kx     dragonfly*|freebsd*|linux-gnu*|*netbsd*|openbsd*)
   371         kx         if test "$ENABLE_JAVA" != ""; then
   371         kx             pathmunge "$JAVA_HOME/bin" "after"
   371         kx         fi
   371         kx         ;;
   371         kx 
   371         kx     cygwin*|wsl*)
   371         kx         # Win32 make needs native paths
   371         kx         if test "$GNUMAKE_WIN_NATIVE" = "TRUE" ; then
   371         kx             LO_PATH=`cygpath -p -m "$PATH"`
   371         kx         fi
   371         kx         if test "$WIN_BUILD_ARCH" = "x64"; then
   371         kx             # needed for msi packaging
   371         kx             pathmunge "$WINDOWS_SDK_BINDIR_NO_ARCH/x86" "before"
   371         kx         fi
   371         kx         if test "$WIN_BUILD_ARCH" = "arm64"; then
   371         kx             # needed for msi packaging - as of 10.0.22621 SDK no arm64 ones yet
   371         kx             # the x86 ones probably would work just as well...
   371         kx             pathmunge "$WINDOWS_SDK_BINDIR_NO_ARCH/arm" "before"
   371         kx         fi
   371         kx         # .NET 4.6 and higher don't have bin directory
   371         kx         if test -f "$DOTNET_FRAMEWORK_HOME/bin"; then
   371         kx             pathmunge "$DOTNET_FRAMEWORK_HOME/bin" "before"
   371         kx         fi
   371         kx         pathmunge "$WINDOWS_SDK_HOME/bin" "before"
   371         kx         pathmunge "$CSC_PATH" "before"
   371         kx         pathmunge "$MIDL_PATH" "before"
   371         kx         pathmunge "$AL_PATH" "before"
   371         kx         pathmunge "$MSVC_MULTI_PATH" "before"
   371         kx         pathmunge "$MSVC_BUILD_PATH" "before"
   371         kx         if test -n "$MSBUILD_PATH" ; then
   371         kx             pathmunge "$MSBUILD_PATH" "before"
   371         kx         fi
   371         kx         pathmunge "$WINDOWS_SDK_BINDIR_NO_ARCH/$WIN_BUILD_ARCH" "before"
   371         kx         if test "$ENABLE_JAVA" != ""; then
   371         kx             if test -d "$JAVA_HOME/jre/bin/client"; then
   371         kx                 pathmunge "$JAVA_HOME/jre/bin/client" "before"
   371         kx             fi
   371         kx             if test -d "$JAVA_HOME/jre/bin/hotspot"; then
   371         kx                 pathmunge "$JAVA_HOME/jre/bin/hotspot" "before"
   371         kx             fi
   371         kx             pathmunge "$JAVA_HOME/bin" "before"
   371         kx         fi
   371         kx         pathmunge "$MSVC_HOST_PATH" "before"
   371         kx         ;;
   371         kx 
   371         kx     solaris*)
   371         kx         pathmunge "/usr/css/bin" "before"
   371         kx         if test "$ENABLE_JAVA" != ""; then
   371         kx             pathmunge "$JAVA_HOME/bin" "after"
   371         kx         fi
   371         kx         ;;
   371         kx     esac
   371         kx fi
   371         kx 
   371         kx AC_SUBST(LO_PATH)
   371         kx 
   371         kx # Allow to pass LO_ELFCHECK_ALLOWLIST from autogen.input to bin/check-elf-dynamic-objects:
   371         kx if test "$LO_ELFCHECK_ALLOWLIST" = x || test "${LO_ELFCHECK_ALLOWLIST-x}" != x; then
   371         kx     x_LO_ELFCHECK_ALLOWLIST=
   371         kx else
   371         kx     x_LO_ELFCHECK_ALLOWLIST=[\#]
   371         kx fi
   371         kx AC_SUBST(x_LO_ELFCHECK_ALLOWLIST)
   371         kx AC_SUBST(LO_ELFCHECK_ALLOWLIST)
   371         kx 
   371         kx libo_FUZZ_SUMMARY
   371         kx 
   371         kx # Generate a configuration sha256 we can use for deps
   371         kx if test -f config_host.mk; then
   371         kx     config_sha256=`$SHA256SUM config_host.mk | sed "s/ .*//"`
   371         kx fi
   371         kx if test -f config_host_lang.mk; then
   371         kx     config_lang_sha256=`$SHA256SUM config_host_lang.mk | sed "s/ .*//"`
   371         kx fi
   371         kx 
   371         kx CFLAGS=$my_original_CFLAGS
   371         kx CXXFLAGS=$my_original_CXXFLAGS
   371         kx CPPFLAGS=$my_original_CPPFLAGS
   371         kx 
   371         kx AC_CONFIG_LINKS([include:include])
   371         kx 
   371         kx # Keep in sync with list of files far up, at AC_MSG_CHECKING([for
   371         kx # BUILD platform configuration] - otherwise breaks cross building
   371         kx AC_CONFIG_FILES([config_host.mk
   371         kx                  config_host_lang.mk
   371         kx                  Makefile
   371         kx                  bin/bffvalidator.sh
   371         kx                  bin/odfvalidator.sh
   371         kx                  bin/officeotron.sh
   371         kx                  instsetoo_native/util/openoffice.lst
   371         kx                  sysui/desktop/macosx/Info.plist
   371         kx                  hardened_runtime.xcent:sysui/desktop/macosx/hardened_runtime.xcent.in
   371         kx                  lo.xcent:sysui/desktop/macosx/lo.xcent.in
   371         kx                  vs-code.code-workspace.template:.vscode/vs-code-template.code-workspace.in])
   371         kx 
   371         kx AC_CONFIG_HEADERS([config_host/config_atspi.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_buildconfig.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_buildid.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_box2d.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_clang.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_crypto.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_dconf.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_eot.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_extensions.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_cairo_canvas.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_cairo_rgba.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_cxxabi.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_dbus.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_features.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_feature_desktop.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_feature_opencl.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_firebird.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_folders.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_fonts.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_fuzzers.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_gio.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_global.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_gpgme.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_java.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_langs.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_lgpl.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_libcxx.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_liblangtag.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_locales.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_mpl.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_oox.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_options.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_options_calc.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_zxing.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_skia.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_typesizes.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_validation.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_vendor.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_vclplug.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_version.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_oauth2.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_poppler.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_python.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_writerperfect.h])
   371         kx AC_CONFIG_HEADERS([config_host/config_wasm_strip.h])
   371         kx AC_CONFIG_HEADERS([solenv/lockfile/autoconf.h])
   371         kx AC_OUTPUT
   371         kx 
   371         kx if test "$CROSS_COMPILING" = TRUE; then
   371         kx     (echo; echo export BUILD_TYPE_FOR_HOST=$BUILD_TYPE) >>config_build.mk
   371         kx fi
   371         kx 
   371         kx # touch the config timestamp file
   371         kx if test ! -f config_host.mk.stamp; then
   371         kx     echo > config_host.mk.stamp
   371         kx elif test "$config_sha256" = `$SHA256SUM config_host.mk | sed "s/ .*//"`; then
   371         kx     echo "Host Configuration unchanged - avoiding scp2 stamp update"
   371         kx else
   371         kx     echo > config_host.mk.stamp
   371         kx fi
   371         kx 
   371         kx # touch the config lang timestamp file
   371         kx if test ! -f config_host_lang.mk.stamp; then
   371         kx     echo > config_host_lang.mk.stamp
   371         kx elif test "$config_lang_sha256" = `$SHA256SUM config_host_lang.mk | sed "s/ .*//"`; then
   371         kx     echo "Language Configuration unchanged - avoiding scp2 stamp update"
   371         kx else
   371         kx     echo > config_host_lang.mk.stamp
   371         kx fi
   371         kx 
   371         kx 
   371         kx if test \( "$STALE_MAKE" = "TRUE" \) \
   371         kx         -a "$build_os" = "cygwin"; then
   371         kx 
   371         kx cat << _EOS
   371         kx ****************************************************************************
   371         kx WARNING:
   371         kx Your make version is known to be horribly slow, and hard to debug
   371         kx problems with. To get a reasonably functional make please do:
   371         kx 
   371         kx to install a pre-compiled binary make for Win32
   371         kx 
   371         kx  mkdir -p /opt/lo/bin
   371         kx  cd /opt/lo/bin
   371         kx  wget https://dev-www.libreoffice.org/bin/cygwin/make-4.2.1-msvc.exe
   371         kx  cp make-4.2.1-msvc.exe make
   371         kx  chmod +x make
   371         kx 
   371         kx to install from source:
   371         kx place yourself in a working directory of you choice.
   371         kx 
   371         kx  git clone git://git.savannah.gnu.org/make.git
   371         kx 
   371         kx  [go to Start menu, open "Visual Studio 2019" or "Visual Studio 2022", and then click "x86 Native Tools Command Prompt" or "x64 Native Tools Command Prompt"]
   371         kx  set PATH=%PATH%;C:\Cygwin\bin
   371         kx  [or Cygwin64, if that is what you have]
   371         kx  cd path-to-make-repo-you-cloned-above
   371         kx  build_w32.bat --without-guile
   371         kx 
   371         kx should result in a WinRel/gnumake.exe.
   371         kx Copy it to the Cygwin /opt/lo/bin directory as make.exe
   371         kx 
   371         kx Then re-run autogen.sh
   371         kx 
   371         kx Note: autogen.sh will try to use /opt/lo/bin/make if the environment variable GNUMAKE is not already defined.
   371         kx Alternatively, you can install the 'new' make where ever you want and make sure that `which make` finds it.
   371         kx 
   371         kx _EOS
   371         kx fi
   371         kx 
   371         kx 
   371         kx cat << _EOF
   371         kx ****************************************************************************
   371         kx 
   371         kx To show information on various make targets and make flags, run:
   371         kx $GNUMAKE help
   371         kx 
   371         kx To just build, run:
   371         kx $GNUMAKE
   371         kx 
   371         kx _EOF
   371         kx 
   371         kx if test $_os != WINNT -a "$CROSS_COMPILING" != TRUE; then
   371         kx     cat << _EOF
   371         kx After the build has finished successfully, you can immediately run what you built using the command:
   371         kx _EOF
   371         kx 
   371         kx     if test $_os = Darwin; then
   371         kx         echo open instdir/$PRODUCTNAME_WITHOUT_SPACES.app
   371         kx     else
   371         kx         echo instdir/program/soffice
   371         kx     fi
   371         kx     cat << _EOF
   371         kx 
   371         kx If you want to run the unit tests, run:
   371         kx $GNUMAKE check
   371         kx 
   371         kx _EOF
   371         kx fi
   371         kx 
   371         kx if test -s "$WARNINGS_FILE_FOR_BUILD"; then
   371         kx     echo "BUILD / cross-toolset config, repeated ($WARNINGS_FILE_FOR_BUILD)"
   371         kx     cat "$WARNINGS_FILE_FOR_BUILD"
   371         kx     echo
   371         kx fi
   371         kx 
   371         kx if test -s "$WARNINGS_FILE"; then
   371         kx     echo "HOST config ($WARNINGS_FILE)"
   371         kx     cat "$WARNINGS_FILE"
   371         kx fi
   371         kx 
   371         kx # Remove unneeded emconfigure artifacts
   371         kx rm -f a.out a.wasm a.out.js a.out.wasm
   371         kx 
   371         kx dnl vim:set shiftwidth=4 softtabstop=4 expandtab: