summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorCraig Scott <craig.scott@crascit.com>2021-11-07 05:09:42 (GMT)
committerCraig Scott <craig.scott@crascit.com>2021-11-07 05:09:42 (GMT)
commit76c0281421dae544ae7931309dae376a28d5f877 (patch)
treee70089e7196b5593662d9d06c7fb629c603a176e /Modules
parentced697d2846abea4b320647a46213c6e130c9a8b (diff)
downloadCMake-76c0281421dae544ae7931309dae376a28d5f877.zip
CMake-76c0281421dae544ae7931309dae376a28d5f877.tar.gz
CMake-76c0281421dae544ae7931309dae376a28d5f877.tar.bz2
Help: Clarify how PKG_CONFIG env var initializes cache vars
Fixes: #22870
Diffstat (limited to 'Modules')
-rw-r--r--Modules/FindPkgConfig.cmake49
1 files changed, 33 insertions, 16 deletions
diff --git a/Modules/FindPkgConfig.cmake b/Modules/FindPkgConfig.cmake
index 4de5331..ef43a3a 100644
--- a/Modules/FindPkgConfig.cmake
+++ b/Modules/FindPkgConfig.cmake
@@ -12,13 +12,24 @@ Finds the ``pkg-config`` executable and adds the :command:`pkg_get_variable`,
following variables will also be set:
``PKG_CONFIG_FOUND``
- if pkg-config executable was found
+ True if a pkg-config executable was found.
+
+``PKG_CONFIG_VERSION_STRING``
+ .. versionadded:: 2.8.8
+
+ The version of pkg-config that was found.
+
``PKG_CONFIG_EXECUTABLE``
- pathname of the pkg-config program
+ The pathname of the pkg-config program.
+
``PKG_CONFIG_ARGN``
- list of arguments to pass to pkg-config
-``PKG_CONFIG_VERSION_STRING``
- version of pkg-config (since CMake 2.8.8)
+ .. versionadded:: 3.22
+
+ A list of arguments to pass to pkg-config.
+
+Both ``PKG_CONFIG_EXECUTABLE`` and ``PKG_CONFIG_ARGN`` are initialized by the
+module, but may be overridden by the user. See `Variables Affecting Behavior`_
+for how these variables are initialized.
#]========================================]
@@ -923,24 +934,30 @@ Variables Affecting Behavior
.. variable:: PKG_CONFIG_EXECUTABLE
- This can be set to the path of the pkg-config executable. If not provided,
- it will be set by the module as a result of calling :command:`find_program`
- internally.
+ This cache variable can be set to the path of the pkg-config executable.
+ :command:`find_program` is called internally by the module with this
+ variable.
.. versionadded:: 3.1
- The ``PKG_CONFIG`` environment variable can be used as a hint.
+ The ``PKG_CONFIG`` environment variable can be used as a hint if
+ ``PKG_CONFIG_EXECUTABLE`` has not yet been set.
+
+ .. versionchanged:: 3.22
+ If the ``PKG_CONFIG`` environment variable is set, only the first
+ argument is taken from it when using it as a hint.
.. variable:: PKG_CONFIG_ARGN
.. versionadded:: 3.22
- This can be set to a list of arguments to additionally pass to pkg-config
- if needed. If not provided, it will be an empty string, however, if the
- environment variable ``PKG_CONFIG`` is provided, this will be set to the
- result of splitting the variable.
-
- The ``PKG_CONFIG`` environment variable can be used to provide both
- ``PKG_CONFIG_EXECUTABLE`` and ``PKG_CONFIG_ARGN``
+ This cache variable can be set to a list of arguments to additionally pass
+ to pkg-config if needed. If not provided, it will be initialized from the
+ ``PKG_CONFIG`` environment variable, if set. The first argument in that
+ environment variable is assumed to be the pkg-config program, while all
+ remaining arguments after that are used to initialize ``PKG_CONFIG_ARGN``.
+ If no such environment variable is defined, ``PKG_CONFIG_ARGN`` is
+ initialized to an empty string. The module does not update the variable once
+ it has been set in the cache.
.. variable:: PKG_CONFIG_USE_CMAKE_PREFIX_PATH