AUTOMOC_DEPEND_FILTERS
Filter definitions used by AUTOMOC
to extract file names from a source file that are registered as additional dependencies for the moc
file of the source file.
Filters are defined as KEYWORD;REGULAR_EXPRESSION
pairs. First the file content is searched for KEYWORD
. If it is found at least once, then file names are extracted by successively searching for REGULAR_EXPRESSION
and taking the first match group.
The file name found in the first match group is searched for
- first in the vicinity of the source file
- and afterwards in the target’s
INCLUDE_DIRECTORIES
.
If any of the extracted files changes, then the moc
file for the source file gets rebuilt even when the source file itself doesn’t change.
If any of the extracted files is GENERATED
or if it is not in the target’s sources, then it might be necessary to add it to the _autogen
target dependencies. See AUTOGEN_TARGET_DEPENDS
for reference.
By default AUTOMOC_DEPEND_FILTERS
is initialized from CMAKE_AUTOMOC_DEPEND_FILTERS
, which is empty by default.
From Qt 5.15.0 on this variable is ignored as moc is able to output the correct dependencies.
See the cmake-qt(7)
manual for more information on using CMake with Qt.
Example 1
A header file my_class.hpp
uses a custom macro JSON_FILE_MACRO
which is defined in an other header macros.hpp
. We want the moc
file of my_class.hpp
to depend on the file name argument of JSON_FILE_MACRO
:
// my_class.hpp class My_Class : public QObject { Q_OBJECT JSON_FILE_MACRO ( "info.json" ) ... };
In CMakeLists.txt
we add a filter to CMAKE_AUTOMOC_DEPEND_FILTERS
like this:
list( APPEND CMAKE_AUTOMOC_DEPEND_FILTERS "JSON_FILE_MACRO" "[\n][ \t]*JSON_FILE_MACRO[ \t]*\\([ \t]*\"([^\"]+)\"" )
We assume info.json
is a plain (not GENERATED
) file that is listed in the target’s source. Therefore we do not need to add it to AUTOGEN_TARGET_DEPENDS
.
Example 2
In the target my_target
a header file complex_class.hpp
uses a custom macro JSON_BASED_CLASS
which is defined in an other header macros.hpp
:
// macros.hpp ... #define JSON_BASED_CLASS(name, json) \ class name : public QObject \ { \ Q_OBJECT \ Q_PLUGIN_METADATA(IID "demo" FILE json) \ name() {} \ }; ...
// complex_class.hpp #pragma once JSON_BASED_CLASS(Complex_Class, "meta.json") // end of file
Since complex_class.hpp
doesn’t contain a Q_OBJECT
macro it would be ignored by AUTOMOC
. We change this by adding JSON_BASED_CLASS
to CMAKE_AUTOMOC_MACRO_NAMES
:
list(APPEND CMAKE_AUTOMOC_MACRO_NAMES "JSON_BASED_CLASS")
We want the moc
file of complex_class.hpp
to depend on meta.json
. So we add a filter to CMAKE_AUTOMOC_DEPEND_FILTERS
:
list(APPEND CMAKE_AUTOMOC_DEPEND_FILTERS "JSON_BASED_CLASS" "[\n^][ \t]*JSON_BASED_CLASS[ \t]*\\([^,]*,[ \t]*\"([^\"]+)\"" )
Additionally we assume meta.json
is GENERATED
which is why we have to add it to AUTOGEN_TARGET_DEPENDS
:
set_property(TARGET my_target APPEND PROPERTY AUTOGEN_TARGET_DEPENDS "meta.json")
© 2000–2020 Kitware, Inc. and Contributors
Licensed under the BSD 3-clause License.
https://cmake.org/cmake/help/v3.17/prop_tgt/AUTOMOC_DEPEND_FILTERS.html