|
|
@@ -1,21 +1,27 @@
|
|
|
AUTOMOC_DEPEND_FILTERS
|
|
|
----------------------
|
|
|
|
|
|
-Filter definitions used by :prop_tgt:`AUTOMOC` to extract file names from
|
|
|
-source code as additional dependencies for the ``moc`` file.
|
|
|
-
|
|
|
-This property is only used if the :prop_tgt:`AUTOMOC` property is ``ON``
|
|
|
-for this target.
|
|
|
+Filter definitions used by :prop_tgt:`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.
|
|
|
|
|
|
-Consider a filter extracts the file name ``DEP`` from the content of a file
|
|
|
-``FOO``. If ``DEP`` changes, then the ``moc`` file for ``FOO`` gets rebuilt.
|
|
|
-The file ``DEP`` is searched for first in the vicinity
|
|
|
-of ``FOO`` and afterwards in the target's :prop_tgt:`INCLUDE_DIRECTORIES`.
|
|
|
+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 :prop_tgt:`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 :prop_sf:`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 :prop_tgt:`AUTOGEN_TARGET_DEPENDS` for reference.
|
|
|
|
|
|
By default :prop_tgt:`AUTOMOC_DEPEND_FILTERS` is initialized from
|
|
|
:variable:`CMAKE_AUTOMOC_DEPEND_FILTERS`, which is empty by default.
|
|
|
@@ -24,22 +30,75 @@ See the :manual:`cmake-qt(7)` manual for more information on using CMake
|
|
|
with Qt.
|
|
|
|
|
|
|
|
|
-Example
|
|
|
-^^^^^^^
|
|
|
+Example 1
|
|
|
+^^^^^^^^^
|
|
|
|
|
|
-Consider a file ``FOO.hpp`` holds a custom macro ``OBJ_JSON_FILE`` and we
|
|
|
-want the ``moc`` file to depend on the macro`s file name argument::
|
|
|
+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
|
|
|
- OBJ_JSON_FILE ( "DEP.json" )
|
|
|
+ JSON_FILE_MACRO ( "info.json" )
|
|
|
+ ...
|
|
|
+ };
|
|
|
+
|
|
|
+In ``CMakeLists.txt`` we add a filter to
|
|
|
+:variable:`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 :prop_sf:`GENERATED`) file that is
|
|
|
+listed in the target's source. Therefore we do not need to add it to
|
|
|
+:prop_tgt:`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() {} \
|
|
|
};
|
|
|
+ ...
|
|
|
+
|
|
|
+::
|
|
|
|
|
|
-Then we might use :variable:`CMAKE_AUTOMOC_DEPEND_FILTERS` to
|
|
|
-define a filter like this::
|
|
|
+ // complex_class.hpp
|
|
|
+ #pragma once
|
|
|
+ JSON_BASED_CLASS(Complex_Class, "meta.json")
|
|
|
+ // end of file
|
|
|
|
|
|
- set(CMAKE_AUTOMOC_DEPEND_FILTERS
|
|
|
- "OBJ_JSON_FILE" "[\n][ \t]*OBJ_JSON_FILE[ \t]*\\([ \t]*\"([^\"]+)\""
|
|
|
+Since ``complex_class.hpp`` doesn't contain a ``Q_OBJECT`` macro it would be
|
|
|
+ignored by :prop_tgt:`AUTOMOC`. We change this by adding ``JSON_BASED_CLASS``
|
|
|
+to :variable:`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
|
|
|
+:variable:`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 :prop_sf:`GENERATED` which is
|
|
|
+why we have to add it to :prop_tgt:`AUTOGEN_TARGET_DEPENDS`::
|
|
|
+
|
|
|
+ set_property(TARGET my_target APPEND PROPERTY AUTOGEN_TARGET_DEPENDS "meta.json")
|