cmake: Avoid hardcoding Qt's major version in Find module

This change facilitates future migration to Qt 6.
This commit is contained in:
Hennadii Stepanov 2024-10-01 13:43:30 +01:00
parent fc642c33ef
commit deacf3c7cd
No known key found for this signature in database
GPG key ID: 410108112E7EA81F
2 changed files with 13 additions and 13 deletions

View file

@ -177,7 +177,7 @@ if(BUILD_GUI)
if(BUILD_GUI_TESTS) if(BUILD_GUI_TESTS)
list(APPEND qt_components Test) list(APPEND qt_components Test)
endif() endif()
find_package(Qt5 5.11.3 MODULE REQUIRED find_package(Qt 5.11.3 MODULE REQUIRED
COMPONENTS ${qt_components} COMPONENTS ${qt_components}
) )
unset(qt_components) unset(qt_components)

View file

@ -3,10 +3,10 @@
# file COPYING or https://opensource.org/license/mit/. # file COPYING or https://opensource.org/license/mit/.
#[=======================================================================[ #[=======================================================================[
FindQt5 FindQt
------- ------
Finds the Qt 5 headers and libraries. Finds the Qt headers and libraries.
This is a wrapper around find_package() command that: This is a wrapper around find_package() command that:
- facilitates searching in various build environments - facilitates searching in various build environments
@ -19,7 +19,7 @@ if(CMAKE_HOST_APPLE)
find_program(HOMEBREW_EXECUTABLE brew) find_program(HOMEBREW_EXECUTABLE brew)
if(HOMEBREW_EXECUTABLE) if(HOMEBREW_EXECUTABLE)
execute_process( execute_process(
COMMAND ${HOMEBREW_EXECUTABLE} --prefix qt@5 COMMAND ${HOMEBREW_EXECUTABLE} --prefix qt@${Qt_FIND_VERSION_MAJOR}
OUTPUT_VARIABLE _qt_homebrew_prefix OUTPUT_VARIABLE _qt_homebrew_prefix
ERROR_QUIET ERROR_QUIET
OUTPUT_STRIP_TRAILING_WHITESPACE OUTPUT_STRIP_TRAILING_WHITESPACE
@ -40,10 +40,10 @@ endif()
# /usr/x86_64-w64-mingw32/lib/libm.a or /usr/arm-linux-gnueabihf/lib/libm.a. # /usr/x86_64-w64-mingw32/lib/libm.a or /usr/arm-linux-gnueabihf/lib/libm.a.
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY BOTH) set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY BOTH)
find_package(Qt5 ${Qt5_FIND_VERSION} find_package(Qt${Qt_FIND_VERSION_MAJOR} ${Qt_FIND_VERSION}
COMPONENTS ${Qt5_FIND_COMPONENTS} COMPONENTS ${Qt_FIND_COMPONENTS}
HINTS ${_qt_homebrew_prefix} HINTS ${_qt_homebrew_prefix}
PATH_SUFFIXES Qt5 # Required on OpenBSD systems. PATH_SUFFIXES Qt${Qt_FIND_VERSION_MAJOR} # Required on OpenBSD systems.
) )
unset(_qt_homebrew_prefix) unset(_qt_homebrew_prefix)
@ -56,11 +56,11 @@ else()
endif() endif()
include(FindPackageHandleStandardArgs) include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(Qt5 find_package_handle_standard_args(Qt
REQUIRED_VARS Qt5_DIR REQUIRED_VARS Qt${Qt_FIND_VERSION_MAJOR}_DIR
VERSION_VAR Qt5_VERSION VERSION_VAR Qt${Qt_FIND_VERSION_MAJOR}_VERSION
) )
foreach(component IN LISTS Qt5_FIND_COMPONENTS ITEMS "") foreach(component IN LISTS Qt_FIND_COMPONENTS ITEMS "")
mark_as_advanced(Qt5${component}_DIR) mark_as_advanced(Qt${Qt_FIND_VERSION_MAJOR}${component}_DIR)
endforeach() endforeach()