summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKyle Edwards <kyle.edwards@kitware.com>2018-04-20 13:04:47 (GMT)
committerBrad King <brad.king@kitware.com>2018-05-03 12:08:42 (GMT)
commitc02eeb08536e14c773961f9288b83a950cee6b55 (patch)
treead10056b2e7992fe4ea7fd3aae26734560d8d0d0
parentedcb545a24ed2df83813a89a20bb2beefe0531c1 (diff)
downloadCMake-c02eeb08536e14c773961f9288b83a950cee6b55.zip
CMake-c02eeb08536e14c773961f9288b83a950cee6b55.tar.gz
CMake-c02eeb08536e14c773961f9288b83a950cee6b55.tar.bz2
Help: clarify "undefined behavior" in install(EXPORT) command
The "undefined behavior" that the install(EXPORT) command warned about was simply the possibility of build errors (or other errors) if the referenced targets aren't installed. As long as the referenced targets are installed, this won't be an issue.
-rw-r--r--Help/command/install.rst23
1 files changed, 18 insertions, 5 deletions
diff --git a/Help/command/install.rst b/Help/command/install.rst
index 63ba210..a81714f 100644
--- a/Help/command/install.rst
+++ b/Help/command/install.rst
@@ -456,11 +456,24 @@ generated import file will reference only the matching target
configurations. The ``EXPORT_LINK_INTERFACE_LIBRARIES`` keyword, if
present, causes the contents of the properties matching
``(IMPORTED_)?LINK_INTERFACE_LIBRARIES(_<CONFIG>)?`` to be exported, when
-policy :policy:`CMP0022` is ``NEW``. If a ``COMPONENT`` option is
-specified that does not match that given to the targets associated with
-``<export-name>`` the behavior is undefined. If a library target is
-included in the export but a target to which it links is not included
-the behavior is unspecified.
+policy :policy:`CMP0022` is ``NEW``.
+
+When a ``COMPONENT`` option is given, the listed ``<component>`` implicitly
+depends on all components mentioned in the export set. The exported
+``<name>.cmake`` file will require each of the exported components to be
+present in order for dependent projects to build properly. For example, a
+project may define components ``Runtime`` and ``Development``, with shared
+libraries going into the ``Runtime`` component and static libraries and
+headers going into the ``Development`` component. The export set would also
+typically be part of the ``Development`` component, but it would export
+targets from both the ``Runtime`` and ``Development`` components. Therefore,
+the ``Runtime`` component would need to be installed if the ``Development``
+component was installed, but not vice versa. If the ``Development`` component
+was installed without the ``Runtime`` component, dependent projects that try
+to link against it would have build errors. Package managers, such as APT and
+RPM, typically handle this by listing the ``Runtime`` component as a dependency
+of the ``Development`` component in the package metadata, ensuring that the
+library is always installed if the headers and CMake export file are present.
In addition to cmake language files, the ``EXPORT_ANDROID_MK`` mode maybe
used to specify an export to the android ndk build system. This mode