cmake/Help/command/target_sources.rst

49 lines
1.8 KiB
ReStructuredText
Raw Normal View History

2015-04-27 22:25:09 +02:00
target_sources
--------------
2021-09-14 00:13:48 +02:00
.. versionadded:: 3.1
2015-04-27 22:25:09 +02:00
Add sources to a target.
2019-11-11 23:01:05 +01:00
.. code-block:: cmake
2015-04-27 22:25:09 +02:00
target_sources(<target>
<INTERFACE|PUBLIC|PRIVATE> [items1...]
[<INTERFACE|PUBLIC|PRIVATE> [items2...] ...])
2021-09-14 00:13:48 +02:00
Specifies sources to use when building a target and/or its dependents.
The named ``<target>`` must have been created by a command such as
:command:`add_executable` or :command:`add_library` or
:command:`add_custom_target` and must not be an
2018-04-23 21:13:27 +02:00
:ref:`ALIAS target <Alias Targets>`.
2015-04-27 22:25:09 +02:00
2021-09-14 00:13:48 +02:00
.. versionchanged:: 3.13
Relative source file paths are interpreted as being relative to the current
source directory (i.e. :variable:`CMAKE_CURRENT_SOURCE_DIR`).
See policy :policy:`CMP0076`.
.. versionadded:: 3.20
``<target>`` can be a custom target.
2015-04-27 22:25:09 +02:00
The ``INTERFACE``, ``PUBLIC`` and ``PRIVATE`` keywords are required to
2021-09-14 00:13:48 +02:00
specify the scope of the items following them. ``PRIVATE`` and ``PUBLIC``
2015-04-27 22:25:09 +02:00
items will populate the :prop_tgt:`SOURCES` property of
2021-09-14 00:13:48 +02:00
``<target>``, which are used when building the target itself.
``PUBLIC`` and ``INTERFACE`` items will populate the
:prop_tgt:`INTERFACE_SOURCES` property of ``<target>``, which are used
when building dependents.
2018-04-23 21:13:27 +02:00
The following arguments specify sources. Repeated calls for the same
2021-09-14 00:13:48 +02:00
``<target>`` append items in the order called. The targets created by
:command:`add_custom_target` can only have ``PRIVATE`` scope.
.. versionadded:: 3.3
Allow exporting targets with :prop_tgt:`INTERFACE_SOURCES`.
.. versionadded:: 3.11
Allow setting ``INTERFACE`` items on :ref:`IMPORTED targets <Imported Targets>`.
2015-04-27 22:25:09 +02:00
Arguments to ``target_sources`` may use "generator expressions"
with the syntax ``$<...>``. See the :manual:`cmake-generator-expressions(7)`
manual for available expressions. See the :manual:`cmake-buildsystem(7)`
manual for more on defining buildsystem properties.