From 5769e1a2f6016cf807d20e09083b893f0c628d07 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jean-Micha=C3=ABl=20Celerier?= Date: Fri, 7 Jun 2019 09:13:31 +0200 Subject: cmake: allow client apps to load static plug-ins Based in part on Kyle Edwards's implementation : https://codereview.qt-project.org/c/qt/qtbase/+/243731 Example : ``` cmake_minimum_required(VERSION 3.15) project(foo) add_executable(foo main.cpp) find_package(ICU COMPONENTS i18n uc data REQUIRED) find_package(Qt6 COMPONENTS Core Gui REQUIRED) target_link_libraries(foo Qt6::Core Qt6::Gui) qt_import_plugins(foo INCLUDE Qt6::qxcb EXCLUDE Qt6::qgtk3 Qt6::qeglfs-kms-integration Qt6::qjpeg ) ``` Change-Id: If7736c42f669f7d7f43052cae59c28fc7fcb4156 Reviewed-by: Alexandru Croitor --- cmake/QtBuild.cmake | 2 +- cmake/QtPlugins.cmake.in | 40 ++++++++++++++++++++++++++++++++++++++++ cmake/QtPostProcess.cmake | 34 +++++++++++++++++----------------- 3 files changed, 58 insertions(+), 18 deletions(-) create mode 100644 cmake/QtPlugins.cmake.in (limited to 'cmake') diff --git a/cmake/QtBuild.cmake b/cmake/QtBuild.cmake index 0852d8ed2f..b2c25b5ef6 100644 --- a/cmake/QtBuild.cmake +++ b/cmake/QtBuild.cmake @@ -1465,7 +1465,7 @@ function(add_qt_plugin target) "${arg_ARCHIVE_INSTALL_DIRECTORY}" "${arg_TYPE}" "${INSTALL_LIBDIR}/${arg_TYPE}" archive_install_directory) - if(arg_STATIC) + if(arg_STATIC OR NOT BUILD_SHARED_LIBS) add_library("${target}" STATIC) else() add_library("${target}" MODULE) diff --git a/cmake/QtPlugins.cmake.in b/cmake/QtPlugins.cmake.in new file mode 100644 index 0000000000..b51c7cec29 --- /dev/null +++ b/cmake/QtPlugins.cmake.in @@ -0,0 +1,40 @@ +@QT_MODULE_PLUGIN_INCLUDES@ + +if(NOT @BUILD_SHARED_LIBS@) + set(_module_target "@INSTALL_CMAKE_NAMESPACE@::@QT_MODULE@") + + set(_default_plugins_genex "$>") + set(_manual_plugins_genex "$>") + set(_no_plugins_genex "$>") + + foreach(target @qt_plugins@) + set(_plugin_target "@INSTALL_CMAKE_NAMESPACE@::${target}") + get_target_property(_classname "${_plugin_target}" QT_PLUGIN_CLASS_NAME) + if(NOT _classname) + message("Warning: plugin ${_plugin_target} has no class name, skipping.") + continue() + endif() + + set(_user_specified_genex "$") + + string(CONCAT _plugin_condition + "$>" + ">" + ">>" + ) + set(_plugin_genex "$<${_plugin_condition}:${_plugin_target}>") + target_link_libraries(${_module_target} INTERFACE "${_plugin_genex}") + file(GENERATE + OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/qt_@QT_MODULE@_${target}.cpp" + CONTENT "#include \nQ_IMPORT_PLUGIN(${_classname})" + ) + target_sources(${_module_target} INTERFACE "$<${_plugin_condition}:${CMAKE_CURRENT_BINARY_DIR}/qt_@QT_MODULE@_${target}.cpp>") + endforeach() +endif() diff --git a/cmake/QtPostProcess.cmake b/cmake/QtPostProcess.cmake index 53b89f22f1..f56eb801ea 100644 --- a/cmake/QtPostProcess.cmake +++ b/cmake/QtPostProcess.cmake @@ -239,26 +239,26 @@ endfunction() # the plug-in target files. function(qt_internal_create_plugins_files) message("Generating Plugins files for ${QT_KNOWN_MODULES}...") - foreach (target ${QT_KNOWN_MODULES}) - qt_path_join(config_build_dir ${QT_CONFIG_BUILD_DIR} ${INSTALL_CMAKE_NAMESPACE}${target}) - qt_path_join(config_install_dir ${QT_CONFIG_INSTALL_DIR} ${INSTALL_CMAKE_NAMESPACE}${target}) + foreach (QT_MODULE ${QT_KNOWN_MODULES}) + qt_path_join(config_build_dir ${QT_CONFIG_BUILD_DIR} ${INSTALL_CMAKE_NAMESPACE}${QT_MODULE}) + qt_path_join(config_install_dir ${QT_CONFIG_INSTALL_DIR} ${INSTALL_CMAKE_NAMESPACE}${QT_MODULE}) + set(QT_MODULE_PLUGIN_INCLUDES "") - set(_plugins_file "") - get_target_property(qt_plugins "${target}" QT_PLUGINS) + get_target_property(qt_plugins "${QT_MODULE}" QT_PLUGINS) if(qt_plugins) - foreach (plugin ${qt_plugins}) - set(_plugins_file "${_plugins_file}include(\"\${CMAKE_CURRENT_LIST_DIR}/${plugin}Config.cmake\")\n") + foreach (pluginTarget ${qt_plugins}) + set(QT_MODULE_PLUGIN_INCLUDES "${QT_MODULE_PLUGIN_INCLUDES}include(\"\${CMAKE_CURRENT_LIST_DIR}/${pluginTarget}Config.cmake\")\n") endforeach() - - if(NOT ("x${_plugins_file}" STREQUAL "x")) - file(WRITE "${config_build_dir}/${INSTALL_CMAKE_NAMESPACE}${target}Plugins.cmake" "${_plugins_file}") - - qt_install(FILES - "${config_build_dir}/${INSTALL_CMAKE_NAMESPACE}${target}Plugins.cmake" - DESTINATION "${config_install_dir}" - COMPONENT Devel - ) - endif() + configure_file( + "${QT_CMAKE_DIR}/QtPlugins.cmake.in" + "${config_build_dir}/${INSTALL_CMAKE_NAMESPACE}${QT_MODULE}Plugins.cmake" + @ONLY + ) + qt_install(FILES + "${config_build_dir}/${INSTALL_CMAKE_NAMESPACE}${QT_MODULE}Plugins.cmake" + DESTINATION "${config_install_dir}" + COMPONENT Devel + ) endif() endforeach() endfunction() -- cgit v1.2.3