|
@@ -12,8 +12,8 @@ When this property is set ``ON``, CMake will scan the header and
|
|
|
source files at build time and invoke moc accordingly.
|
|
|
|
|
|
* If an ``#include`` statement like ``#include "moc_<basename>.cpp"`` is found,
|
|
|
- the ``Q_OBJECT`` or ``Q_GADGET`` macros are expected in an otherwise empty
|
|
|
- line of the ``<basename>.h(xx)`` header file. ``moc`` is run on the header
|
|
|
+ a macro from :prop_tgt:`AUTOMOC_MACRO_NAMES` is expected to appear in the
|
|
|
+ ``<basename>.h(xx)`` header file. ``moc`` is run on the header
|
|
|
file to generate ``moc_<basename>.cpp`` in the
|
|
|
``<AUTOGEN_BUILD_DIR>/include`` directory which is automatically added
|
|
|
to the target's :prop_tgt:`INCLUDE_DIRECTORIES`.
|
|
@@ -26,11 +26,12 @@ source files at build time and invoke moc accordingly.
|
|
|
* See :prop_tgt:`AUTOGEN_BUILD_DIR`.
|
|
|
|
|
|
* If an ``#include`` statement like ``#include "<basename>.moc"`` is found,
|
|
|
- then ``Q_OBJECT`` or ``Q_GADGET`` macros are expected in the current source
|
|
|
- file and ``moc`` is run on the source file itself.
|
|
|
+ a macro from :prop_tgt:`AUTOMOC_MACRO_NAMES` is expected to appear in the
|
|
|
+ source file and ``moc`` is run on the source file itself.
|
|
|
|
|
|
* Header files that are not included by an ``#include "moc_<basename>.cpp"``
|
|
|
- statement are nonetheless scanned for ``Q_OBJECT`` or ``Q_GADGET`` macros.
|
|
|
+ statement are nonetheless scanned for a macro out of
|
|
|
+ :prop_tgt:`AUTOMOC_MACRO_NAMES`.
|
|
|
The resulting ``moc_<basename>.cpp`` files are generated in custom
|
|
|
directories and automatically included in a generated
|
|
|
``<AUTOGEN_BUILD_DIR>/mocs_compilation.cpp`` file,
|
|
@@ -44,8 +45,9 @@ source files at build time and invoke moc accordingly.
|
|
|
|
|
|
* Additionally, header files with the same base name as a source file,
|
|
|
(like ``<basename>.h``) or ``_p`` appended to the base name (like
|
|
|
- ``<basename>_p.h``), are parsed for ``Q_OBJECT`` or ``Q_GADGET`` macros,
|
|
|
- and if found, ``moc`` is also executed on those files.
|
|
|
+ ``<basename>_p.h``), are scanned for a macro out of
|
|
|
+ :prop_tgt:`AUTOMOC_MACRO_NAMES`, and if found, ``moc``
|
|
|
+ is also executed on those files.
|
|
|
|
|
|
* ``AUTOMOC`` always checks multiple header alternative extensions,
|
|
|
such as ``hpp``, ``hxx``, etc. when searching for headers.
|
|
@@ -69,9 +71,7 @@ automoc targets together in an IDE, e.g. in MSVS.
|
|
|
The global property :prop_gbl:`AUTOGEN_SOURCE_GROUP` can be used to group
|
|
|
files generated by :prop_tgt:`AUTOMOC` together in an IDE, e.g. in MSVS.
|
|
|
|
|
|
-The appearance of the strings ``Q_OBJECT`` or ``Q_GADGET`` in a source file
|
|
|
-determines if it needs to be ``moc`` processed. To search for additional
|
|
|
-strings, list them in :prop_tgt:`AUTOMOC_MACRO_NAMES`.
|
|
|
+Additional macro names to search for can be added to :prop_tgt:`AUTOMOC_MACRO_NAMES`.
|
|
|
|
|
|
Additional ``moc`` dependency file names can be extracted from source code
|
|
|
by using :prop_tgt:`AUTOMOC_DEPEND_FILTERS`.
|