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: