CMake: Turn off pkg_config_enabled if pkg_config is not found

The qt_build_internals_disable_pkg_config_if_needed function didn't
actually check if the pkg-config executable is available when turning
the pkg-config feature on.

This broke certain configurations like Android (on some hosts).

Try to find the executable and take that into account when computing
the value of the feature.

Task-number: QTBUG-85399
Change-Id: Ie79c637f2d2b689c392862c90075d309906fe506
Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
This commit is contained in:
Alessandro Portale 2020-08-26 18:48:01 +02:00 committed by Alexandru Croitor
parent 7b6d8261d8
commit 72388f77a7

View File

@ -52,11 +52,14 @@ endif()
include(QtPlatformSupport) include(QtPlatformSupport)
function(qt_build_internals_disable_pkg_config_if_needed) function(qt_build_internals_disable_pkg_config_if_needed)
# pkg-config should not be used by default on Darwin and Windows platforms, as defined in # pkg-config should not be used by default on Darwin and Windows platforms (and QNX), as defined
# the qtbase/configure.json. Unfortunately by the time the feature is evaluated there are # in the qtbase/configure.json. Unfortunately by the time the feature is evaluated there are
# already a few find_package() calls. # already a few find_package() calls that try to use the FindPkgConfig module.
# So we have to duplicate the condition logic here and disable pkg-config for those platforms by # Thus, we have to duplicate the condition logic here and disable pkg-config for those platforms
# default. # by default.
# We also need to check if the pkg-config executable exists, to mirror the condition test in
# configure.json. We do that by trying to find the executable ourselves, and not delegating to
# the FindPkgConfig module because that has more unwanted side-effects.
# #
# Note that on macOS, if the pkg-config feature is enabled by the user explicitly, we will also # Note that on macOS, if the pkg-config feature is enabled by the user explicitly, we will also
# tell CMake to consider paths like /usr/local (Homebrew) as system paths when looking for # tell CMake to consider paths like /usr/local (Homebrew) as system paths when looking for
@ -65,10 +68,16 @@ function(qt_build_internals_disable_pkg_config_if_needed)
# enabled won't enable finding all system libraries via pkg-config alone, many libraries can # enabled won't enable finding all system libraries via pkg-config alone, many libraries can
# only be found via FooConfig.cmake files which means /usr/local should be in the system prefix # only be found via FooConfig.cmake files which means /usr/local should be in the system prefix
# path. # path.
set(pkg_config_enabled ON) set(pkg_config_enabled ON)
if(APPLE OR WIN32 OR QNX) qt_build_internals_find_pkg_config_executable()
if(APPLE OR WIN32 OR QNX OR (NOT PKG_CONFIG_EXECUTABLE))
set(pkg_config_enabled OFF) set(pkg_config_enabled OFF)
endif() endif()
# If user explicitly specified a value for the feature, honor it, even if it might break
# the build.
if(DEFINED FEATURE_pkg_config) if(DEFINED FEATURE_pkg_config)
if(FEATURE_pkg_config) if(FEATURE_pkg_config)
set(pkg_config_enabled ON) set(pkg_config_enabled ON)
@ -76,6 +85,7 @@ function(qt_build_internals_disable_pkg_config_if_needed)
set(pkg_config_enabled OFF) set(pkg_config_enabled OFF)
endif() endif()
endif() endif()
set(FEATURE_pkg_config "${pkg_config_enabled}" CACHE STRING "Using pkg-config") set(FEATURE_pkg_config "${pkg_config_enabled}" CACHE STRING "Using pkg-config")
if(NOT pkg_config_enabled) if(NOT pkg_config_enabled)
qt_build_internals_disable_pkg_config() qt_build_internals_disable_pkg_config()
@ -84,9 +94,20 @@ function(qt_build_internals_disable_pkg_config_if_needed)
endif() endif()
endfunction() endfunction()
# This is a copy of the first few lines in FindPkgConfig.cmake.
function(qt_build_internals_find_pkg_config_executable)
# find pkg-config, use PKG_CONFIG if set
if((NOT PKG_CONFIG_EXECUTABLE) AND (NOT "$ENV{PKG_CONFIG}" STREQUAL ""))
set(PKG_CONFIG_EXECUTABLE "$ENV{PKG_CONFIG}" CACHE FILEPATH "pkg-config executable")
endif()
find_program(PKG_CONFIG_EXECUTABLE NAMES pkg-config DOC "pkg-config executable")
mark_as_advanced(PKG_CONFIG_EXECUTABLE)
endfunction()
function(qt_build_internals_disable_pkg_config) function(qt_build_internals_disable_pkg_config)
# Disable pkg-config by setting an empty executable path. There's no documented way to # Disable pkg-config by setting an empty executable path. There's no documented way to
# mark the package as found, but force all pkg_check_modules calls to do nothing. # mark the package as not found, but we can force all pkg_check_modules calls to do nothing
# by setting the variable to an empty value.
set(PKG_CONFIG_EXECUTABLE "" CACHE STRING "Disabled pkg-config usage." FORCE) set(PKG_CONFIG_EXECUTABLE "" CACHE STRING "Disabled pkg-config usage." FORCE)
endfunction() endfunction()