Jump to content

CMake Port/Configure System: Difference between revisions

From Qt Wiki
Kkoehne (talk | contribs)
No edit summary
Kkoehne (talk | contribs)
No edit summary
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
This is supposed to be a reference of Qt-specific CMake functions one can use in <tt>configure.cmake</tt> files.  
This is supposed to be a reference of Qt-specific CMake functions one can use in <tt>configure.cmake</tt> files. Since the port currently is still evolving quite rapidly, things may change. The ultimate reference is the code in [http://code.qt.io/cgit/qt/qtbase.git/tree/cmake?h=wip/cmake qtbase/cmake/].


== CMake Functions ==
== CMake Functions ==


=== qt_feature(<name> ...) ===
=== qt_feature("<feature>" ...) ===


Declares a Qt feature.  
Defines a feature called <feature>.  Whether a feature is enabled can be then elsewhere be checked by <tt>QT_FEATURE_<name></tt>.


<code>qt_feature(<name> [PRIVATE] [PUBLIC]  
<code>qt_feature("<feature>" [PUBLIC] [PRIVATE]
                 [LABEL <label>]  
                 [LABEL "<label>"]  
                 [PURPOSE <purpose>]  
                 [PURPOSE "<purpose>"]  
                 [SECTION <selection>]  
                 [SECTION "<selection>"]  
                 [AUTODETECT <condition>]  
                 [AUTODETECT <condition>]  
                 [CONDITION <condition>]
                 [CONDITION <condition>]
Line 17: Line 17:
                 [EMIT_IF <condition>])</code>
                 [EMIT_IF <condition>])</code>


Defines a feature called <name> .  
<tt>PUBLIC</tt> or <tt>PRIVATE</tt> defines whether the feature is available within the Qt module, or also in other Qt modules.


=== qt_evaluate_feature ===
=== qt_feature_definition("<feature>" "<name>" ...) ===


Declares a Qt feature.  
Makes a C++ define <tt><name></tt> available.


== CMake Macros ==
<code>
qt_feature_definition("<feature>" "<name>" [NEGATE] [VALUE "<value>"])
</code>


=== qt_parse_all_arguments ===
If <tt>&lt;value&gt;</tt> is set, the define will have this as value.


A version of cmake_parse_arguments that makes sure all arguments are processed and errors out with a message about ${type} having received unknown arguments.
If <tt>NEGATE</tt> is given, the define is set only if the feature is disabled. Otherwise it is set only if it is enabled.
 
''Internal API.''
 
<code>qt_parse_all_arguments(<result> <type> <flags> <options> <multiopts>)</code>

Latest revision as of 13:44, 11 February 2019

This is supposed to be a reference of Qt-specific CMake functions one can use in configure.cmake files. Since the port currently is still evolving quite rapidly, things may change. The ultimate reference is the code in qtbase/cmake/.

CMake Functions

qt_feature("<feature>" ...)

Defines a feature called <feature>. Whether a feature is enabled can be then elsewhere be checked by QT_FEATURE_<name>.

qt_feature("<feature>" [PUBLIC] [PRIVATE]  
                [LABEL "<label>"] 
                [PURPOSE "<purpose>"] 
                [SECTION "<selection>"] 
                [AUTODETECT <condition>] 
                [CONDITION <condition>]
                [ENABLE <condition>]
                [DISABLE <condition>]
                [EMIT_IF <condition>])

PUBLIC or PRIVATE defines whether the feature is available within the Qt module, or also in other Qt modules.

qt_feature_definition("<feature>" "<name>" ...)

Makes a C++ define <name> available.

qt_feature_definition("<feature>" "<name>" [NEGATE] [VALUE "<value>"])

If <value> is set, the define will have this as value.

If NEGATE is given, the define is set only if the feature is disabled. Otherwise it is set only if it is enabled.