include_guard(DIRECTORY) @QT_MODULE_PLUGIN_INCLUDES@ if(NOT @BUILD_SHARED_LIBS@) set(_module_target "@INSTALL_CMAKE_NAMESPACE@::@QT_MODULE@") # Properties can't be set on aliased targets, so make sure to unalias the target. This is needed # when Qt examples are built as part of the Qt build itself. get_target_property(_aliased_target ${_module_target} ALIASED_TARGET) if(_aliased_target) set(_module_target ${_aliased_target}) endif() unset(_aliased_target) set(_default_plugins_are_enabled "$>,0>>") # Make sure to boolify the result of the expression, in case if the returned property value # is empty. set(_default_plugins_are_enabled_wrapped "$") set(_manual_plugins_genex "$>") set(_no_plugins_genex "$>") # In super builds the rules below pollute the dependency rule for the # plugin target when it's being build, causing cyclic dependencies. # to overcome this, we check if the current target where this rule evaluates # has a QT_BUILD_PROJECT_NAME equal to the current PROJECT_NAME. # If so we disable the injection of plugin link rules to avoid cyclic # dependencies. if (@QT_SUPERBUILD@) set(_build_allow_plugin_link_rules_genex "$,@PROJECT_NAME@>>") else() set(_build_allow_plugin_link_rules_genex 1) endif() # The code in here uses the properties defined in qt_import_plugins (Qt6CoreMacros.cmake) foreach(target @qt_plugins@) set(_plugin_target "@INSTALL_CMAKE_NAMESPACE@::${target}") set(_plugin_target_versionless "Qt::${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() get_target_property(_plugin_type "${_plugin_target}" QT_PLUGIN_TYPE) if(NOT _plugin_type) message("Warning: plugin ${_plugin_target} has no type ('${_plugin_type}'), skipping.") continue() endif() list(APPEND "QT_ALL_PLUGINS_FOUND_BY_FIND_PACKAGE_${_plugin_type}" "${target}") set(_plugin_is_default "$") # INCLUDE set(_plugin_is_whitelisted "$") set(_plugin_versionless_is_whitelisted "$") # Note: qt_import_plugins sets the QT_PLUGINS_${_plugin_type} to "-" # when excluding it with EXCLUDE_BY_TYPE, # which ensures that no plug-in will be supported unless explicitly re-added afterwards. string(CONCAT _plugin_is_not_blacklisted "$" ">," "$" ">," # Excludes both plugins targeted by EXCLUDE_BY_TYPE and not included in # INCLUDE_BY_TYPE. "$>>" ">" ) # Support INCLUDE_BY_TYPE string(CONCAT _plugin_is_in_type_whitelist "$" ">" ">" ) string(CONCAT _plugin_versionless_is_in_type_whitelist "$" ">" ">" ) # Complete condition that defines whether a static plugin is linked string(CONCAT _plugin_condition "$" ">" ">>" ) # If this condition is true, we link against the plug-in set(_plugin_genex "$<${_plugin_condition}:${_plugin_target}>") target_link_libraries(${_module_target} INTERFACE "${_plugin_genex}") set(_generated_qt_plugin_file_name "${CMAKE_CURRENT_BINARY_DIR}/qt_@QT_MODULE@_${target}.cpp") set(_generated_qt_plugin_file_name_template "${_generated_qt_plugin_file_name}.in") set(_generated_qt_plugin_file_content "#include \nQ_IMPORT_PLUGIN(${_classname})") # Generate a source file to import that plug-in. Has to be done with configure_file, # because file(GENERATE) and target_sources has issues with scopes. file(WRITE "${_generated_qt_plugin_file_name_template}" "${_generated_qt_plugin_file_content}") configure_file("${_generated_qt_plugin_file_name_template}" "${_generated_qt_plugin_file_name}") target_sources(${_module_target} INTERFACE "$<${_plugin_condition}:${_generated_qt_plugin_file_name}>") endforeach() endif()