qt_import_plugins
Specifies a custom set of plugins to import or exclude.
The command is defined in the Core
component of the Qt6
package, which can be loaded like so:
find_package(Qt6 REQUIRED COMPONENTS Core)
This command was introduced in Qt 5.14.
Synopsis
qt_import_plugins(target [INCLUDE plugin ...] [EXCLUDE plugin ...] [INCLUDE_BY_TYPE plugin_type plugin ...] [EXCLUDE_BY_TYPE plugin_type] [NO_DEFAULT] )
If versionless commands are disabled, use qt6_import_plugins()
instead. It supports the same set of arguments as this command.
Description
Specifies a custom set of plugins to import. The optional arguments: INCLUDE
, EXCLUDE
, INCLUDE_BY_TYPE
, and EXCLUDE_BY_TYPE
, can be used more than once.
INCLUDE
– can be used to specify a list of plugins to import.EXCLUDE
– can be used to specify a list of plugins to exclude.INCLUDE_BY_TYPE
– can be used to override the list of plugins to import for a certain plugin type.EXCLUDE_BY_TYPE
– can be used to specify a plugin type to exclude; then no plugins of that type are imported.NO_DEFAULT
– prevent the default plugins from being included automatically (for example, the default platform plugin).
Qt provides plugin types such as imageformats
, platforms
, and sqldrivers
.
Dynamic plugins
If plugins are dynamic libraries, the function controls the plugin deployment. Using this function, you may exclude specific plugin types from being packaged into an Android APK, for example:
qt_add_executable(MyApp ...) ... qt_import_plugins(MyApp EXCLUDE_BY_TYPE imageformats)
In the snippet above, all plugins that have the imageformats
type will be excluded when deploying MyApp
. The resulting Android APK will not contain any of the imageformats
plugins.
If the command isn't used, the target automatically deploys all plugins that belong to the Qt modules that the target is linked against.
Static plugins
If the command isn't used the target automatically links against a sane set of default static plugins, for each Qt module that the target is linked against. For more information, see target_link_libraries.
Each plugin comes with a C++ stub file that automatically initializes the static plugin. Consequently, any target that links against a plugin has this C++ file added to its SOURCES
.
Examples
qt_add_executable(myapp main.cpp) target_link_libraries(myapp Qt::Gui Qt::Sql) qt_import_plugins(myapp INCLUDE Qt::QCocoaIntegrationPlugin EXCLUDE Qt::QMinimalIntegrationPlugin INCLUDE_BY_TYPE imageformats Qt::QGifPlugin Qt::QJpegPlugin EXCLUDE_BY_TYPE sqldrivers )
In the snippet above, the following occurs with the executable myapp
:
- The
Qt6::QCocoaIntegrationPlugin
is imported into myapp. - The
Qt6::QMinimalIntegrationPlugin
plugin is excluded from being automatically imported into myapp. - The default list of plugins for
imageformats
is overridden to only include Qt6::QGifPlugin and Qt6::QJpegPlugin. - All
sqldrivers
plugins are excluded from automatic importing.
See also qt_import_qml_plugins().